Skip to content

Commit

Permalink
query engine integration
Browse files Browse the repository at this point in the history
  • Loading branch information
joshua-spacetime committed Dec 19, 2024
1 parent a191055 commit 3e4ae13
Show file tree
Hide file tree
Showing 23 changed files with 2,220 additions and 1,269 deletions.
24 changes: 23 additions & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 2 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ members = [
"crates/paths",
"crates/physical-plan",
"crates/primitives",
"crates/query",
"crates/sats",
"crates/schema",
"crates/sdk",
Expand Down Expand Up @@ -106,6 +107,7 @@ spacetimedb-metrics = { path = "crates/metrics", version = "1.0.0-rc2" }
spacetimedb-paths = { path = "crates/paths", version = "1.0.0-rc2" }
spacetimedb-physical-plan = { path = "crates/physical-plan", version = "1.0.0-rc2" }
spacetimedb-primitives = { path = "crates/primitives", version = "1.0.0-rc2" }
spacetimedb-query = { path = "crates/query", version = "1.0.0-rc2" }
spacetimedb-sats = { path = "crates/sats", version = "1.0.0-rc2" }
spacetimedb-schema = { path = "crates/schema", version = "1.0.0-rc2" }
spacetimedb-standalone = { path = "crates/standalone", version = "1.0.0-rc2" }
Expand Down
2 changes: 2 additions & 0 deletions crates/bench/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -31,9 +31,11 @@ bench = false
spacetimedb-client-api = { path = "../client-api" }
spacetimedb-core = { path = "../core", features = ["test"] }
spacetimedb-data-structures.workspace = true
spacetimedb-execution = { path = "../execution" }
spacetimedb-lib = { path = "../lib" }
spacetimedb-paths.workspace = true
spacetimedb-primitives = { path = "../primitives" }
spacetimedb-query = { path = "../query" }
spacetimedb-sats = { path = "../sats" }
spacetimedb-schema = { workspace = true, features = ["test"] }
spacetimedb-standalone = { path = "../standalone" }
Expand Down
29 changes: 28 additions & 1 deletion crates/bench/benches/subscription.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,14 @@ use spacetimedb::execution_context::Workload;
use spacetimedb::host::module_host::DatabaseTableUpdate;
use spacetimedb::identity::AuthCtx;
use spacetimedb::messages::websocket::BsatnFormat;
use spacetimedb::sql::ast::SchemaViewer;
use spacetimedb::subscription::query::compile_read_only_query;
use spacetimedb::subscription::subscription::ExecutionSet;
use spacetimedb::{db::relational_db::RelationalDB, messages::websocket::Compression};
use spacetimedb_bench::database::BenchDatabase as _;
use spacetimedb_bench::spacetime_raw::SpacetimeRaw;
use spacetimedb_primitives::{col_list, TableId};
use spacetimedb_query::SubscribePlan;
use spacetimedb_sats::{product, AlgebraicType, AlgebraicValue, ProductValue};

fn create_table_location(db: &RelationalDB) -> Result<TableId, DBError> {
Expand Down Expand Up @@ -99,6 +101,18 @@ fn eval(c: &mut Criterion) {
let ins_rhs = insert_op(rhs, "location", new_rhs_row);
let update = [&ins_lhs, &ins_rhs];

// A benchmark runner for the new query engine
let bench_query = |c: &mut Criterion, name, sql| {
c.bench_function(name, |b| {
let tx = raw.db.begin_tx(Workload::Subscribe);
let auth = AuthCtx::for_testing();
let schema_viewer = &SchemaViewer::new(&raw.db, &tx, &auth);
let plan = SubscribePlan::compile(sql, schema_viewer).unwrap();

b.iter(|| drop(black_box(plan.execute_bsatn(&tx))))
});
};

let bench_eval = |c: &mut Criterion, name, sql| {
c.bench_function(name, |b| {
let tx = raw.db.begin_tx(Workload::Update);
Expand All @@ -116,6 +130,19 @@ fn eval(c: &mut Criterion) {
});
};

// Join 1M rows on the left with 12K rows on the right.
// Note, this should use an index join so as not to read the entire footprint table.
let name = format!(
r#"
select f.*
from location l join footprint f on l.entity_id = f.entity_id
where l.chunk_index = {chunk_index}
"#
);

bench_query(c, "footprint-scan", "select * from footprint");
bench_query(c, "footprint-semijoin", &name);

// To profile this benchmark for 30s
// samply record -r 10000000 cargo bench --bench=subscription --profile=profiling -- full-scan --exact --profile-time=30
// Iterate 1M rows.
Expand All @@ -124,7 +151,7 @@ fn eval(c: &mut Criterion) {
// To profile this benchmark for 30s
// samply record -r 10000000 cargo bench --bench=subscription --profile=profiling -- full-join --exact --profile-time=30
// Join 1M rows on the left with 12K rows on the right.
// Note, this should use an index join so as not to read the entire lhs table.
// Note, this should use an index join so as not to read the entire footprint table.
let name = format!(
r#"
select footprint.*
Expand Down
1 change: 1 addition & 0 deletions crates/core/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ spacetimedb-table.workspace = true
spacetimedb-vm.workspace = true
spacetimedb-snapshot.workspace = true
spacetimedb-expr.workspace = true
spacetimedb-execution.workspace = true

anyhow = { workspace = true, features = ["backtrace"] }
arrayvec.workspace = true
Expand Down
13 changes: 13 additions & 0 deletions crates/core/src/db/datastore/locking_tx_datastore/tx.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,12 @@ use super::{
SharedReadGuard,
};
use crate::execution_context::ExecutionContext;
use spacetimedb_execution::Datastore;
use spacetimedb_primitives::{ColList, TableId};
use spacetimedb_sats::AlgebraicValue;
use spacetimedb_schema::schema::TableSchema;
use spacetimedb_table::blob_store::BlobStore;
use spacetimedb_table::table::Table;
use std::num::NonZeroU64;
use std::sync::Arc;
use std::{
Expand All @@ -23,6 +26,16 @@ pub struct TxId {
pub(crate) ctx: ExecutionContext,
}

impl Datastore for TxId {
fn blob_store(&self) -> &dyn BlobStore {
&self.committed_state_shared_lock.blob_store
}

fn table(&self, table_id: TableId) -> Option<&Table> {
self.committed_state_shared_lock.get_table(table_id)
}
}

impl StateView for TxId {
fn get_schema(&self, table_id: TableId) -> Option<&Arc<TableSchema>> {
self.committed_state_shared_lock.get_schema(table_id)
Expand Down
4 changes: 2 additions & 2 deletions crates/core/src/sql/parser.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,13 +3,13 @@ use crate::db::relational_db::RelationalDB;
use crate::sql::ast::SchemaViewer;
use spacetimedb_expr::check::parse_and_type_sub;
use spacetimedb_expr::errors::TypingError;
use spacetimedb_expr::expr::Project;
use spacetimedb_expr::expr::ProjectName;
use spacetimedb_lib::db::raw_def::v9::RawRowLevelSecurityDefV9;
use spacetimedb_lib::identity::AuthCtx;
use spacetimedb_schema::schema::RowLevelSecuritySchema;

pub struct RowLevelExpr {
pub sql: Project,
pub sql: ProjectName,
pub def: RowLevelSecuritySchema,
}

Expand Down
4 changes: 3 additions & 1 deletion crates/execution/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,9 @@ license-file = "LICENSE"
description = "The SpacetimeDB query engine"

[dependencies]
spacetimedb-expr.workspace = true
anyhow.workspace = true
spacetimedb-lib.workspace = true
spacetimedb-physical-plan.workspace = true
spacetimedb-primitives.workspace = true
spacetimedb-sql-parser.workspace = true
spacetimedb-table.workspace = true
Loading

0 comments on commit 3e4ae13

Please sign in to comment.