@quereus/quereus 0.5.2 → 0.6.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/README.md +5 -1
- package/dist/src/common/datatype.d.ts +4 -5
- package/dist/src/common/datatype.d.ts.map +1 -1
- package/dist/src/common/datatype.js.map +1 -1
- package/dist/src/common/type-inference.d.ts +3 -6
- package/dist/src/common/type-inference.d.ts.map +1 -1
- package/dist/src/common/type-inference.js +17 -22
- package/dist/src/common/type-inference.js.map +1 -1
- package/dist/src/core/param.d.ts.map +1 -1
- package/dist/src/core/param.js +3 -18
- package/dist/src/core/param.js.map +1 -1
- package/dist/src/func/builtins/aggregate.d.ts.map +1 -1
- package/dist/src/func/builtins/aggregate.js +24 -2
- package/dist/src/func/builtins/aggregate.js.map +1 -1
- package/dist/src/func/builtins/builtin-window-functions.js +10 -10
- package/dist/src/func/builtins/builtin-window-functions.js.map +1 -1
- package/dist/src/func/builtins/conversion.d.ts +10 -0
- package/dist/src/func/builtins/conversion.d.ts.map +1 -1
- package/dist/src/func/builtins/conversion.js +20 -1
- package/dist/src/func/builtins/conversion.js.map +1 -1
- package/dist/src/func/builtins/explain.js +53 -53
- package/dist/src/func/builtins/explain.js.map +1 -1
- package/dist/src/func/builtins/generation.js +2 -2
- package/dist/src/func/builtins/generation.js.map +1 -1
- package/dist/src/func/builtins/index.d.ts.map +1 -1
- package/dist/src/func/builtins/index.js +16 -1
- package/dist/src/func/builtins/index.js.map +1 -1
- package/dist/src/func/builtins/json-tvf.js +17 -17
- package/dist/src/func/builtins/json-tvf.js.map +1 -1
- package/dist/src/func/builtins/scalar.d.ts.map +1 -1
- package/dist/src/func/builtins/scalar.js +202 -13
- package/dist/src/func/builtins/scalar.js.map +1 -1
- package/dist/src/func/builtins/schema.js +18 -18
- package/dist/src/func/builtins/schema.js.map +1 -1
- package/dist/src/func/builtins/string.d.ts.map +1 -1
- package/dist/src/func/builtins/string.js +56 -47
- package/dist/src/func/builtins/string.js.map +1 -1
- package/dist/src/func/builtins/timespan.d.ts +45 -0
- package/dist/src/func/builtins/timespan.d.ts.map +1 -0
- package/dist/src/func/builtins/timespan.js +147 -0
- package/dist/src/func/builtins/timespan.js.map +1 -0
- package/dist/src/func/registration.d.ts +26 -0
- package/dist/src/func/registration.d.ts.map +1 -1
- package/dist/src/func/registration.js +9 -5
- package/dist/src/func/registration.js.map +1 -1
- package/dist/src/index.d.ts +1 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +1 -1
- package/dist/src/index.js.map +1 -1
- package/dist/src/parser/parser.js +2 -2
- package/dist/src/parser/parser.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 +3 -3
- package/dist/src/planner/building/delete.js.map +1 -1
- package/dist/src/planner/building/function-call.d.ts.map +1 -1
- package/dist/src/planner/building/function-call.js +24 -4
- package/dist/src/planner/building/function-call.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.d.ts.map +1 -1
- package/dist/src/planner/building/select.js +3 -2
- package/dist/src/planner/building/select.js.map +1 -1
- package/dist/src/planner/building/update.js +7 -7
- package/dist/src/planner/building/update.js.map +1 -1
- package/dist/src/planner/nodes/aggregate-function.d.ts +2 -1
- package/dist/src/planner/nodes/aggregate-function.d.ts.map +1 -1
- package/dist/src/planner/nodes/aggregate-function.js +10 -3
- package/dist/src/planner/nodes/aggregate-function.js.map +1 -1
- package/dist/src/planner/nodes/cte-node.d.ts.map +1 -1
- package/dist/src/planner/nodes/cte-node.js +2 -2
- package/dist/src/planner/nodes/cte-node.js.map +1 -1
- package/dist/src/planner/nodes/declarative-schema.js +3 -3
- package/dist/src/planner/nodes/declarative-schema.js.map +1 -1
- package/dist/src/planner/nodes/function.d.ts +2 -1
- package/dist/src/planner/nodes/function.d.ts.map +1 -1
- package/dist/src/planner/nodes/function.js +6 -3
- package/dist/src/planner/nodes/function.js.map +1 -1
- package/dist/src/planner/nodes/insert-node.js +1 -1
- package/dist/src/planner/nodes/insert-node.js.map +1 -1
- package/dist/src/planner/nodes/pragma.d.ts +1 -1
- package/dist/src/planner/nodes/pragma.d.ts.map +1 -1
- package/dist/src/planner/nodes/pragma.js +3 -3
- package/dist/src/planner/nodes/pragma.js.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/scalar.d.ts.map +1 -1
- package/dist/src/planner/nodes/scalar.js +55 -101
- package/dist/src/planner/nodes/scalar.js.map +1 -1
- package/dist/src/planner/nodes/sequencing-node.js +2 -2
- package/dist/src/planner/nodes/sequencing-node.js.map +1 -1
- package/dist/src/planner/nodes/sink-node.js +2 -2
- package/dist/src/planner/nodes/sink-node.js.map +1 -1
- package/dist/src/planner/nodes/subquery.d.ts.map +1 -1
- package/dist/src/planner/nodes/subquery.js +4 -7
- package/dist/src/planner/nodes/subquery.js.map +1 -1
- package/dist/src/planner/nodes/view-reference-node.d.ts.map +1 -1
- package/dist/src/planner/nodes/view-reference-node.js +2 -2
- package/dist/src/planner/nodes/view-reference-node.js.map +1 -1
- package/dist/src/planner/nodes/window-function.js +3 -3
- package/dist/src/planner/nodes/window-function.js.map +1 -1
- package/dist/src/planner/rules/access/rule-select-access-path.js +1 -1
- package/dist/src/planner/rules/access/rule-select-access-path.js.map +1 -1
- package/dist/src/planner/rules/retrieve/rule-grow-retrieve.js +1 -1
- package/dist/src/planner/rules/retrieve/rule-grow-retrieve.js.map +1 -1
- package/dist/src/planner/scopes/global.js +3 -3
- package/dist/src/planner/scopes/global.js.map +1 -1
- package/dist/src/planner/scopes/param.d.ts.map +1 -1
- package/dist/src/planner/scopes/param.js +2 -2
- package/dist/src/planner/scopes/param.js.map +1 -1
- package/dist/src/planner/type-utils.d.ts +2 -12
- package/dist/src/planner/type-utils.d.ts.map +1 -1
- package/dist/src/planner/type-utils.js +6 -21
- package/dist/src/planner/type-utils.js.map +1 -1
- package/dist/src/runtime/emit/binary.d.ts.map +1 -1
- package/dist/src/runtime/emit/binary.js +40 -2
- package/dist/src/runtime/emit/binary.js.map +1 -1
- package/dist/src/runtime/emit/temporal-arithmetic.d.ts +33 -0
- package/dist/src/runtime/emit/temporal-arithmetic.d.ts.map +1 -0
- package/dist/src/runtime/emit/temporal-arithmetic.js +269 -0
- package/dist/src/runtime/emit/temporal-arithmetic.js.map +1 -0
- package/dist/src/runtime/emit/unary.d.ts.map +1 -1
- package/dist/src/runtime/emit/unary.js +12 -0
- package/dist/src/runtime/emit/unary.js.map +1 -1
- package/dist/src/schema/catalog.js +3 -3
- package/dist/src/schema/catalog.js.map +1 -1
- package/dist/src/schema/column.d.ts +0 -3
- package/dist/src/schema/column.d.ts.map +1 -1
- package/dist/src/schema/column.js +0 -2
- package/dist/src/schema/column.js.map +1 -1
- package/dist/src/schema/function.d.ts +29 -1
- package/dist/src/schema/function.d.ts.map +1 -1
- package/dist/src/schema/function.js.map +1 -1
- package/dist/src/schema/table.d.ts +3 -3
- package/dist/src/schema/table.d.ts.map +1 -1
- package/dist/src/schema/table.js +4 -6
- package/dist/src/schema/table.js.map +1 -1
- package/dist/src/types/index.d.ts +1 -1
- package/dist/src/types/index.d.ts.map +1 -1
- package/dist/src/types/index.js +1 -1
- package/dist/src/types/index.js.map +1 -1
- package/dist/src/types/registry.d.ts.map +1 -1
- package/dist/src/types/registry.js +5 -1
- package/dist/src/types/registry.js.map +1 -1
- package/dist/src/types/temporal-types.d.ts +5 -0
- package/dist/src/types/temporal-types.d.ts.map +1 -1
- package/dist/src/types/temporal-types.js +122 -0
- package/dist/src/types/temporal-types.js.map +1 -1
- package/dist/src/util/plan-formatter.d.ts.map +1 -1
- package/dist/src/util/plan-formatter.js +1 -5
- package/dist/src/util/plan-formatter.js.map +1 -1
- package/dist/src/util/row-descriptor.js +2 -2
- package/dist/src/util/row-descriptor.js.map +1 -1
- package/dist/src/vtab/best-access-plan.d.ts +4 -3
- 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/memory/module.js +1 -1
- package/dist/src/vtab/memory/module.js.map +1 -1
- package/package.json +1 -1
- package/src/common/datatype.ts +4 -5
- package/src/common/type-inference.ts +13 -22
- package/src/core/param.ts +4 -11
- package/src/func/builtins/aggregate.ts +24 -2
- package/src/func/builtins/builtin-window-functions.ts +10 -10
- package/src/func/builtins/conversion.ts +26 -1
- package/src/func/builtins/explain.ts +53 -53
- package/src/func/builtins/generation.ts +2 -2
- package/src/func/builtins/index.ts +20 -1
- package/src/func/builtins/json-tvf.ts +17 -17
- package/src/func/builtins/scalar.ts +205 -14
- package/src/func/builtins/schema.ts +18 -18
- package/src/func/builtins/string.ts +91 -78
- package/src/func/builtins/timespan.ts +179 -0
- package/src/func/registration.ts +35 -5
- package/src/index.ts +2 -1
- package/src/parser/parser.ts +2 -2
- package/src/planner/building/constraint-builder.ts +2 -2
- package/src/planner/building/delete.ts +3 -3
- package/src/planner/building/function-call.ts +44 -3
- package/src/planner/building/insert.ts +3 -3
- package/src/planner/building/select.ts +3 -2
- package/src/planner/building/update.ts +7 -7
- package/src/planner/nodes/aggregate-function.ts +13 -3
- package/src/planner/nodes/cte-node.ts +2 -2
- package/src/planner/nodes/declarative-schema.ts +3 -3
- package/src/planner/nodes/function.ts +8 -3
- package/src/planner/nodes/insert-node.ts +1 -1
- package/src/planner/nodes/pragma.ts +4 -3
- package/src/planner/nodes/reference.ts +1 -1
- package/src/planner/nodes/scalar.ts +54 -102
- package/src/planner/nodes/sequencing-node.ts +2 -2
- package/src/planner/nodes/sink-node.ts +2 -2
- package/src/planner/nodes/subquery.ts +5 -7
- package/src/planner/nodes/view-reference-node.ts +2 -2
- package/src/planner/nodes/window-function.ts +3 -3
- package/src/planner/rules/access/rule-select-access-path.ts +1 -1
- package/src/planner/rules/retrieve/rule-grow-retrieve.ts +1 -1
- package/src/planner/scopes/global.ts +3 -3
- package/src/planner/scopes/param.ts +2 -2
- package/src/planner/type-utils.ts +6 -14
- package/src/runtime/emit/binary.ts +48 -2
- package/src/runtime/emit/temporal-arithmetic.ts +302 -0
- package/src/runtime/emit/unary.ts +13 -0
- package/src/schema/catalog.ts +3 -3
- package/src/schema/column.ts +0 -3
- package/src/schema/function.ts +29 -1
- package/src/schema/table.ts +5 -7
- package/src/types/index.ts +1 -1
- package/src/types/registry.ts +5 -1
- package/src/types/temporal-types.ts +123 -0
- package/src/util/plan-formatter.ts +1 -4
- package/src/util/row-descriptor.ts +2 -2
- package/src/vtab/best-access-plan.ts +4 -3
- package/src/vtab/memory/module.ts +1 -1
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { PlanNode } from './plan-node.js';
|
|
2
2
|
import { PlanNodeType } from './plan-node-type.js';
|
|
3
|
-
import {
|
|
3
|
+
import { TEXT_TYPE } from '../../types/builtin-types.js';
|
|
4
4
|
/**
|
|
5
5
|
* DECLARE SCHEMA statement plan node
|
|
6
6
|
*/
|
|
@@ -51,7 +51,7 @@ export class DiffSchemaNode extends PlanNode {
|
|
|
51
51
|
name: 'ddl',
|
|
52
52
|
type: {
|
|
53
53
|
typeClass: 'scalar',
|
|
54
|
-
|
|
54
|
+
logicalType: TEXT_TYPE,
|
|
55
55
|
nullable: false,
|
|
56
56
|
isReadOnly: true,
|
|
57
57
|
},
|
|
@@ -139,7 +139,7 @@ export class ExplainSchemaNode extends PlanNode {
|
|
|
139
139
|
name: 'info',
|
|
140
140
|
type: {
|
|
141
141
|
typeClass: 'scalar',
|
|
142
|
-
|
|
142
|
+
logicalType: TEXT_TYPE,
|
|
143
143
|
nullable: false,
|
|
144
144
|
isReadOnly: true,
|
|
145
145
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"declarative-schema.js","sourceRoot":"","sources":["../../../../src/planner/nodes/declarative-schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAqD,MAAM,gBAAgB,CAAC;AAC7F,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAInD,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"declarative-schema.js","sourceRoot":"","sources":["../../../../src/planner/nodes/declarative-schema.ts"],"names":[],"mappings":"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"}
|
|
@@ -9,7 +9,8 @@ export declare class ScalarFunctionCallNode extends PlanNode implements NaryScal
|
|
|
9
9
|
readonly functionSchema: FunctionSchema;
|
|
10
10
|
readonly operands: ScalarPlanNode[];
|
|
11
11
|
readonly nodeType = PlanNodeType.ScalarFunctionCall;
|
|
12
|
-
|
|
12
|
+
private readonly _inferredType?;
|
|
13
|
+
constructor(scope: Scope, expression: AST.FunctionExpr, functionSchema: FunctionSchema, operands: ScalarPlanNode[], inferredType?: ScalarType);
|
|
13
14
|
getType(): ScalarType;
|
|
14
15
|
getChildren(): readonly ScalarPlanNode[];
|
|
15
16
|
getRelations(): readonly [];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"function.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/function.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,KAAK,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAChD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,KAAK,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAC7G,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAG/D,qBAAa,sBAAuB,SAAQ,QAAS,YAAW,cAAc;
|
|
1
|
+
{"version":3,"file":"function.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/function.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,KAAK,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAChD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,KAAK,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAC7G,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAG/D,qBAAa,sBAAuB,SAAQ,QAAS,YAAW,cAAc;aAM5D,UAAU,EAAE,GAAG,CAAC,YAAY;aAC5B,cAAc,EAAE,cAAc;aAC9B,QAAQ,EAAE,cAAc,EAAE;IAP3C,SAAkB,QAAQ,mCAAmC;IAC7D,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAa;gBAG3C,KAAK,EAAE,KAAK,EACI,UAAU,EAAE,GAAG,CAAC,YAAY,EAC5B,cAAc,EAAE,cAAc,EAC9B,QAAQ,EAAE,cAAc,EAAE,EAC1C,YAAY,CAAC,EAAE,UAAU;IAM1B,OAAO,IAAI,UAAU;IAKrB,WAAW,IAAI,SAAS,cAAc,EAAE;IAIxC,YAAY,IAAI,SAAS,EAAE;IAI3B,YAAY,CAAC,WAAW,EAAE,SAAS,QAAQ,EAAE,GAAG,QAAQ;IA4B/C,QAAQ,IAAI,MAAM;IAIlB,eAAe,CAAC,iBAAiB,EAAE,kBAAkB,EAAE,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAqBrF,oBAAoB,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAOxD"}
|
|
@@ -7,14 +7,17 @@ export class ScalarFunctionCallNode extends PlanNode {
|
|
|
7
7
|
functionSchema;
|
|
8
8
|
operands;
|
|
9
9
|
nodeType = PlanNodeType.ScalarFunctionCall;
|
|
10
|
-
|
|
10
|
+
_inferredType;
|
|
11
|
+
constructor(scope, expression, functionSchema, operands, inferredType) {
|
|
11
12
|
super(scope);
|
|
12
13
|
this.expression = expression;
|
|
13
14
|
this.functionSchema = functionSchema;
|
|
14
15
|
this.operands = operands;
|
|
16
|
+
this._inferredType = inferredType;
|
|
15
17
|
}
|
|
16
18
|
getType() {
|
|
17
|
-
return
|
|
19
|
+
// Use inferred type if available, otherwise use schema's return type
|
|
20
|
+
return this._inferredType ?? this.functionSchema.returnType;
|
|
18
21
|
}
|
|
19
22
|
getChildren() {
|
|
20
23
|
return this.operands;
|
|
@@ -38,7 +41,7 @@ export class ScalarFunctionCallNode extends PlanNode {
|
|
|
38
41
|
return this;
|
|
39
42
|
}
|
|
40
43
|
// Create new instance
|
|
41
|
-
return new ScalarFunctionCallNode(this.scope, this.expression, this.functionSchema, newChildren);
|
|
44
|
+
return new ScalarFunctionCallNode(this.scope, this.expression, this.functionSchema, newChildren, this._inferredType);
|
|
42
45
|
}
|
|
43
46
|
toString() {
|
|
44
47
|
return `${this.expression.name}(${formatExpressionList(this.operands)})`;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"function.js","sourceRoot":"","sources":["../../../../src/planner/nodes/function.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,QAAQ,EAAqE,MAAM,gBAAgB,CAAC;AAC7G,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAEtF,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAE1D,MAAM,OAAO,sBAAuB,SAAQ,QAAQ;
|
|
1
|
+
{"version":3,"file":"function.js","sourceRoot":"","sources":["../../../../src/planner/nodes/function.ts"],"names":[],"mappings":"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"}
|
|
@@ -49,7 +49,7 @@ export class InsertNode extends PlanNode {
|
|
|
49
49
|
name: col.name,
|
|
50
50
|
type: {
|
|
51
51
|
typeClass: 'scalar',
|
|
52
|
-
|
|
52
|
+
logicalType: col.logicalType,
|
|
53
53
|
nullable: isOld ? true : !col.notNull, // OLD values can be null, NEW follows column constraints
|
|
54
54
|
isReadOnly: false
|
|
55
55
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"insert-node.js","sourceRoot":"","sources":["../../../../src/planner/nodes/insert-node.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAA6G,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AACvK,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAInD;;;GAGG;AACH,MAAM,OAAO,UAAW,SAAQ,QAAQ;IAKpB;IACA;IACA;IACA;IACA;IACA;IACA;IAVA,QAAQ,GAAG,YAAY,CAAC,MAAM,CAAC;IAEjD,YACE,KAAY,EACI,KAAyB,EACzB,aAA0B,EAC1B,MAA0B,EAAE,4CAA4C;IACxE,iBAAiC,EAAE,8BAA8B;IACjE,qBAAmD,EAAE,qCAAqC;IAC1F,iBAA+B,EAAE,8BAA8B;IAC/D,iBAAiC;QAEjD,KAAK,CAAC,KAAK,CAAC,CAAC;QARG,UAAK,GAAL,KAAK,CAAoB;QACzB,kBAAa,GAAb,aAAa,CAAa;QAC1B,WAAM,GAAN,MAAM,CAAoB;QAC1B,sBAAiB,GAAjB,iBAAiB,CAAgB;QACjC,0BAAqB,GAArB,qBAAqB,CAA8B;QACnD,sBAAiB,GAAjB,iBAAiB,CAAc;QAC/B,sBAAiB,GAAjB,iBAAiB,CAAgB;IAGnD,CAAC;IAEO,OAAO;QACf,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;IAC9B,CAAC;IAEA,aAAa;QACX,uGAAuG;QACvG,IAAI,IAAI,CAAC,iBAAiB,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC7E,0EAA0E;YAC1E,MAAM,UAAU,GAAgB,EAAE,CAAC;YAEnC,mDAAmD;YACnD,KAAK,MAAM,SAAS,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBAC/C,MAAM,MAAM,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAC;gBACnC,MAAM,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;gBAEjD,iDAAiD;gBACjD,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC;gBAC/D,MAAM,KAAK,GAAG,SAAS,GAAG,gBAAgB,CAAC;gBAC3C,MAAM,WAAW,GAAG,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,GAAG,gBAAgB,CAAC;gBACrE,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;gBAExD,UAAU,CAAC,SAAS,CAAC,GAAG;oBACtB,EAAE,EAAE,MAAM;oBACV,IAAI,EAAE,GAAG,CAAC,IAAI;oBACd,IAAI,EAAE;wBACJ,SAAS,EAAE,QAAQ;wBACnB,
|
|
1
|
+
{"version":3,"file":"insert-node.js","sourceRoot":"","sources":["../../../../src/planner/nodes/insert-node.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import type { SqlValue } from '../../common/types.js';
|
|
2
2
|
import * as AST from '../../parser/ast.js';
|
|
3
3
|
import { Attribute, type RelationalPlanNode } from './plan-node.js';
|
|
4
4
|
import { PlanNodeType } from './plan-node-type.js';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pragma.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/pragma.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"pragma.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/pragma.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAE,KAAK,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACpE,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAG3C,qBAAa,cAAe,SAAQ,QAAS,YAAW,kBAAkB;aAKxD,UAAU,EAAE,MAAM;aAClB,YAAY,EAAE,GAAG,CAAC,UAAU;aAC5B,KAAK,CAAC,EAAE,QAAQ;IANjC,SAAkB,QAAQ,uBAAuB;gBAGhD,KAAK,EAAE,KAAK,EACI,UAAU,EAAE,MAAM,EAClB,YAAY,EAAE,GAAG,CAAC,UAAU,EAC5B,KAAK,CAAC,EAAE,QAAQ,YAAA;IAKjC,OAAO,IAAI,YAAY;IA+BvB,IAAI,aAAa,IAAI,MAAM,GAAG,SAAS,CAEtC;IAED,aAAa,IAAI,SAAS,EAAE;IAW5B,WAAW,IAAI,QAAQ,EAAE;IAIzB,YAAY,CAAC,YAAY,EAAE,SAAS,QAAQ,EAAE,GAAG,QAAQ;IAIhD,QAAQ,IAAI,MAAM;IAOlB,oBAAoB,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAcxD"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { SqlDataType } from '../../common/types.js';
|
|
2
1
|
import { PlanNodeType } from './plan-node-type.js';
|
|
3
2
|
import { expressionToString } from '../../util/ast-stringify.js';
|
|
4
3
|
import { PlanNode } from './plan-node.js';
|
|
4
|
+
import { TEXT_TYPE } from '../../types/builtin-types.js';
|
|
5
5
|
export class PragmaPlanNode extends PlanNode {
|
|
6
6
|
pragmaName;
|
|
7
7
|
statementAst;
|
|
@@ -23,7 +23,7 @@ export class PragmaPlanNode extends PlanNode {
|
|
|
23
23
|
name: "name",
|
|
24
24
|
type: {
|
|
25
25
|
typeClass: 'scalar',
|
|
26
|
-
|
|
26
|
+
logicalType: TEXT_TYPE,
|
|
27
27
|
nullable: false,
|
|
28
28
|
isReadOnly: true,
|
|
29
29
|
},
|
|
@@ -33,7 +33,7 @@ export class PragmaPlanNode extends PlanNode {
|
|
|
33
33
|
name: "value",
|
|
34
34
|
type: {
|
|
35
35
|
typeClass: 'scalar',
|
|
36
|
-
|
|
36
|
+
logicalType: TEXT_TYPE,
|
|
37
37
|
nullable: false,
|
|
38
38
|
},
|
|
39
39
|
generated: true,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pragma.js","sourceRoot":"","sources":["../../../../src/planner/nodes/pragma.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"pragma.js","sourceRoot":"","sources":["../../../../src/planner/nodes/pragma.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACjE,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAG1C,OAAO,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAC;AAEzD,MAAM,OAAO,cAAe,SAAQ,QAAQ;IAK1B;IACA;IACA;IANC,QAAQ,GAAG,YAAY,CAAC,MAAM,CAAC;IAEjD,YACC,KAAY,EACI,UAAkB,EAClB,YAA4B,EAC5B,KAAgB;QAEhC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,kCAAkC;QAJnC,eAAU,GAAV,UAAU,CAAQ;QAClB,iBAAY,GAAZ,YAAY,CAAgB;QAC5B,UAAK,GAAL,KAAK,CAAW;IAGjC,CAAC;IAED,OAAO;QACN,OAAO;YACN,SAAS,EAAE,UAAU;YACrB,UAAU,EAAE,IAAI;YAChB,KAAK,EAAE,IAAI;YACX,OAAO,EAAE;gBACR;oBACC,IAAI,EAAE,MAAM;oBACZ,IAAI,EAAE;wBACL,SAAS,EAAE,QAAQ;wBACnB,WAAW,EAAE,SAAS;wBACtB,QAAQ,EAAE,KAAK;wBACf,UAAU,EAAE,IAAI;qBAChB;oBACD,SAAS,EAAE,IAAI;iBACf;gBACD;oBACC,IAAI,EAAE,OAAO;oBACb,IAAI,EAAE;wBACL,SAAS,EAAE,QAAQ;wBACnB,WAAW,EAAE,SAAS;wBACtB,QAAQ,EAAE,KAAK;qBACf;oBACD,SAAS,EAAE,IAAI;iBACf;aACD;YACD,IAAI,EAAE,CAAC,EAAE,CAAC;YACV,cAAc,EAAE,EAAE;SAClB,CAAC;IACH,CAAC;IAED,IAAI,aAAa;QAChB,OAAO,CAAC,CAAC;IACV,CAAC;IAED,aAAa;QACZ,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAC7C;YACC,EAAE,EAAE,QAAQ,CAAC,UAAU,EAAE;YACzB,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,4BAA4B;YAC/C,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,cAAc,EAAE,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,EAAE,EAAE;SAE9C,CAAA,CAAC,CAAC;IACJ,CAAC;IAED,WAAW;QACV,OAAO,EAAE,CAAC;IACX,CAAC;IAED,YAAY,CAAC,YAAiC;QAC7C,OAAO,IAAI,cAAc,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;IACvF,CAAC;IAEQ,QAAQ;QAChB,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC9B,OAAO,UAAU,IAAI,CAAC,UAAU,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QACpD,CAAC;QACD,OAAO,UAAU,IAAI,CAAC,UAAU,EAAE,CAAC;IACpC,CAAC;IAEQ,oBAAoB;QAC5B,MAAM,KAAK,GAA4B;YACtC,IAAI,EAAE,QAAQ;YACd,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI;YAC5B,8DAA8D;YAC9D,SAAS,EAAE,kBAAkB,CAAC,IAAI,CAAC,YAAmB,CAAC;SACvD,CAAC;QAEF,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC9B,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QAC1B,CAAC;QAED,OAAO,KAAK,CAAC;IACd,CAAC;CACD"}
|
|
@@ -27,7 +27,7 @@ export class TableReferenceNode extends PlanNode {
|
|
|
27
27
|
name: column.name,
|
|
28
28
|
type: {
|
|
29
29
|
typeClass: 'scalar',
|
|
30
|
-
|
|
30
|
+
logicalType: column.logicalType,
|
|
31
31
|
nullable: !column.notNull,
|
|
32
32
|
isReadOnly: false,
|
|
33
33
|
collationName: column.collation
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"reference.js","sourceRoot":"","sources":["../../../../src/planner/nodes/reference.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAsE,MAAM,gBAAgB,CAAC;AAC9G,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAInD,OAAO,EAAE,2BAA2B,EAAE,MAAM,kBAAkB,CAAC;AAC/D,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAE9C,OAAO,EAAE,2BAA2B,EAAE,MAAM,0BAA0B,CAAC;AACvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAKnD,8DAA8D;AAC9D,MAAM,OAAO,kBAAmB,SAAQ,QAAQ;IAQ9B;IACA;IACA;IATC,QAAQ,GAAG,YAAY,CAAC,cAAc,CAAC;IAEjD,SAAS,CAAuB;IAChC,eAAe,CAAsB;IAE7C,YACC,KAAY,EACI,WAAwB,EACxB,UAAiC,EACjC,WAAqB,EACrC,qBAA8B;QAE9B,KAAK,CAAC,KAAK,EAAE,qBAAqB,IAAI,CAAC,CAAC,CAAC;QALzB,gBAAW,GAAX,WAAW,CAAa;QACxB,eAAU,GAAV,UAAU,CAAuB;QACjC,gBAAW,GAAX,WAAW,CAAU;QAIrC,IAAI,CAAC,SAAS,GAAG,IAAI,MAAM,CAAC,GAAG,EAAE,CAAC,2BAA2B,CAAC,WAAW,CAAC,CAAC,CAAC;QAC5E,IAAI,CAAC,eAAe,GAAG,IAAI,MAAM,CAAC,GAAG,EAAE;YACtC,8CAA8C;YAC9C,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;gBAChD,EAAE,EAAE,QAAQ,CAAC,UAAU,EAAE;gBACzB,IAAI,EAAE,MAAM,CAAC,IAAI;gBACjB,IAAI,EAAE;oBACL,SAAS,EAAE,QAAiB;oBAC5B,
|
|
1
|
+
{"version":3,"file":"reference.js","sourceRoot":"","sources":["../../../../src/planner/nodes/reference.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scalar.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/scalar.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,WAAW,EAAe,MAAM,uBAAuB,CAAC;AACjE,OAAO,EAAE,QAAQ,EAAE,KAAK,cAAc,EAAE,KAAK,eAAe,EAAE,KAAK,cAAc,EAAE,KAAK,iBAAiB,EAAE,KAAK,gBAAgB,EAAE,kBAAkB,EAAE,KAAK,YAAY,EAAE,KAAK,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACxN,OAAO,KAAK,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAChD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"scalar.d.ts","sourceRoot":"","sources":["../../../../src/planner/nodes/scalar.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import { SqlDataType } from "../../common/types.js";
|
|
2
1
|
import { PlanNode } from "./plan-node.js";
|
|
3
2
|
import { PlanNodeType } from "./plan-node-type.js";
|
|
4
3
|
import { Cached } from "../../util/cached.js";
|
|
5
4
|
import { formatExpression, formatScalarType } from "../../util/plan-formatter.js";
|
|
6
5
|
import { quereusError } from '../../common/errors.js';
|
|
7
6
|
import { StatusCode } from '../../common/types.js';
|
|
7
|
+
import { NULL_TYPE, INTEGER_TYPE, REAL_TYPE, TEXT_TYPE, BLOB_TYPE, BOOLEAN_TYPE } from "../../types/builtin-types.js";
|
|
8
|
+
import { typeRegistry } from "../../types/registry.js";
|
|
8
9
|
export class UnaryOpNode extends PlanNode {
|
|
9
10
|
scope;
|
|
10
11
|
expression;
|
|
@@ -20,34 +21,29 @@ export class UnaryOpNode extends PlanNode {
|
|
|
20
21
|
}
|
|
21
22
|
generateType = () => {
|
|
22
23
|
const operandType = this.operand.getType();
|
|
23
|
-
let
|
|
24
|
-
let affinity = operandType.affinity;
|
|
24
|
+
let logicalType = operandType.logicalType;
|
|
25
25
|
let nullable = operandType.nullable;
|
|
26
26
|
switch (this.expression.operator) {
|
|
27
27
|
case 'NOT':
|
|
28
28
|
case 'IS NULL':
|
|
29
29
|
case 'IS NOT NULL':
|
|
30
|
-
|
|
31
|
-
affinity = SqlDataType.INTEGER;
|
|
30
|
+
logicalType = BOOLEAN_TYPE;
|
|
32
31
|
nullable = false; // Boolean results are never null
|
|
33
32
|
break;
|
|
34
33
|
case '-':
|
|
35
34
|
case '+':
|
|
36
|
-
// Numeric unary operators preserve type
|
|
37
|
-
datatype = operandType.datatype;
|
|
35
|
+
// Numeric unary operators preserve type
|
|
38
36
|
break;
|
|
39
37
|
case '~':
|
|
40
38
|
// Bitwise NOT - results in integer
|
|
41
|
-
|
|
42
|
-
affinity = SqlDataType.INTEGER;
|
|
39
|
+
logicalType = INTEGER_TYPE;
|
|
43
40
|
break;
|
|
44
41
|
}
|
|
45
42
|
return {
|
|
46
43
|
typeClass: 'scalar',
|
|
47
|
-
|
|
44
|
+
logicalType,
|
|
48
45
|
nullable,
|
|
49
46
|
isReadOnly: operandType.isReadOnly,
|
|
50
|
-
datatype,
|
|
51
47
|
collationName: operandType.collationName,
|
|
52
48
|
};
|
|
53
49
|
};
|
|
@@ -105,16 +101,10 @@ export class BinaryOpNode extends PlanNode {
|
|
|
105
101
|
generateType = () => {
|
|
106
102
|
const leftType = this.left.getType();
|
|
107
103
|
const rightType = this.right.getType();
|
|
108
|
-
|
|
109
|
-
let datatype;
|
|
104
|
+
let logicalType = leftType.logicalType;
|
|
110
105
|
switch (this.expression.operator) {
|
|
111
106
|
case 'OR':
|
|
112
107
|
case 'AND':
|
|
113
|
-
case '+':
|
|
114
|
-
case '-':
|
|
115
|
-
case '*':
|
|
116
|
-
case '/':
|
|
117
|
-
case '%':
|
|
118
108
|
case '=':
|
|
119
109
|
case '!=':
|
|
120
110
|
case '<':
|
|
@@ -124,10 +114,35 @@ export class BinaryOpNode extends PlanNode {
|
|
|
124
114
|
case 'IS':
|
|
125
115
|
case 'IS NOT':
|
|
126
116
|
case 'IN':
|
|
127
|
-
|
|
117
|
+
// Comparison and logical operators return boolean
|
|
118
|
+
logicalType = BOOLEAN_TYPE;
|
|
119
|
+
break;
|
|
120
|
+
case '+':
|
|
121
|
+
case '-':
|
|
122
|
+
case '*':
|
|
123
|
+
case '/':
|
|
124
|
+
case '%':
|
|
125
|
+
// Arithmetic operators - implement numeric type promotion
|
|
126
|
+
// Rules: INTEGER + INTEGER -> INTEGER, INTEGER + REAL -> REAL, REAL + REAL -> REAL
|
|
127
|
+
if (leftType.logicalType.isNumeric && rightType.logicalType.isNumeric) {
|
|
128
|
+
// Both operands are numeric
|
|
129
|
+
if (leftType.logicalType.name === 'REAL' || rightType.logicalType.name === 'REAL') {
|
|
130
|
+
// If either is REAL, result is REAL
|
|
131
|
+
logicalType = REAL_TYPE;
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
// Both are INTEGER, result is INTEGER
|
|
135
|
+
logicalType = INTEGER_TYPE;
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
// Non-numeric operands - use left operand type (fallback)
|
|
140
|
+
logicalType = leftType.logicalType;
|
|
141
|
+
}
|
|
128
142
|
break;
|
|
129
143
|
case '||':
|
|
130
|
-
|
|
144
|
+
// String concatenation
|
|
145
|
+
logicalType = TEXT_TYPE;
|
|
131
146
|
break;
|
|
132
147
|
}
|
|
133
148
|
;
|
|
@@ -135,10 +150,9 @@ export class BinaryOpNode extends PlanNode {
|
|
|
135
150
|
const collationName = leftType.collationName || rightType.collationName;
|
|
136
151
|
return {
|
|
137
152
|
typeClass: 'scalar',
|
|
138
|
-
|
|
153
|
+
logicalType,
|
|
139
154
|
nullable: leftType.nullable || rightType.nullable,
|
|
140
155
|
isReadOnly: leftType.isReadOnly || rightType.isReadOnly,
|
|
141
|
-
datatype,
|
|
142
156
|
collationName,
|
|
143
157
|
};
|
|
144
158
|
};
|
|
@@ -208,55 +222,49 @@ export class LiteralNode extends PlanNode {
|
|
|
208
222
|
if (value === null) {
|
|
209
223
|
return {
|
|
210
224
|
typeClass: 'scalar',
|
|
211
|
-
|
|
225
|
+
logicalType: NULL_TYPE,
|
|
212
226
|
nullable: true,
|
|
213
227
|
isReadOnly: true,
|
|
214
|
-
datatype: SqlDataType.NULL,
|
|
215
228
|
};
|
|
216
229
|
}
|
|
217
230
|
if (typeof value === 'number') {
|
|
218
231
|
return {
|
|
219
232
|
typeClass: 'scalar',
|
|
220
|
-
|
|
233
|
+
logicalType: REAL_TYPE,
|
|
221
234
|
nullable: false,
|
|
222
235
|
isReadOnly: true,
|
|
223
|
-
datatype: SqlDataType.REAL,
|
|
224
236
|
};
|
|
225
237
|
}
|
|
226
238
|
if (typeof value === 'bigint') {
|
|
227
239
|
return {
|
|
228
240
|
typeClass: 'scalar',
|
|
229
|
-
|
|
241
|
+
logicalType: INTEGER_TYPE,
|
|
230
242
|
nullable: false,
|
|
231
243
|
isReadOnly: true,
|
|
232
|
-
datatype: SqlDataType.INTEGER,
|
|
233
244
|
};
|
|
234
245
|
}
|
|
235
246
|
if (typeof value === 'string') {
|
|
236
247
|
return {
|
|
237
248
|
typeClass: 'scalar',
|
|
238
|
-
|
|
249
|
+
logicalType: TEXT_TYPE,
|
|
239
250
|
nullable: false,
|
|
240
251
|
isReadOnly: true,
|
|
241
|
-
datatype: SqlDataType.TEXT,
|
|
242
252
|
};
|
|
243
253
|
}
|
|
244
254
|
if (typeof value === 'boolean') {
|
|
245
255
|
return {
|
|
246
256
|
typeClass: 'scalar',
|
|
247
|
-
|
|
257
|
+
logicalType: BOOLEAN_TYPE,
|
|
248
258
|
nullable: false,
|
|
249
259
|
isReadOnly: true,
|
|
250
|
-
datatype: SqlDataType.INTEGER,
|
|
251
260
|
};
|
|
252
261
|
}
|
|
253
262
|
if (value instanceof Uint8Array) {
|
|
254
263
|
return {
|
|
255
264
|
typeClass: 'scalar',
|
|
256
|
-
|
|
265
|
+
logicalType: BLOB_TYPE,
|
|
257
266
|
nullable: false,
|
|
258
267
|
isReadOnly: true,
|
|
259
|
-
datatype: SqlDataType.BLOB,
|
|
260
268
|
};
|
|
261
269
|
}
|
|
262
270
|
quereusError(`Unknown literal type ${typeof value}`, StatusCode.INTERNAL);
|
|
@@ -328,15 +336,14 @@ export class CaseExprNode extends PlanNode {
|
|
|
328
336
|
// No THEN clauses and no ELSE - should not happen in valid SQL
|
|
329
337
|
return {
|
|
330
338
|
typeClass: 'scalar',
|
|
331
|
-
|
|
339
|
+
logicalType: NULL_TYPE,
|
|
332
340
|
nullable: true,
|
|
333
341
|
isReadOnly: true,
|
|
334
|
-
datatype: SqlDataType.NULL,
|
|
335
342
|
};
|
|
336
343
|
}
|
|
337
344
|
// Use the first result expression as the base type
|
|
338
345
|
const firstType = resultExpressions[0].getType();
|
|
339
|
-
let
|
|
346
|
+
let logicalType = firstType.logicalType;
|
|
340
347
|
let nullable = firstType.nullable;
|
|
341
348
|
let isReadOnly = firstType.isReadOnly;
|
|
342
349
|
let collationName = firstType.collationName;
|
|
@@ -356,9 +363,9 @@ export class CaseExprNode extends PlanNode {
|
|
|
356
363
|
collationName = exprType.collationName;
|
|
357
364
|
}
|
|
358
365
|
// TODO: Implement proper type coercion rules for SQL
|
|
359
|
-
// For now, if types differ, default to TEXT
|
|
360
|
-
if (exprType.
|
|
361
|
-
|
|
366
|
+
// For now, if types differ, default to TEXT
|
|
367
|
+
if (exprType.logicalType !== logicalType) {
|
|
368
|
+
logicalType = TEXT_TYPE;
|
|
362
369
|
}
|
|
363
370
|
}
|
|
364
371
|
// If there's no ELSE clause, the result can be NULL
|
|
@@ -367,11 +374,10 @@ export class CaseExprNode extends PlanNode {
|
|
|
367
374
|
}
|
|
368
375
|
return {
|
|
369
376
|
typeClass: 'scalar',
|
|
370
|
-
|
|
377
|
+
logicalType,
|
|
371
378
|
nullable,
|
|
372
379
|
isReadOnly,
|
|
373
380
|
collationName,
|
|
374
|
-
// Don't set datatype since it can vary based on runtime conditions
|
|
375
381
|
};
|
|
376
382
|
};
|
|
377
383
|
get operands() {
|
|
@@ -473,66 +479,15 @@ export class CastNode extends PlanNode {
|
|
|
473
479
|
}
|
|
474
480
|
generateType = () => {
|
|
475
481
|
const operandType = this.operand.getType();
|
|
476
|
-
const targetType = this.expression.targetType
|
|
477
|
-
//
|
|
478
|
-
|
|
479
|
-
let affinity;
|
|
480
|
-
switch (targetType) {
|
|
481
|
-
case 'INTEGER':
|
|
482
|
-
case 'INT':
|
|
483
|
-
case 'TINYINT':
|
|
484
|
-
case 'SMALLINT':
|
|
485
|
-
case 'MEDIUMINT':
|
|
486
|
-
case 'BIGINT':
|
|
487
|
-
case 'UNSIGNED BIG INT':
|
|
488
|
-
case 'INT2':
|
|
489
|
-
case 'INT8':
|
|
490
|
-
datatype = SqlDataType.INTEGER;
|
|
491
|
-
affinity = SqlDataType.INTEGER;
|
|
492
|
-
break;
|
|
493
|
-
case 'REAL':
|
|
494
|
-
case 'DOUBLE':
|
|
495
|
-
case 'DOUBLE PRECISION':
|
|
496
|
-
case 'FLOAT':
|
|
497
|
-
datatype = SqlDataType.REAL;
|
|
498
|
-
affinity = SqlDataType.REAL;
|
|
499
|
-
break;
|
|
500
|
-
case 'TEXT':
|
|
501
|
-
case 'CHARACTER':
|
|
502
|
-
case 'VARCHAR':
|
|
503
|
-
case 'VARYING CHARACTER':
|
|
504
|
-
case 'NCHAR':
|
|
505
|
-
case 'NATIVE CHARACTER':
|
|
506
|
-
case 'NVARCHAR':
|
|
507
|
-
case 'CLOB':
|
|
508
|
-
datatype = SqlDataType.TEXT;
|
|
509
|
-
affinity = SqlDataType.TEXT;
|
|
510
|
-
break;
|
|
511
|
-
case 'BLOB':
|
|
512
|
-
datatype = SqlDataType.BLOB;
|
|
513
|
-
affinity = SqlDataType.BLOB;
|
|
514
|
-
break;
|
|
515
|
-
case 'NUMERIC':
|
|
516
|
-
case 'DECIMAL':
|
|
517
|
-
case 'BOOLEAN':
|
|
518
|
-
case 'DATE':
|
|
519
|
-
case 'DATETIME':
|
|
520
|
-
datatype = SqlDataType.NUMERIC;
|
|
521
|
-
affinity = SqlDataType.NUMERIC;
|
|
522
|
-
break;
|
|
523
|
-
default:
|
|
524
|
-
// For unknown types, default to BLOB affinity
|
|
525
|
-
datatype = SqlDataType.BLOB;
|
|
526
|
-
affinity = SqlDataType.BLOB;
|
|
527
|
-
break;
|
|
528
|
-
}
|
|
482
|
+
const targetType = this.expression.targetType;
|
|
483
|
+
// Look up the logical type from the type registry
|
|
484
|
+
const logicalType = typeRegistry.getTypeOrDefault(targetType);
|
|
529
485
|
return {
|
|
530
486
|
typeClass: 'scalar',
|
|
531
|
-
|
|
487
|
+
logicalType,
|
|
532
488
|
nullable: operandType.nullable, // CAST preserves nullability
|
|
533
489
|
isReadOnly: operandType.isReadOnly,
|
|
534
|
-
|
|
535
|
-
collationName: affinity === SqlDataType.TEXT ? operandType.collationName : undefined,
|
|
490
|
+
collationName: logicalType.isTextual ? operandType.collationName : undefined,
|
|
536
491
|
};
|
|
537
492
|
};
|
|
538
493
|
getChildren() {
|
|
@@ -640,13 +595,12 @@ export class BetweenNode extends PlanNode {
|
|
|
640
595
|
this.upper = upper;
|
|
641
596
|
}
|
|
642
597
|
getType() {
|
|
643
|
-
// BETWEEN always returns
|
|
598
|
+
// BETWEEN always returns BOOLEAN
|
|
644
599
|
return {
|
|
645
600
|
typeClass: 'scalar',
|
|
646
|
-
|
|
601
|
+
logicalType: BOOLEAN_TYPE,
|
|
647
602
|
nullable: false,
|
|
648
603
|
isReadOnly: true,
|
|
649
|
-
datatype: SqlDataType.INTEGER,
|
|
650
604
|
};
|
|
651
605
|
}
|
|
652
606
|
getChildren() {
|