@quereus/quereus 1.1.1 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/core/database-options.d.ts.map +1 -1
- package/dist/src/core/database-options.js +9 -8
- package/dist/src/core/database-options.js.map +1 -1
- package/dist/src/core/database.d.ts.map +1 -1
- package/dist/src/core/database.js +17 -4
- package/dist/src/core/database.js.map +1 -1
- package/dist/src/emit/ast-stringify.d.ts +1 -0
- package/dist/src/emit/ast-stringify.d.ts.map +1 -1
- package/dist/src/emit/ast-stringify.js +44 -2
- package/dist/src/emit/ast-stringify.js.map +1 -1
- package/dist/src/func/builtins/aggregate.d.ts.map +1 -1
- package/dist/src/func/builtins/aggregate.js +5 -6
- package/dist/src/func/builtins/aggregate.js.map +1 -1
- package/dist/src/func/builtins/datetime.d.ts.map +1 -1
- package/dist/src/func/builtins/datetime.js +1 -3
- package/dist/src/func/builtins/datetime.js.map +1 -1
- package/dist/src/func/builtins/json-tvf.d.ts.map +1 -1
- package/dist/src/func/builtins/json-tvf.js +58 -50
- package/dist/src/func/builtins/json-tvf.js.map +1 -1
- package/dist/src/func/builtins/json.d.ts.map +1 -1
- package/dist/src/func/builtins/json.js +4 -5
- package/dist/src/func/builtins/json.js.map +1 -1
- package/dist/src/func/builtins/schema.d.ts +2 -0
- package/dist/src/func/builtins/schema.d.ts.map +1 -1
- package/dist/src/func/builtins/schema.js +5 -4
- package/dist/src/func/builtins/schema.js.map +1 -1
- package/dist/src/index.d.ts +1 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +1 -0
- package/dist/src/index.js.map +1 -1
- package/dist/src/parser/ast.d.ts +6 -3
- package/dist/src/parser/ast.d.ts.map +1 -1
- package/dist/src/parser/parser.d.ts +5 -0
- package/dist/src/parser/parser.d.ts.map +1 -1
- package/dist/src/parser/parser.js +25 -7
- package/dist/src/parser/parser.js.map +1 -1
- package/dist/src/parser/visitor.d.ts.map +1 -1
- package/dist/src/parser/visitor.js +42 -2
- package/dist/src/parser/visitor.js.map +1 -1
- package/dist/src/planner/analysis/constraint-extractor.d.ts +3 -3
- package/dist/src/planner/analysis/constraint-extractor.d.ts.map +1 -1
- package/dist/src/planner/analysis/predicate-normalizer.d.ts.map +1 -1
- package/dist/src/planner/analysis/predicate-normalizer.js +4 -2
- package/dist/src/planner/analysis/predicate-normalizer.js.map +1 -1
- package/dist/src/planner/building/block.d.ts.map +1 -1
- package/dist/src/planner/building/block.js +16 -7
- package/dist/src/planner/building/block.js.map +1 -1
- package/dist/src/planner/building/constraint-builder.js +2 -2
- package/dist/src/planner/building/constraint-builder.js.map +1 -1
- package/dist/src/planner/building/delete.js +1 -1
- package/dist/src/planner/building/delete.js.map +1 -1
- package/dist/src/planner/building/drop-index.d.ts +8 -0
- package/dist/src/planner/building/drop-index.d.ts.map +1 -0
- package/dist/src/planner/building/drop-index.js +10 -0
- package/dist/src/planner/building/drop-index.js.map +1 -0
- package/dist/src/planner/building/foreign-key-builder.d.ts.map +1 -1
- package/dist/src/planner/building/foreign-key-builder.js +5 -2
- package/dist/src/planner/building/foreign-key-builder.js.map +1 -1
- package/dist/src/planner/building/insert.js +3 -3
- package/dist/src/planner/building/insert.js.map +1 -1
- package/dist/src/planner/building/select-window.js +7 -7
- package/dist/src/planner/building/select-window.js.map +1 -1
- package/dist/src/planner/building/select.d.ts.map +1 -1
- package/dist/src/planner/building/select.js +18 -72
- package/dist/src/planner/building/select.js.map +1 -1
- package/dist/src/planner/building/update.js +2 -2
- package/dist/src/planner/building/update.js.map +1 -1
- package/dist/src/planner/framework/characteristics.d.ts +2 -0
- package/dist/src/planner/framework/characteristics.d.ts.map +1 -1
- package/dist/src/planner/nodes/add-constraint-node.d.ts +2 -6
- package/dist/src/planner/nodes/add-constraint-node.d.ts.map +1 -1
- package/dist/src/planner/nodes/add-constraint-node.js +2 -14
- package/dist/src/planner/nodes/add-constraint-node.js.map +1 -1
- package/dist/src/planner/nodes/alter-table-node.d.ts +2 -6
- package/dist/src/planner/nodes/alter-table-node.d.ts.map +1 -1
- package/dist/src/planner/nodes/alter-table-node.js +2 -14
- package/dist/src/planner/nodes/alter-table-node.js.map +1 -1
- package/dist/src/planner/nodes/bloom-join-node.d.ts +2 -8
- package/dist/src/planner/nodes/bloom-join-node.d.ts.map +1 -1
- package/dist/src/planner/nodes/bloom-join-node.js +4 -70
- package/dist/src/planner/nodes/bloom-join-node.js.map +1 -1
- package/dist/src/planner/nodes/create-assertion-node.d.ts +2 -6
- package/dist/src/planner/nodes/create-assertion-node.d.ts.map +1 -1
- package/dist/src/planner/nodes/create-assertion-node.js +2 -14
- package/dist/src/planner/nodes/create-assertion-node.js.map +1 -1
- package/dist/src/planner/nodes/cte-node.d.ts.map +1 -1
- package/dist/src/planner/nodes/cte-node.js +7 -25
- package/dist/src/planner/nodes/cte-node.js.map +1 -1
- package/dist/src/planner/nodes/declarative-schema.d.ts +4 -10
- package/dist/src/planner/nodes/declarative-schema.d.ts.map +1 -1
- package/dist/src/planner/nodes/declarative-schema.js +3 -27
- package/dist/src/planner/nodes/declarative-schema.js.map +1 -1
- package/dist/src/planner/nodes/drop-assertion-node.d.ts +2 -6
- package/dist/src/planner/nodes/drop-assertion-node.d.ts.map +1 -1
- package/dist/src/planner/nodes/drop-assertion-node.js +2 -14
- package/dist/src/planner/nodes/drop-assertion-node.js.map +1 -1
- package/dist/src/planner/nodes/drop-index-node.d.ts +18 -0
- package/dist/src/planner/nodes/drop-index-node.d.ts.map +1 -0
- package/dist/src/planner/nodes/drop-index-node.js +33 -0
- package/dist/src/planner/nodes/drop-index-node.js.map +1 -0
- package/dist/src/planner/nodes/join-node.d.ts.map +1 -1
- package/dist/src/planner/nodes/join-node.js +5 -99
- package/dist/src/planner/nodes/join-node.js.map +1 -1
- package/dist/src/planner/nodes/join-utils.d.ts +31 -0
- package/dist/src/planner/nodes/join-utils.d.ts.map +1 -0
- package/dist/src/planner/nodes/join-utils.js +86 -0
- package/dist/src/planner/nodes/join-utils.js.map +1 -0
- package/dist/src/planner/nodes/merge-join-node.d.ts +1 -1
- package/dist/src/planner/nodes/merge-join-node.d.ts.map +1 -1
- package/dist/src/planner/nodes/merge-join-node.js +4 -70
- package/dist/src/planner/nodes/merge-join-node.js.map +1 -1
- package/dist/src/planner/nodes/plan-node-type.d.ts +1 -0
- package/dist/src/planner/nodes/plan-node-type.d.ts.map +1 -1
- package/dist/src/planner/nodes/plan-node-type.js +1 -0
- package/dist/src/planner/nodes/plan-node-type.js.map +1 -1
- package/dist/src/planner/nodes/plan-node.d.ts.map +1 -1
- package/dist/src/planner/nodes/plan-node.js +1 -3
- package/dist/src/planner/nodes/plan-node.js.map +1 -1
- package/dist/src/planner/nodes/reference.d.ts +1 -1
- package/dist/src/planner/nodes/reference.d.ts.map +1 -1
- package/dist/src/planner/nodes/reference.js +1 -1
- package/dist/src/planner/nodes/reference.js.map +1 -1
- package/dist/src/planner/nodes/set-operation-node.js +1 -1
- package/dist/src/planner/nodes/set-operation-node.js.map +1 -1
- package/dist/src/planner/nodes/sort.d.ts +2 -0
- package/dist/src/planner/nodes/sort.d.ts.map +1 -1
- package/dist/src/planner/nodes/sort.js +5 -4
- package/dist/src/planner/nodes/sort.js.map +1 -1
- package/dist/src/planner/scopes/global.d.ts.map +1 -1
- package/dist/src/planner/scopes/global.js +7 -10
- package/dist/src/planner/scopes/global.js.map +1 -1
- package/dist/src/planner/scopes/registered.d.ts +0 -1
- package/dist/src/planner/scopes/registered.d.ts.map +1 -1
- package/dist/src/planner/scopes/registered.js +0 -7
- package/dist/src/planner/scopes/registered.js.map +1 -1
- package/dist/src/planner/stats/histogram.d.ts.map +1 -1
- package/dist/src/planner/stats/histogram.js +2 -1
- package/dist/src/planner/stats/histogram.js.map +1 -1
- package/dist/src/runtime/emit/analyze.d.ts.map +1 -1
- package/dist/src/runtime/emit/analyze.js +15 -14
- package/dist/src/runtime/emit/analyze.js.map +1 -1
- package/dist/src/runtime/emit/between.d.ts.map +1 -1
- package/dist/src/runtime/emit/between.js +17 -3
- package/dist/src/runtime/emit/between.js.map +1 -1
- package/dist/src/runtime/emit/binary.d.ts.map +1 -1
- package/dist/src/runtime/emit/binary.js +35 -18
- package/dist/src/runtime/emit/binary.js.map +1 -1
- package/dist/src/runtime/emit/bloom-join.d.ts.map +1 -1
- package/dist/src/runtime/emit/bloom-join.js +4 -12
- package/dist/src/runtime/emit/bloom-join.js.map +1 -1
- package/dist/src/runtime/emit/create-assertion.d.ts.map +1 -1
- package/dist/src/runtime/emit/create-assertion.js +1 -3
- package/dist/src/runtime/emit/create-assertion.js.map +1 -1
- package/dist/src/runtime/emit/dml-executor.d.ts.map +1 -1
- package/dist/src/runtime/emit/dml-executor.js +5 -0
- package/dist/src/runtime/emit/dml-executor.js.map +1 -1
- package/dist/src/runtime/emit/drop-index.d.ts +5 -0
- package/dist/src/runtime/emit/drop-index.d.ts.map +1 -0
- package/dist/src/runtime/emit/drop-index.js +14 -0
- package/dist/src/runtime/emit/drop-index.js.map +1 -0
- package/dist/src/runtime/emit/join-output.d.ts +13 -0
- package/dist/src/runtime/emit/join-output.d.ts.map +1 -0
- package/dist/src/runtime/emit/join-output.js +22 -0
- package/dist/src/runtime/emit/join-output.js.map +1 -0
- package/dist/src/runtime/emit/join.d.ts.map +1 -1
- package/dist/src/runtime/emit/join.js +4 -16
- package/dist/src/runtime/emit/join.js.map +1 -1
- package/dist/src/runtime/emit/merge-join.d.ts.map +1 -1
- package/dist/src/runtime/emit/merge-join.js +4 -11
- package/dist/src/runtime/emit/merge-join.js.map +1 -1
- package/dist/src/runtime/emit/remote-query.d.ts.map +1 -1
- package/dist/src/runtime/emit/remote-query.js +9 -1
- package/dist/src/runtime/emit/remote-query.js.map +1 -1
- package/dist/src/runtime/emit/schema-declarative.d.ts.map +1 -1
- package/dist/src/runtime/emit/schema-declarative.js +11 -1
- package/dist/src/runtime/emit/schema-declarative.js.map +1 -1
- package/dist/src/runtime/emit/set-operation.d.ts.map +1 -1
- package/dist/src/runtime/emit/set-operation.js +6 -1
- package/dist/src/runtime/emit/set-operation.js.map +1 -1
- package/dist/src/runtime/emit/temporal-arithmetic.d.ts.map +1 -1
- package/dist/src/runtime/emit/temporal-arithmetic.js +97 -1
- package/dist/src/runtime/emit/temporal-arithmetic.js.map +1 -1
- package/dist/src/runtime/emit/window.d.ts.map +1 -1
- package/dist/src/runtime/emit/window.js +43 -82
- package/dist/src/runtime/emit/window.js.map +1 -1
- package/dist/src/runtime/foreign-key-actions.d.ts.map +1 -1
- package/dist/src/runtime/foreign-key-actions.js +3 -0
- package/dist/src/runtime/foreign-key-actions.js.map +1 -1
- package/dist/src/runtime/register.js +2 -2
- package/dist/src/runtime/register.js.map +1 -1
- package/dist/src/runtime/scheduler.d.ts.map +1 -1
- package/dist/src/runtime/scheduler.js +9 -8
- package/dist/src/runtime/scheduler.js.map +1 -1
- package/dist/src/runtime/utils.d.ts.map +1 -1
- package/dist/src/runtime/utils.js +13 -5
- package/dist/src/runtime/utils.js.map +1 -1
- package/dist/src/schema/function.d.ts +1 -10
- package/dist/src/schema/function.d.ts.map +1 -1
- package/dist/src/schema/function.js +0 -3
- package/dist/src/schema/function.js.map +1 -1
- package/dist/src/schema/manager.d.ts +9 -0
- package/dist/src/schema/manager.d.ts.map +1 -1
- package/dist/src/schema/manager.js +69 -0
- package/dist/src/schema/manager.js.map +1 -1
- package/dist/src/schema/schema-differ.d.ts.map +1 -1
- package/dist/src/schema/schema-differ.js +42 -12
- package/dist/src/schema/schema-differ.js.map +1 -1
- package/dist/src/schema/table.d.ts +0 -1
- package/dist/src/schema/table.d.ts.map +1 -1
- package/dist/src/schema/table.js +1 -2
- package/dist/src/schema/table.js.map +1 -1
- package/dist/src/types/temporal-types.d.ts.map +1 -1
- package/dist/src/types/temporal-types.js +10 -5
- package/dist/src/types/temporal-types.js.map +1 -1
- package/dist/src/util/hash.js +6 -6
- package/dist/src/util/hash.js.map +1 -1
- package/dist/src/util/hrtime.d.ts +15 -0
- package/dist/src/util/hrtime.d.ts.map +1 -0
- package/dist/src/util/hrtime.js +26 -0
- package/dist/src/util/hrtime.js.map +1 -0
- package/dist/src/vtab/best-access-plan.d.ts +16 -0
- package/dist/src/vtab/best-access-plan.d.ts.map +1 -1
- package/dist/src/vtab/best-access-plan.js.map +1 -1
- package/dist/src/vtab/capabilities.d.ts +4 -3
- package/dist/src/vtab/capabilities.d.ts.map +1 -1
- package/dist/src/vtab/memory/layer/interface.d.ts +1 -1
- package/dist/src/vtab/memory/layer/interface.d.ts.map +1 -1
- package/dist/src/vtab/memory/layer/manager.d.ts +2 -2
- package/dist/src/vtab/memory/layer/manager.d.ts.map +1 -1
- package/dist/src/vtab/memory/layer/manager.js +4 -36
- package/dist/src/vtab/memory/layer/manager.js.map +1 -1
- package/dist/src/vtab/memory/layer/plan-filter.d.ts +8 -0
- package/dist/src/vtab/memory/layer/plan-filter.d.ts.map +1 -0
- package/dist/src/vtab/memory/layer/plan-filter.js +46 -0
- package/dist/src/vtab/memory/layer/plan-filter.js.map +1 -0
- package/dist/src/vtab/memory/layer/scan-layer.d.ts +9 -0
- package/dist/src/vtab/memory/layer/scan-layer.d.ts.map +1 -0
- package/dist/src/vtab/memory/layer/{base-cursor.js → scan-layer.js} +35 -77
- package/dist/src/vtab/memory/layer/scan-layer.js.map +1 -0
- package/dist/src/vtab/memory/layer/scan-plan.js +2 -2
- package/dist/src/vtab/memory/layer/scan-plan.js.map +1 -1
- package/dist/src/vtab/memory/module.d.ts +4 -0
- package/dist/src/vtab/memory/module.d.ts.map +1 -1
- package/dist/src/vtab/memory/module.js +16 -3
- package/dist/src/vtab/memory/module.js.map +1 -1
- package/dist/src/vtab/memory/table.d.ts +3 -3
- package/dist/src/vtab/memory/table.d.ts.map +1 -1
- package/dist/src/vtab/memory/table.js +20 -12
- package/dist/src/vtab/memory/table.js.map +1 -1
- package/dist/src/vtab/module.d.ts +11 -0
- package/dist/src/vtab/module.d.ts.map +1 -1
- package/dist/src/vtab/table.d.ts +4 -3
- package/dist/src/vtab/table.d.ts.map +1 -1
- package/dist/src/vtab/table.js.map +1 -1
- package/package.json +3 -3
- package/dist/src/planner/nodes/view-reference-node.d.ts +0 -27
- package/dist/src/planner/nodes/view-reference-node.d.ts.map +0 -1
- package/dist/src/planner/nodes/view-reference-node.js +0 -83
- package/dist/src/planner/nodes/view-reference-node.js.map +0 -1
- package/dist/src/runtime/emit/window-function.d.ts +0 -5
- package/dist/src/runtime/emit/window-function.d.ts.map +0 -1
- package/dist/src/runtime/emit/window-function.js +0 -31
- package/dist/src/runtime/emit/window-function.js.map +0 -1
- package/dist/src/vtab/memory/layer/base-cursor.d.ts +0 -5
- package/dist/src/vtab/memory/layer/base-cursor.d.ts.map +0 -1
- package/dist/src/vtab/memory/layer/base-cursor.js.map +0 -1
- package/dist/src/vtab/memory/layer/transaction-cursor.d.ts +0 -5
- package/dist/src/vtab/memory/layer/transaction-cursor.d.ts.map +0 -1
- package/dist/src/vtab/memory/layer/transaction-cursor.js +0 -247
- package/dist/src/vtab/memory/layer/transaction-cursor.js.map +0 -1
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import type { Scope } from '../scopes/scope.js';
|
|
2
|
-
import {
|
|
2
|
+
import { VoidNode, type PhysicalProperties } from './plan-node.js';
|
|
3
3
|
import { PlanNodeType } from './plan-node-type.js';
|
|
4
4
|
import type { TableReferenceNode } from './reference.js';
|
|
5
|
-
import type { VoidType } from '../../common/datatype.js';
|
|
6
5
|
import type * as AST from '../../parser/ast.js';
|
|
7
6
|
/**
|
|
8
7
|
* Discriminated union of ALTER TABLE actions handled by AlterTableNode.
|
|
@@ -26,15 +25,12 @@ export type AlterTableAction = {
|
|
|
26
25
|
* Plan node for ALTER TABLE operations (rename table/column, add/drop column).
|
|
27
26
|
* Constraint additions are handled by the separate AddConstraintNode.
|
|
28
27
|
*/
|
|
29
|
-
export declare class AlterTableNode extends
|
|
28
|
+
export declare class AlterTableNode extends VoidNode {
|
|
30
29
|
readonly table: TableReferenceNode;
|
|
31
30
|
readonly action: AlterTableAction;
|
|
32
31
|
readonly nodeType = PlanNodeType.AlterTable;
|
|
33
32
|
constructor(scope: Scope, table: TableReferenceNode, action: AlterTableAction);
|
|
34
|
-
getType(): VoidType;
|
|
35
33
|
getRelations(): readonly [TableReferenceNode];
|
|
36
|
-
getChildren(): readonly PlanNode[];
|
|
37
|
-
withChildren(newChildren: readonly PlanNode[]): PlanNode;
|
|
38
34
|
toString(): string;
|
|
39
35
|
getLogicalAttributes(): Record<string, unknown>;
|
|
40
36
|
computePhysical(_children: readonly PhysicalProperties[]): Partial<PhysicalProperties>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"alter-table-node.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/alter-table-node.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"alter-table-node.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/alter-table-node.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,KAAK,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACzD,OAAO,KAAK,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAEhD;;;GAGG;AACH,MAAM,MAAM,gBAAgB,GACzB;IAAE,IAAI,EAAE,aAAa,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,GACxC;IAAE,IAAI,EAAE,cAAc,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,GAC1D;IAAE,IAAI,EAAE,WAAW,CAAC;IAAC,MAAM,EAAE,GAAG,CAAC,SAAS,CAAA;CAAE,GAC5C;IAAE,IAAI,EAAE,YAAY,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,CAAC;AAExC;;;GAGG;AACH,qBAAa,cAAe,SAAQ,QAAQ;aAK1B,KAAK,EAAE,kBAAkB;aACzB,MAAM,EAAE,gBAAgB;IALzC,SAAkB,QAAQ,2BAA2B;gBAGpD,KAAK,EAAE,KAAK,EACI,KAAK,EAAE,kBAAkB,EACzB,MAAM,EAAE,gBAAgB;IAKhC,YAAY,IAAI,SAAS,CAAC,kBAAkB,CAAC;IAI7C,QAAQ,IAAI,MAAM;IAalB,oBAAoB,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAS/C,eAAe,CAAC,SAAS,EAAE,SAAS,kBAAkB,EAAE,GAAG,OAAO,CAAC,kBAAkB,CAAC;CAG/F"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { VoidNode } from './plan-node.js';
|
|
2
2
|
import { PlanNodeType } from './plan-node-type.js';
|
|
3
3
|
/**
|
|
4
4
|
* Plan node for ALTER TABLE operations (rename table/column, add/drop column).
|
|
5
5
|
* Constraint additions are handled by the separate AddConstraintNode.
|
|
6
6
|
*/
|
|
7
|
-
export class AlterTableNode extends
|
|
7
|
+
export class AlterTableNode extends VoidNode {
|
|
8
8
|
table;
|
|
9
9
|
action;
|
|
10
10
|
nodeType = PlanNodeType.AlterTable;
|
|
@@ -13,21 +13,9 @@ export class AlterTableNode extends PlanNode {
|
|
|
13
13
|
this.table = table;
|
|
14
14
|
this.action = action;
|
|
15
15
|
}
|
|
16
|
-
getType() {
|
|
17
|
-
return { typeClass: 'void' };
|
|
18
|
-
}
|
|
19
16
|
getRelations() {
|
|
20
17
|
return [this.table];
|
|
21
18
|
}
|
|
22
|
-
getChildren() {
|
|
23
|
-
return [];
|
|
24
|
-
}
|
|
25
|
-
withChildren(newChildren) {
|
|
26
|
-
if (newChildren.length !== 0) {
|
|
27
|
-
throw new Error(`AlterTableNode expects 0 children, got ${newChildren.length}`);
|
|
28
|
-
}
|
|
29
|
-
return this;
|
|
30
|
-
}
|
|
31
19
|
toString() {
|
|
32
20
|
switch (this.action.type) {
|
|
33
21
|
case 'renameTable':
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"alter-table-node.js","sourceRoot":"","sources":["../../../../src/planner/nodes/alter-table-node.ts"],"names":[],"mappings":"AACA,OAAO,
|
|
1
|
+
{"version":3,"file":"alter-table-node.js","sourceRoot":"","sources":["../../../../src/planner/nodes/alter-table-node.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAA2B,MAAM,gBAAgB,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAcnD;;;GAGG;AACH,MAAM,OAAO,cAAe,SAAQ,QAAQ;IAK1B;IACA;IALC,QAAQ,GAAG,YAAY,CAAC,UAAU,CAAC;IAErD,YACC,KAAY,EACI,KAAyB,EACzB,MAAwB;QAExC,KAAK,CAAC,KAAK,CAAC,CAAC;QAHG,UAAK,GAAL,KAAK,CAAoB;QACzB,WAAM,GAAN,MAAM,CAAkB;IAGzC,CAAC;IAEQ,YAAY;QACpB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC;IAEQ,QAAQ;QAChB,QAAQ,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;YAC1B,KAAK,aAAa;gBACjB,OAAO,yBAAyB,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACvD,KAAK,cAAc;gBAClB,OAAO,6BAA6B,IAAI,CAAC,MAAM,CAAC,OAAO,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACrF,KAAK,WAAW;gBACf,OAAO,0BAA0B,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;YAC5D,KAAK,YAAY;gBAChB,OAAO,2BAA2B,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QACvD,CAAC;IACF,CAAC;IAEQ,oBAAoB;QAC5B,OAAO;YACN,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI;YAClC,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,UAAU;YACzC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI;YAC5B,GAAG,IAAI,CAAC,MAAM;SACd,CAAC;IACH,CAAC;IAEQ,eAAe,CAAC,SAAwC;QAChE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IAC5B,CAAC;CACD"}
|
|
@@ -4,14 +4,8 @@ import type { RelationType } from '../../common/datatype.js';
|
|
|
4
4
|
import type { Scope } from '../scopes/scope.js';
|
|
5
5
|
import type { JoinCapable, PredicateSourceCapable } from '../framework/characteristics.js';
|
|
6
6
|
import type { JoinType } from './join-node.js';
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
* Attribute IDs are stable across plan transformations.
|
|
10
|
-
*/
|
|
11
|
-
export interface EquiJoinPair {
|
|
12
|
-
leftAttrId: number;
|
|
13
|
-
rightAttrId: number;
|
|
14
|
-
}
|
|
7
|
+
import { type EquiJoinPair } from './join-utils.js';
|
|
8
|
+
export type { EquiJoinPair } from './join-utils.js';
|
|
15
9
|
/**
|
|
16
10
|
* Physical plan node implementing a hash (bloom) join.
|
|
17
11
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bloom-join-node.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/bloom-join-node.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,QAAQ,EAAE,KAAK,kBAAkB,EAAE,KAAK,oBAAoB,EAAE,KAAK,cAAc,EAAE,KAAK,kBAAkB,EAAE,KAAK,SAAS,EAAoB,MAAM,gBAAgB,CAAC;AAC9K,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAIhD,OAAO,KAAK,EAAE,WAAW,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAE3F,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"bloom-join-node.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/bloom-join-node.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,QAAQ,EAAE,KAAK,kBAAkB,EAAE,KAAK,oBAAoB,EAAE,KAAK,cAAc,EAAE,KAAK,kBAAkB,EAAE,KAAK,SAAS,EAAoB,MAAM,gBAAgB,CAAC;AAC9K,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAIhD,OAAO,KAAK,EAAE,WAAW,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAE3F,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE/C,OAAO,EAAgE,KAAK,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAElH,YAAY,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAEpD;;;;;;;;GAQG;AACH,qBAAa,aAAc,SAAQ,QAAS,YAAW,oBAAoB,EAAE,WAAW,EAAE,sBAAsB;IAM9G,4BAA4B;aACZ,IAAI,EAAE,kBAAkB;IACxC,8CAA8C;aAC9B,KAAK,EAAE,kBAAkB;aACzB,QAAQ,EAAE,QAAQ;IAClC,2DAA2D;aAC3C,SAAS,EAAE,SAAS,YAAY,EAAE;IAClD,qDAAqD;aACrC,iBAAiB,CAAC,EAAE,cAAc;IAClD,wDAAwD;aACxC,oBAAoB,CAAC,EAAE,SAAS,SAAS,EAAE;IAf5D,SAAkB,QAAQ,yBAAyB;IACnD,OAAO,CAAC,eAAe,CAAsB;gBAG5C,KAAK,EAAE,KAAK;IACZ,4BAA4B;IACZ,IAAI,EAAE,kBAAkB;IACxC,8CAA8C;IAC9B,KAAK,EAAE,kBAAkB,EACzB,QAAQ,EAAE,QAAQ;IAClC,2DAA2D;IAC3C,SAAS,EAAE,SAAS,YAAY,EAAE;IAClD,qDAAqD;IACrC,iBAAiB,CAAC,EAAE,cAAc,YAAA;IAClD,wDAAwD;IACxC,oBAAoB,CAAC,EAAE,SAAS,SAAS,EAAE,YAAA;IAU5D,OAAO,CAAC,eAAe;IAOvB,aAAa,IAAI,SAAS,EAAE;IAI5B,OAAO,IAAI,YAAY;IAIvB,eAAe,CAAC,gBAAgB,EAAE,kBAAkB,EAAE,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAyBpF,IAAI,aAAa,IAAI,MAAM,GAAG,SAAS,CAEtC;IAED,WAAW,IAAI,SAAS,QAAQ,EAAE;IAMlC,YAAY,IAAI,SAAS,CAAC,kBAAkB,EAAE,kBAAkB,CAAC;IAIjE,YAAY,CAAC,WAAW,EAAE,SAAS,QAAQ,EAAE,GAAG,QAAQ;IAgCxD,WAAW,IAAI,QAAQ;IACvB,gBAAgB,IAAI,cAAc,GAAG,SAAS;IAC9C,aAAa,IAAI,kBAAkB;IACnC,cAAc,IAAI,kBAAkB;IACpC,eAAe,IAAI,SAAS,MAAM,EAAE,GAAG,SAAS;IAGhD,aAAa,IAAI,SAAS,cAAc,EAAE;IAIjC,QAAQ,IAAI,MAAM;IAKlB,oBAAoB,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAcxD"}
|
|
@@ -5,6 +5,7 @@ import { StatusCode } from '../../common/types.js';
|
|
|
5
5
|
import { quereusError } from '../../common/errors.js';
|
|
6
6
|
import { hashJoinCost } from '../cost/index.js';
|
|
7
7
|
import { analyzeJoinKeyCoverage } from '../util/key-utils.js';
|
|
8
|
+
import { buildJoinAttributes, buildJoinRelationType, estimateJoinRows } from './join-utils.js';
|
|
8
9
|
/**
|
|
9
10
|
* Physical plan node implementing a hash (bloom) join.
|
|
10
11
|
*
|
|
@@ -47,64 +48,13 @@ export class BloomJoinNode extends PlanNode {
|
|
|
47
48
|
this.attributesCache = new Cached(() => this.buildAttributes());
|
|
48
49
|
}
|
|
49
50
|
buildAttributes() {
|
|
50
|
-
|
|
51
|
-
return this.preserveAttributeIds.slice();
|
|
52
|
-
}
|
|
53
|
-
const leftAttrs = this.left.getAttributes();
|
|
54
|
-
// Semi/anti joins produce only left-side attributes
|
|
55
|
-
if (this.joinType === 'semi' || this.joinType === 'anti') {
|
|
56
|
-
return leftAttrs.slice();
|
|
57
|
-
}
|
|
58
|
-
// Fallback: combine left + right attributes (should rarely happen)
|
|
59
|
-
const rightAttrs = this.right.getAttributes();
|
|
60
|
-
const attributes = [];
|
|
61
|
-
for (const attr of leftAttrs) {
|
|
62
|
-
const isNullable = this.joinType === 'right' || this.joinType === 'full';
|
|
63
|
-
attributes.push(isNullable ? { ...attr, type: { ...attr.type, nullable: true } } : attr);
|
|
64
|
-
}
|
|
65
|
-
for (const attr of rightAttrs) {
|
|
66
|
-
const isNullable = this.joinType === 'left' || this.joinType === 'full';
|
|
67
|
-
attributes.push(isNullable ? { ...attr, type: { ...attr.type, nullable: true } } : attr);
|
|
68
|
-
}
|
|
69
|
-
return attributes;
|
|
51
|
+
return buildJoinAttributes(this.left.getAttributes(), this.right.getAttributes(), this.joinType, this.preserveAttributeIds);
|
|
70
52
|
}
|
|
71
53
|
getAttributes() {
|
|
72
54
|
return this.attributesCache.value;
|
|
73
55
|
}
|
|
74
56
|
getType() {
|
|
75
|
-
|
|
76
|
-
// Semi/anti joins produce only left-side columns
|
|
77
|
-
if (this.joinType === 'semi' || this.joinType === 'anti') {
|
|
78
|
-
return {
|
|
79
|
-
typeClass: 'relation',
|
|
80
|
-
columns: leftType.columns,
|
|
81
|
-
isSet: leftType.isSet,
|
|
82
|
-
isReadOnly: leftType.isReadOnly,
|
|
83
|
-
keys: leftType.keys,
|
|
84
|
-
rowConstraints: leftType.rowConstraints
|
|
85
|
-
};
|
|
86
|
-
}
|
|
87
|
-
const rightType = this.right.getType();
|
|
88
|
-
const combinedColumns = [
|
|
89
|
-
...leftType.columns.map(col => {
|
|
90
|
-
const isNullable = this.joinType === 'right' || this.joinType === 'full';
|
|
91
|
-
return isNullable ? { ...col, type: { ...col.type, nullable: true } } : col;
|
|
92
|
-
}),
|
|
93
|
-
...rightType.columns.map(col => {
|
|
94
|
-
const isNullable = this.joinType === 'left' || this.joinType === 'full';
|
|
95
|
-
return isNullable ? { ...col, type: { ...col.type, nullable: true } } : col;
|
|
96
|
-
})
|
|
97
|
-
];
|
|
98
|
-
const isSet = (this.joinType === 'inner' || this.joinType === 'cross') &&
|
|
99
|
-
leftType.isSet && rightType.isSet;
|
|
100
|
-
return {
|
|
101
|
-
typeClass: 'relation',
|
|
102
|
-
columns: combinedColumns,
|
|
103
|
-
isSet,
|
|
104
|
-
isReadOnly: leftType.isReadOnly && rightType.isReadOnly,
|
|
105
|
-
keys: [], // Conservative: don't infer keys for hash join
|
|
106
|
-
rowConstraints: [...leftType.rowConstraints, ...rightType.rowConstraints]
|
|
107
|
-
};
|
|
57
|
+
return buildJoinRelationType(this.left.getType(), this.right.getType(), this.joinType, []);
|
|
108
58
|
}
|
|
109
59
|
computePhysical(childrenPhysical) {
|
|
110
60
|
const leftPhys = childrenPhysical[0];
|
|
@@ -123,23 +73,7 @@ export class BloomJoinNode extends PlanNode {
|
|
|
123
73
|
};
|
|
124
74
|
}
|
|
125
75
|
get estimatedRows() {
|
|
126
|
-
|
|
127
|
-
const rightRows = this.right.estimatedRows;
|
|
128
|
-
if (leftRows === undefined || rightRows === undefined)
|
|
129
|
-
return undefined;
|
|
130
|
-
switch (this.joinType) {
|
|
131
|
-
case 'cross':
|
|
132
|
-
return leftRows * rightRows;
|
|
133
|
-
case 'inner':
|
|
134
|
-
return Math.max(1, leftRows * rightRows * 0.1);
|
|
135
|
-
case 'left':
|
|
136
|
-
return leftRows;
|
|
137
|
-
case 'semi':
|
|
138
|
-
case 'anti':
|
|
139
|
-
return Math.max(1, Math.floor(leftRows * 0.5));
|
|
140
|
-
default:
|
|
141
|
-
return leftRows * rightRows * 0.1;
|
|
142
|
-
}
|
|
76
|
+
return estimateJoinRows(this.left.estimatedRows, this.right.estimatedRows, this.joinType);
|
|
143
77
|
}
|
|
144
78
|
getChildren() {
|
|
145
79
|
const children = [this.left, this.right];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bloom-join-node.js","sourceRoot":"","sources":["../../../../src/planner/nodes/bloom-join-node.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,QAAQ,EAAoH,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAG9K,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAEtD,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAEhD,OAAO,EAAE,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"bloom-join-node.js","sourceRoot":"","sources":["../../../../src/planner/nodes/bloom-join-node.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,20 +1,16 @@
|
|
|
1
1
|
import type { Scope } from '../scopes/scope.js';
|
|
2
|
-
import {
|
|
2
|
+
import { VoidNode, type PhysicalProperties } from './plan-node.js';
|
|
3
3
|
import { PlanNodeType } from './plan-node-type.js';
|
|
4
|
-
import type { VoidType } from '../../common/datatype.js';
|
|
5
4
|
import type * as AST from '../../parser/ast.js';
|
|
6
5
|
/**
|
|
7
6
|
* Represents creating a global integrity assertion.
|
|
8
7
|
* This is a DDL operation that adds an assertion to the schema.
|
|
9
8
|
*/
|
|
10
|
-
export declare class CreateAssertionNode extends
|
|
9
|
+
export declare class CreateAssertionNode extends VoidNode {
|
|
11
10
|
readonly name: string;
|
|
12
11
|
readonly checkExpression: AST.Expression;
|
|
13
12
|
readonly nodeType = PlanNodeType.CreateAssertion;
|
|
14
13
|
constructor(scope: Scope, name: string, checkExpression: AST.Expression);
|
|
15
|
-
getType(): VoidType;
|
|
16
|
-
getChildren(): readonly PlanNode[];
|
|
17
|
-
withChildren(newChildren: readonly PlanNode[]): PlanNode;
|
|
18
14
|
toString(): string;
|
|
19
15
|
getLogicalAttributes(): Record<string, unknown>;
|
|
20
16
|
computePhysical(_children: readonly PhysicalProperties[]): Partial<PhysicalProperties>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-assertion-node.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/create-assertion-node.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,KAAK,
|
|
1
|
+
{"version":3,"file":"create-assertion-node.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/create-assertion-node.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,KAAK,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,KAAK,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAEhD;;;GAGG;AACH,qBAAa,mBAAoB,SAAQ,QAAQ;aAK7B,IAAI,EAAE,MAAM;aACZ,eAAe,EAAE,GAAG,CAAC,UAAU;IALjD,SAAkB,QAAQ,gCAAgC;gBAGxD,KAAK,EAAE,KAAK,EACI,IAAI,EAAE,MAAM,EACZ,eAAe,EAAE,GAAG,CAAC,UAAU;IAKxC,QAAQ,IAAI,MAAM;IAIlB,oBAAoB,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAO/C,eAAe,CAAC,SAAS,EAAE,SAAS,kBAAkB,EAAE,GAAG,OAAO,CAAC,kBAAkB,CAAC;CAGhG"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { VoidNode } from './plan-node.js';
|
|
2
2
|
import { PlanNodeType } from './plan-node-type.js';
|
|
3
3
|
/**
|
|
4
4
|
* Represents creating a global integrity assertion.
|
|
5
5
|
* This is a DDL operation that adds an assertion to the schema.
|
|
6
6
|
*/
|
|
7
|
-
export class CreateAssertionNode extends
|
|
7
|
+
export class CreateAssertionNode extends VoidNode {
|
|
8
8
|
name;
|
|
9
9
|
checkExpression;
|
|
10
10
|
nodeType = PlanNodeType.CreateAssertion;
|
|
@@ -13,18 +13,6 @@ export class CreateAssertionNode extends PlanNode {
|
|
|
13
13
|
this.name = name;
|
|
14
14
|
this.checkExpression = checkExpression;
|
|
15
15
|
}
|
|
16
|
-
getType() {
|
|
17
|
-
return { typeClass: 'void' };
|
|
18
|
-
}
|
|
19
|
-
getChildren() {
|
|
20
|
-
return [];
|
|
21
|
-
}
|
|
22
|
-
withChildren(newChildren) {
|
|
23
|
-
if (newChildren.length !== 0) {
|
|
24
|
-
throw new Error(`CreateAssertionNode expects 0 children, got ${newChildren.length}`);
|
|
25
|
-
}
|
|
26
|
-
return this; // No children, so no change
|
|
27
|
-
}
|
|
28
16
|
toString() {
|
|
29
17
|
return `CREATE ASSERTION ${this.name}`;
|
|
30
18
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-assertion-node.js","sourceRoot":"","sources":["../../../../src/planner/nodes/create-assertion-node.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,
|
|
1
|
+
{"version":3,"file":"create-assertion-node.js","sourceRoot":"","sources":["../../../../src/planner/nodes/create-assertion-node.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAA2B,MAAM,gBAAgB,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAGnD;;;GAGG;AACH,MAAM,OAAO,mBAAoB,SAAQ,QAAQ;IAK7B;IACA;IALA,QAAQ,GAAG,YAAY,CAAC,eAAe,CAAC;IAE1D,YACE,KAAY,EACI,IAAY,EACZ,eAA+B;QAE/C,KAAK,CAAC,KAAK,CAAC,CAAC;QAHG,SAAI,GAAJ,IAAI,CAAQ;QACZ,oBAAe,GAAf,eAAe,CAAgB;IAGjD,CAAC;IAEQ,QAAQ;QACf,OAAO,oBAAoB,IAAI,CAAC,IAAI,EAAE,CAAC;IACzC,CAAC;IAEQ,oBAAoB;QAC3B,OAAO;YACL,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,eAAe,EAAE,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,EAAE,IAAI,oBAAoB;SAC3E,CAAC;IACJ,CAAC;IAEQ,eAAe,CAAC,SAAwC;QAC/D,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IAC7B,CAAC;CACF"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cte-node.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/cte-node.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,KAAK,mBAAmB,EAAE,KAAK,kBAAkB,EAAE,KAAK,SAAS,EAAE,KAAK,eAAe,EAAoB,MAAM,gBAAgB,CAAC;AACrJ,OAAO,KAAK,EAAE,YAAY,
|
|
1
|
+
{"version":3,"file":"cte-node.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/cte-node.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,KAAK,mBAAmB,EAAE,KAAK,kBAAkB,EAAE,KAAK,SAAS,EAAE,KAAK,eAAe,EAAoB,MAAM,gBAAgB,CAAC;AACrJ,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAEhD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAElE;;;;GAIG;AACH,MAAM,WAAW,YAAa,SAAQ,QAAQ;IAC1C,2BAA2B;IAC3B,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IAEzB,2DAA2D;IAC3D,aAAa,IAAI,SAAS,SAAS,EAAE,CAAC;IAEtC,uCAAuC;IACvC,OAAO,IAAI,YAAY,CAAC;CAC3B;AAED;;GAEG;AACH,MAAM,WAAW,WAAY,SAAQ,mBAAmB;IACvD,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;IACvC,QAAQ,CAAC,mBAAmB,EAAE,cAAc,GAAG,kBAAkB,GAAG,SAAS,CAAC;IAC9E,QAAQ,CAAC,WAAW,EAAE,OAAO,CAAC;IAC9B,QAAQ,CAAC,eAAe,EAAE,eAAe,CAAC;CAC1C;AAED;;;GAGG;AACH,qBAAa,OAAQ,SAAQ,QAAS,YAAW,WAAW,EAAE,YAAY,EAAE,UAAU;aASpE,OAAO,EAAE,MAAM;aACf,OAAO,EAAE,MAAM,EAAE,GAAG,SAAS;aAC7B,MAAM,EAAE,kBAAkB;aAC1B,mBAAmB,EAAE,cAAc,GAAG,kBAAkB,GAAG,SAAS;aACpE,WAAW,EAAE,OAAO;IAZrC,QAAQ,CAAC,QAAQ,oBAAoB;IACrC,QAAQ,CAAC,eAAe,EAAE,eAAe,CAAM;IAE/C,OAAO,CAAC,eAAe,CAAsB;IAC7C,OAAO,CAAC,SAAS,CAAuB;gBAGvC,KAAK,EAAE,KAAK,EACI,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,MAAM,EAAE,GAAG,SAAS,EAC7B,MAAM,EAAE,kBAAkB,EAC1B,mBAAmB,EAAE,cAAc,GAAG,kBAAkB,GAAG,SAAS,EACpE,WAAW,GAAE,OAAe;IAO7C,OAAO,CAAC,eAAe;IAYvB,OAAO,CAAC,SAAS;IAejB,aAAa,IAAI,SAAS,SAAS,EAAE;IAIrC,OAAO,IAAI,YAAY;IAIvB,WAAW,IAAI,SAAS,CAAC,kBAAkB,CAAC;IAI5C,YAAY,IAAI,SAAS,CAAC,kBAAkB,CAAC;IAI7C,YAAY,CAAC,WAAW,EAAE,SAAS,QAAQ,EAAE,GAAG,QAAQ;IA4BxD,YAAY,IAAI,kBAAkB;IAIzB,QAAQ,IAAI,MAAM;IAOlB,oBAAoB,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CASxD"}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { PlanNode, isRelationalNode } from './plan-node.js';
|
|
2
2
|
import { PlanNodeType } from './plan-node-type.js';
|
|
3
3
|
import { Cached } from '../../util/cached.js';
|
|
4
|
-
import { TEXT_TYPE } from '../../types/builtin-types.js';
|
|
5
4
|
/**
|
|
6
5
|
* Plan node for Common Table Expressions (CTEs).
|
|
7
6
|
* This represents a single CTE definition within a WITH clause.
|
|
@@ -28,29 +27,13 @@ export class CTENode extends PlanNode {
|
|
|
28
27
|
}
|
|
29
28
|
buildAttributes() {
|
|
30
29
|
const queryAttributes = this.source.getAttributes();
|
|
31
|
-
const
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
if (!resolvedType) {
|
|
39
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
40
|
-
const colMeta = queryType.columns.find((c) => c.name.toLowerCase() === name.toLowerCase());
|
|
41
|
-
resolvedType = colMeta?.type;
|
|
42
|
-
}
|
|
43
|
-
// Fallback: generic TEXT scalar if nothing else is available (should not normally happen)
|
|
44
|
-
if (!resolvedType) {
|
|
45
|
-
resolvedType = { typeClass: 'scalar', logicalType: TEXT_TYPE, nullable: true, isReadOnly: false };
|
|
46
|
-
}
|
|
47
|
-
return {
|
|
48
|
-
id: srcAttr?.id ?? PlanNode.nextAttrId(),
|
|
49
|
-
name,
|
|
50
|
-
type: resolvedType,
|
|
51
|
-
sourceRelation: `cte:${this.cteName}`
|
|
52
|
-
};
|
|
53
|
-
});
|
|
30
|
+
const columnNames = this.columns || this.source.getType().columns.map((c) => c.name);
|
|
31
|
+
return queryAttributes.map((attr, index) => ({
|
|
32
|
+
id: attr.id,
|
|
33
|
+
name: columnNames[index] || attr.name,
|
|
34
|
+
type: attr.type,
|
|
35
|
+
sourceRelation: `cte:${this.cteName}`
|
|
36
|
+
}));
|
|
54
37
|
}
|
|
55
38
|
buildType() {
|
|
56
39
|
const queryType = this.source.getType();
|
|
@@ -58,7 +41,6 @@ export class CTENode extends PlanNode {
|
|
|
58
41
|
typeClass: 'relation',
|
|
59
42
|
isReadOnly: false,
|
|
60
43
|
isSet: queryType.isSet, // CTEs preserve the set/bag nature of their query
|
|
61
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
62
44
|
columns: this.getAttributes().map((attr) => ({
|
|
63
45
|
name: attr.name,
|
|
64
46
|
type: attr.type
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cte-node.js","sourceRoot":"","sources":["../../../../src/planner/nodes/cte-node.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAA2F,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAErJ,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"cte-node.js","sourceRoot":"","sources":["../../../../src/planner/nodes/cte-node.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,18 +1,15 @@
|
|
|
1
|
-
import { PlanNode,
|
|
1
|
+
import { PlanNode, VoidNode, type RelationalPlanNode, Attribute } from './plan-node.js';
|
|
2
2
|
import { PlanNodeType } from './plan-node-type.js';
|
|
3
3
|
import type { Scope } from '../scopes/scope.js';
|
|
4
4
|
import type * as AST from '../../parser/ast.js';
|
|
5
|
-
import { RelationType
|
|
5
|
+
import { RelationType } from '../../common/datatype.js';
|
|
6
6
|
/**
|
|
7
7
|
* DECLARE SCHEMA statement plan node
|
|
8
8
|
*/
|
|
9
|
-
export declare class DeclareSchemaNode extends
|
|
9
|
+
export declare class DeclareSchemaNode extends VoidNode {
|
|
10
10
|
readonly statementAst: AST.DeclareSchemaStmt;
|
|
11
11
|
readonly nodeType = PlanNodeType.DeclareSchema;
|
|
12
12
|
constructor(scope: Scope, statementAst: AST.DeclareSchemaStmt);
|
|
13
|
-
getType(): VoidType;
|
|
14
|
-
getChildren(): PlanNode[];
|
|
15
|
-
withChildren(newChildren: readonly PlanNode[]): PlanNode;
|
|
16
13
|
toString(): string;
|
|
17
14
|
getLogicalAttributes(): Record<string, unknown>;
|
|
18
15
|
}
|
|
@@ -36,13 +33,10 @@ export declare class DiffSchemaNode extends PlanNode implements RelationalPlanNo
|
|
|
36
33
|
/**
|
|
37
34
|
* APPLY SCHEMA statement plan node
|
|
38
35
|
*/
|
|
39
|
-
export declare class ApplySchemaNode extends
|
|
36
|
+
export declare class ApplySchemaNode extends VoidNode {
|
|
40
37
|
readonly statementAst: AST.ApplySchemaStmt;
|
|
41
38
|
readonly nodeType = PlanNodeType.ApplySchema;
|
|
42
39
|
constructor(scope: Scope, statementAst: AST.ApplySchemaStmt);
|
|
43
|
-
getType(): VoidType;
|
|
44
|
-
getChildren(): PlanNode[];
|
|
45
|
-
withChildren(newChildren: readonly PlanNode[]): PlanNode;
|
|
46
40
|
toString(): string;
|
|
47
41
|
getLogicalAttributes(): Record<string, unknown>;
|
|
48
42
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"declarative-schema.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/declarative-schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,
|
|
1
|
+
{"version":3,"file":"declarative-schema.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/declarative-schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,kBAAkB,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACxF,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,KAAK,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAIxD;;GAEG;AACH,qBAAa,iBAAkB,SAAQ,QAAQ;aAK7B,YAAY,EAAE,GAAG,CAAC,iBAAiB;IAJpD,SAAkB,QAAQ,8BAA8B;gBAGvD,KAAK,EAAE,KAAK,EACI,YAAY,EAAE,GAAG,CAAC,iBAAiB;IAK3C,QAAQ,IAAI,MAAM;IAIlB,oBAAoB,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAOxD;AAED;;GAEG;AACH,qBAAa,cAAe,SAAQ,QAAS,YAAW,kBAAkB;aAOxD,YAAY,EAAE,GAAG,CAAC,cAAc;IANjD,SAAkB,QAAQ,2BAA2B;IAErD,OAAO,CAAC,eAAe,CAAsB;gBAG5C,KAAK,EAAE,KAAK,EACI,YAAY,EAAE,GAAG,CAAC,cAAc;IAMjD,OAAO,IAAI,YAAY;IAsBvB,IAAI,aAAa,IAAI,MAAM,GAAG,SAAS,CAEtC;IAED,OAAO,CAAC,eAAe;IASvB,aAAa,IAAI,SAAS,EAAE;IAI5B,WAAW,IAAI,QAAQ,EAAE;IAIzB,YAAY,CAAC,WAAW,EAAE,SAAS,QAAQ,EAAE,GAAG,QAAQ;IAO/C,QAAQ,IAAI,MAAM;IAIlB,oBAAoB,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAMxD;AAED;;GAEG;AACH,qBAAa,eAAgB,SAAQ,QAAQ;aAK3B,YAAY,EAAE,GAAG,CAAC,eAAe;IAJlD,SAAkB,QAAQ,4BAA4B;gBAGrD,KAAK,EAAE,KAAK,EACI,YAAY,EAAE,GAAG,CAAC,eAAe;IAKzC,QAAQ,IAAI,MAAM;IAIlB,oBAAoB,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAOxD;AAED;;GAEG;AACH,qBAAa,iBAAkB,SAAQ,QAAS,YAAW,kBAAkB;aAO3D,YAAY,EAAE,GAAG,CAAC,iBAAiB;IANpD,SAAkB,QAAQ,8BAA8B;IAExD,OAAO,CAAC,eAAe,CAAsB;gBAG5C,KAAK,EAAE,KAAK,EACI,YAAY,EAAE,GAAG,CAAC,iBAAiB;IAMpD,OAAO,IAAI,YAAY;IAsBvB,IAAI,aAAa,IAAI,MAAM,GAAG,SAAS,CAEtC;IAED,OAAO,CAAC,eAAe;IASvB,aAAa,IAAI,SAAS,EAAE;IAI5B,WAAW,IAAI,QAAQ,EAAE;IAIzB,YAAY,CAAC,WAAW,EAAE,SAAS,QAAQ,EAAE,GAAG,QAAQ;IAO/C,QAAQ,IAAI,MAAM;IAIlB,oBAAoB,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAOxD"}
|
|
@@ -1,29 +1,17 @@
|
|
|
1
|
-
import { PlanNode } from './plan-node.js';
|
|
1
|
+
import { PlanNode, VoidNode } from './plan-node.js';
|
|
2
2
|
import { PlanNodeType } from './plan-node-type.js';
|
|
3
3
|
import { TEXT_TYPE } from '../../types/builtin-types.js';
|
|
4
4
|
import { Cached } from '../../util/cached.js';
|
|
5
5
|
/**
|
|
6
6
|
* DECLARE SCHEMA statement plan node
|
|
7
7
|
*/
|
|
8
|
-
export class DeclareSchemaNode extends
|
|
8
|
+
export class DeclareSchemaNode extends VoidNode {
|
|
9
9
|
statementAst;
|
|
10
10
|
nodeType = PlanNodeType.DeclareSchema;
|
|
11
11
|
constructor(scope, statementAst) {
|
|
12
12
|
super(scope, 1);
|
|
13
13
|
this.statementAst = statementAst;
|
|
14
14
|
}
|
|
15
|
-
getType() {
|
|
16
|
-
return { typeClass: 'void' };
|
|
17
|
-
}
|
|
18
|
-
getChildren() {
|
|
19
|
-
return [];
|
|
20
|
-
}
|
|
21
|
-
withChildren(newChildren) {
|
|
22
|
-
if (newChildren.length !== 0) {
|
|
23
|
-
throw new Error(`DeclareSchemaNode expects 0 children, got ${newChildren.length}`);
|
|
24
|
-
}
|
|
25
|
-
return this;
|
|
26
|
-
}
|
|
27
15
|
toString() {
|
|
28
16
|
return `DECLARE SCHEMA ${this.statementAst.schemaName || 'main'}`;
|
|
29
17
|
}
|
|
@@ -104,25 +92,13 @@ export class DiffSchemaNode extends PlanNode {
|
|
|
104
92
|
/**
|
|
105
93
|
* APPLY SCHEMA statement plan node
|
|
106
94
|
*/
|
|
107
|
-
export class ApplySchemaNode extends
|
|
95
|
+
export class ApplySchemaNode extends VoidNode {
|
|
108
96
|
statementAst;
|
|
109
97
|
nodeType = PlanNodeType.ApplySchema;
|
|
110
98
|
constructor(scope, statementAst) {
|
|
111
99
|
super(scope, 1);
|
|
112
100
|
this.statementAst = statementAst;
|
|
113
101
|
}
|
|
114
|
-
getType() {
|
|
115
|
-
return { typeClass: 'void' };
|
|
116
|
-
}
|
|
117
|
-
getChildren() {
|
|
118
|
-
return [];
|
|
119
|
-
}
|
|
120
|
-
withChildren(newChildren) {
|
|
121
|
-
if (newChildren.length !== 0) {
|
|
122
|
-
throw new Error(`ApplySchemaNode expects 0 children, got ${newChildren.length}`);
|
|
123
|
-
}
|
|
124
|
-
return this;
|
|
125
|
-
}
|
|
126
102
|
toString() {
|
|
127
103
|
return `APPLY SCHEMA ${this.statementAst.schemaName || 'main'}${this.statementAst.withSeed ? ' WITH SEED' : ''}`;
|
|
128
104
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"declarative-schema.js","sourceRoot":"","sources":["../../../../src/planner/nodes/declarative-schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,
|
|
1
|
+
{"version":3,"file":"declarative-schema.js","sourceRoot":"","sources":["../../../../src/planner/nodes/declarative-schema.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,19 +1,15 @@
|
|
|
1
1
|
import type { Scope } from '../scopes/scope.js';
|
|
2
|
-
import {
|
|
2
|
+
import { VoidNode, type PhysicalProperties } from './plan-node.js';
|
|
3
3
|
import { PlanNodeType } from './plan-node-type.js';
|
|
4
|
-
import type { VoidType } from '../../common/datatype.js';
|
|
5
4
|
/**
|
|
6
5
|
* Represents dropping a global integrity assertion.
|
|
7
6
|
* This is a DDL operation that removes an assertion from the schema.
|
|
8
7
|
*/
|
|
9
|
-
export declare class DropAssertionNode extends
|
|
8
|
+
export declare class DropAssertionNode extends VoidNode {
|
|
10
9
|
readonly name: string;
|
|
11
10
|
readonly ifExists: boolean;
|
|
12
11
|
readonly nodeType = PlanNodeType.DropAssertion;
|
|
13
12
|
constructor(scope: Scope, name: string, ifExists: boolean);
|
|
14
|
-
getType(): VoidType;
|
|
15
|
-
getChildren(): readonly PlanNode[];
|
|
16
|
-
withChildren(newChildren: readonly PlanNode[]): PlanNode;
|
|
17
13
|
toString(): string;
|
|
18
14
|
getLogicalAttributes(): Record<string, unknown>;
|
|
19
15
|
computePhysical(_children: readonly PhysicalProperties[]): Partial<PhysicalProperties>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"drop-assertion-node.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/drop-assertion-node.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,KAAK,
|
|
1
|
+
{"version":3,"file":"drop-assertion-node.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/drop-assertion-node.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,KAAK,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD;;;GAGG;AACH,qBAAa,iBAAkB,SAAQ,QAAQ;aAK3B,IAAI,EAAE,MAAM;aACZ,QAAQ,EAAE,OAAO;IALnC,SAAkB,QAAQ,8BAA8B;gBAGtD,KAAK,EAAE,KAAK,EACI,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,OAAO;IAK1B,QAAQ,IAAI,MAAM;IAIlB,oBAAoB,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAO/C,eAAe,CAAC,SAAS,EAAE,SAAS,kBAAkB,EAAE,GAAG,OAAO,CAAC,kBAAkB,CAAC;CAGhG"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { VoidNode } from './plan-node.js';
|
|
2
2
|
import { PlanNodeType } from './plan-node-type.js';
|
|
3
3
|
/**
|
|
4
4
|
* Represents dropping a global integrity assertion.
|
|
5
5
|
* This is a DDL operation that removes an assertion from the schema.
|
|
6
6
|
*/
|
|
7
|
-
export class DropAssertionNode extends
|
|
7
|
+
export class DropAssertionNode extends VoidNode {
|
|
8
8
|
name;
|
|
9
9
|
ifExists;
|
|
10
10
|
nodeType = PlanNodeType.DropAssertion;
|
|
@@ -13,18 +13,6 @@ export class DropAssertionNode extends PlanNode {
|
|
|
13
13
|
this.name = name;
|
|
14
14
|
this.ifExists = ifExists;
|
|
15
15
|
}
|
|
16
|
-
getType() {
|
|
17
|
-
return { typeClass: 'void' };
|
|
18
|
-
}
|
|
19
|
-
getChildren() {
|
|
20
|
-
return [];
|
|
21
|
-
}
|
|
22
|
-
withChildren(newChildren) {
|
|
23
|
-
if (newChildren.length !== 0) {
|
|
24
|
-
throw new Error(`DropAssertionNode expects 0 children, got ${newChildren.length}`);
|
|
25
|
-
}
|
|
26
|
-
return this; // No children, so no change
|
|
27
|
-
}
|
|
28
16
|
toString() {
|
|
29
17
|
return `DROP ASSERTION ${this.name}`;
|
|
30
18
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"drop-assertion-node.js","sourceRoot":"","sources":["../../../../src/planner/nodes/drop-assertion-node.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,
|
|
1
|
+
{"version":3,"file":"drop-assertion-node.js","sourceRoot":"","sources":["../../../../src/planner/nodes/drop-assertion-node.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAA2B,MAAM,gBAAgB,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD;;;GAGG;AACH,MAAM,OAAO,iBAAkB,SAAQ,QAAQ;IAK3B;IACA;IALA,QAAQ,GAAG,YAAY,CAAC,aAAa,CAAC;IAExD,YACE,KAAY,EACI,IAAY,EACZ,QAAiB;QAEjC,KAAK,CAAC,KAAK,CAAC,CAAC;QAHG,SAAI,GAAJ,IAAI,CAAQ;QACZ,aAAQ,GAAR,QAAQ,CAAS;IAGnC,CAAC;IAEQ,QAAQ;QACf,OAAO,kBAAkB,IAAI,CAAC,IAAI,EAAE,CAAC;IACvC,CAAC;IAEQ,oBAAoB;QAC3B,OAAO;YACL,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,QAAQ,EAAE,IAAI,CAAC,QAAQ;SACxB,CAAC;IACJ,CAAC;IAEQ,eAAe,CAAC,SAAwC;QAC/D,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IAC7B,CAAC;CACF"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { PhysicalProperties, VoidNode } from './plan-node.js';
|
|
2
|
+
import { PlanNodeType } from './plan-node-type.js';
|
|
3
|
+
import type { Scope } from '../scopes/scope.js';
|
|
4
|
+
/**
|
|
5
|
+
* Plan node for DROP INDEX statements.
|
|
6
|
+
* Removes a secondary index from its owning table.
|
|
7
|
+
*/
|
|
8
|
+
export declare class DropIndexNode extends VoidNode {
|
|
9
|
+
readonly indexName: string;
|
|
10
|
+
readonly schemaName: string;
|
|
11
|
+
readonly ifExists: boolean;
|
|
12
|
+
readonly nodeType = PlanNodeType.DropIndex;
|
|
13
|
+
constructor(scope: Scope, indexName: string, schemaName: string, ifExists: boolean);
|
|
14
|
+
toString(): string;
|
|
15
|
+
getLogicalAttributes(): Record<string, unknown>;
|
|
16
|
+
computePhysical(_children: readonly PhysicalProperties[]): Partial<PhysicalProperties>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=drop-index-node.d.ts.map
|