@shaxpir/squilt 1.0.0 → 1.1.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.
Files changed (68) hide show
  1. package/README.md +289 -1
  2. package/dist/ast/AlterTableQuery.d.ts +32 -0
  3. package/dist/ast/AlterTableQuery.js +60 -0
  4. package/dist/ast/BetweenExpression.d.ts +10 -0
  5. package/dist/ast/BetweenExpression.js +18 -0
  6. package/dist/ast/CastExpression.d.ts +13 -0
  7. package/dist/ast/CastExpression.js +25 -0
  8. package/dist/ast/CollateExpression.d.ts +18 -0
  9. package/dist/ast/CollateExpression.js +30 -0
  10. package/dist/ast/CreateIndexQuery.d.ts +25 -0
  11. package/dist/ast/CreateIndexQuery.js +64 -0
  12. package/dist/ast/CreateTableQuery.d.ts +57 -0
  13. package/dist/ast/CreateTableQuery.js +79 -0
  14. package/dist/ast/CreateViewQuery.d.ts +34 -0
  15. package/dist/ast/CreateViewQuery.js +61 -0
  16. package/dist/ast/CreateVirtualTableQuery.d.ts +32 -0
  17. package/dist/ast/CreateVirtualTableQuery.js +74 -0
  18. package/dist/ast/DeleteQuery.d.ts +17 -0
  19. package/dist/ast/DeleteQuery.js +43 -0
  20. package/dist/ast/DropIndexQuery.d.ts +14 -0
  21. package/dist/ast/DropIndexQuery.js +35 -0
  22. package/dist/ast/DropTableQuery.d.ts +14 -0
  23. package/dist/ast/DropTableQuery.js +35 -0
  24. package/dist/ast/DropViewQuery.d.ts +11 -0
  25. package/dist/ast/DropViewQuery.js +24 -0
  26. package/dist/ast/FunctionExpression.d.ts +21 -0
  27. package/dist/ast/FunctionExpression.js +40 -1
  28. package/dist/ast/FunctionName.d.ts +1 -1
  29. package/dist/ast/FunctionName.js +1 -1
  30. package/dist/ast/InsertQuery.d.ts +24 -1
  31. package/dist/ast/InsertQuery.js +49 -1
  32. package/dist/ast/Operator.d.ts +2 -0
  33. package/dist/ast/Operator.js +3 -1
  34. package/dist/ast/SelectQuery.d.ts +4 -0
  35. package/dist/ast/SelectQuery.js +11 -1
  36. package/dist/ast/SubqueryExpression.d.ts +18 -0
  37. package/dist/ast/SubqueryExpression.js +27 -0
  38. package/dist/ast/UpdateQuery.d.ts +24 -0
  39. package/dist/ast/UpdateQuery.js +51 -0
  40. package/dist/ast/WindowExpression.d.ts +51 -0
  41. package/dist/ast/WindowExpression.js +61 -0
  42. package/dist/ast/WindowSpecification.d.ts +46 -0
  43. package/dist/ast/WindowSpecification.js +60 -0
  44. package/dist/builder/QueryBuilder.d.ts +20 -0
  45. package/dist/builder/QueryBuilder.js +41 -1
  46. package/dist/builder/Shorthand.d.ts +51 -0
  47. package/dist/builder/Shorthand.js +125 -1
  48. package/dist/index.d.ts +17 -1
  49. package/dist/index.js +59 -3
  50. package/dist/renderer/CompactQueryRenderer.d.ts +34 -2
  51. package/dist/renderer/CompactQueryRenderer.js +272 -2
  52. package/dist/renderer/IndentedQueryRenderer.d.ts +34 -2
  53. package/dist/renderer/IndentedQueryRenderer.js +289 -3
  54. package/dist/renderer/QueryRenderer.d.ts +11 -1
  55. package/dist/renderer/QueryRenderer.js +1 -1
  56. package/dist/validate/CommonQueryValidator.d.ts +31 -1
  57. package/dist/validate/CommonQueryValidator.js +253 -4
  58. package/dist/validate/QueryValidator.d.ts +10 -1
  59. package/dist/validate/QueryValidator.js +1 -1
  60. package/dist/validate/SQLiteQueryValidator.d.ts +16 -1
  61. package/dist/validate/SQLiteQueryValidator.js +32 -3
  62. package/dist/visitor/ParamCollector.d.ts +30 -0
  63. package/dist/visitor/ParamCollector.js +109 -2
  64. package/dist/visitor/QueryIdentityTransformer.d.ts +30 -0
  65. package/dist/visitor/QueryIdentityTransformer.js +217 -2
  66. package/dist/visitor/SqlTreeNodeVisitor.d.ts +30 -0
  67. package/dist/visitor/SqlTreeNodeVisitor.js +1 -1
  68. package/package.json +4 -1
@@ -13,7 +13,7 @@ class SQLiteQueryValidator extends CommonQueryValidator_1.CommonQueryValidator {
13
13
  'LOWER', 'UPPER', 'LENGTH', 'SUBSTR', 'TRIM', 'LTRIM', 'RTRIM',
14
14
  'REPLACE', 'INSTR', 'QUOTE', 'CHAR', 'UNICODE', 'HEX', 'ZEROBLOB',
15
15
  'COALESCE', 'IFNULL', 'NULLIF', 'TYPEOF', 'TOTAL_CHANGES', 'CHANGES',
16
- 'LAST_INSERT_ROWID',
16
+ 'LAST_INSERT_ROWID', 'CONCAT',
17
17
  // Aggregate functions
18
18
  'COUNT', 'SUM', 'AVG', 'MIN', 'MAX', 'TOTAL', 'GROUP_CONCAT',
19
19
  // Date and time functions
@@ -22,7 +22,13 @@ class SQLiteQueryValidator extends CommonQueryValidator_1.CommonQueryValidator {
22
22
  'json', 'json_array', 'json_object', 'json_extract', 'json_insert',
23
23
  'json_replace', 'json_set', 'json_remove', 'json_type', 'json_valid',
24
24
  'json_quote', 'json_patch', 'json_array_length', 'json_group_array',
25
- 'json_group_object', 'json_each', 'json_tree'
25
+ 'json_group_object', 'json_each', 'json_tree',
26
+ // Window functions
27
+ 'ROW_NUMBER', 'RANK', 'DENSE_RANK', 'NTILE',
28
+ 'LAG', 'LEAD', 'FIRST_VALUE', 'LAST_VALUE', 'NTH_VALUE',
29
+ 'CUME_DIST', 'PERCENT_RANK',
30
+ // FTS5 functions
31
+ 'bm25', 'highlight', 'snippet', 'offsets', 'matchinfo'
26
32
  ]);
27
33
  this.supportedUnaryOperators = new Set([
28
34
  Operator_1.Operator.NOT, Operator_1.Operator.PLUS, Operator_1.Operator.MINUS,
@@ -42,6 +48,14 @@ class SQLiteQueryValidator extends CommonQueryValidator_1.CommonQueryValidator {
42
48
  super.visitInsertQuery(node);
43
49
  // SQLite-specific validation (if any) can be added here
44
50
  }
51
+ visitDeleteQuery(node) {
52
+ super.visitDeleteQuery(node);
53
+ // SQLite-specific validation (if any) can be added here
54
+ }
55
+ visitUpdateQuery(node) {
56
+ super.visitUpdateQuery(node);
57
+ // SQLite-specific validation (if any) can be added here
58
+ }
45
59
  visitSelectQuery(node) {
46
60
  super.visitSelectQuery(node);
47
61
  if (node['_limit'] !== null && node['_limit'] !== undefined && !Number.isInteger(node['_limit'])) {
@@ -91,6 +105,21 @@ class SQLiteQueryValidator extends CommonQueryValidator_1.CommonQueryValidator {
91
105
  visitInExpression(node) {
92
106
  super.visitInExpression(node);
93
107
  }
108
+ visitCreateVirtualTableQuery(node) {
109
+ super.visitCreateVirtualTableQuery(node);
110
+ // FTS5-specific validation
111
+ if (node.module === 'fts5') {
112
+ // Validate content table reference if specified
113
+ if (node.options.content) {
114
+ // Content table name should be a valid identifier
115
+ // Note: we can't validate that the table exists at this point
116
+ }
117
+ // If contentRowid is specified, content must also be specified
118
+ if (node.options.contentRowid && !node.options.content) {
119
+ throw new Error('FTS5 content_rowid requires content option to be specified');
120
+ }
121
+ }
122
+ }
94
123
  }
95
124
  exports.SQLiteQueryValidator = SQLiteQueryValidator;
96
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SQLiteQueryValidator.js","sourceRoot":"","sources":["../../src/validate/SQLiteQueryValidator.ts"],"names":[],"mappings":"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","sourcesContent":["import { JsonEachFrom, TableFrom } from \"../ast/From\";\nimport { FunctionExpression } from \"../ast/FunctionExpression\";\nimport { FunctionName } from \"../ast/FunctionName\";\nimport { InExpression } from \"../ast/InExpression\";\nimport { InsertQuery } from \"../ast/InsertQuery\";\nimport { Join, JoinType } from \"../ast/Join\";\nimport { Operator } from \"../ast/Operator\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { UnaryExpression } from \"../ast/UnaryExpression\";\nimport { With } from \"../ast/With\";\nimport { SqlTreeNodeVisitor } from \"../visitor/SqlTreeNodeVisitor\";\nimport { CommonQueryValidator } from \"./CommonQueryValidator\";\nimport { QueryValidator } from \"./QueryValidator\";\n\nexport class SQLiteQueryValidator\n  extends CommonQueryValidator\n  implements QueryValidator, SqlTreeNodeVisitor<void>\n{\n  private supportedFunctions: Set<FunctionName> = new Set([\n    // Core scalar functions\n    'ABS', 'CEIL', 'FLOOR', 'ROUND', 'TRUNC', 'RANDOM', 'RANDOMBLOB',\n    'LOWER', 'UPPER', 'LENGTH', 'SUBSTR', 'TRIM', 'LTRIM', 'RTRIM',\n    'REPLACE', 'INSTR', 'QUOTE', 'CHAR', 'UNICODE', 'HEX', 'ZEROBLOB',\n    'COALESCE', 'IFNULL', 'NULLIF', 'TYPEOF', 'TOTAL_CHANGES', 'CHANGES',\n    'LAST_INSERT_ROWID',\n    // Aggregate functions\n    'COUNT', 'SUM', 'AVG', 'MIN', 'MAX', 'TOTAL', 'GROUP_CONCAT',\n    // Date and time functions\n    'DATE', 'TIME', 'DATETIME', 'JULIANDAY', 'STRFTIME',\n    // JSON1 functions\n    'json', 'json_array', 'json_object', 'json_extract', 'json_insert',\n    'json_replace', 'json_set', 'json_remove', 'json_type', 'json_valid',\n    'json_quote', 'json_patch', 'json_array_length', 'json_group_array',\n    'json_group_object', 'json_each', 'json_tree'\n  ]);\n\n  private supportedUnaryOperators: Set<string> = new Set([\n    Operator.NOT, Operator.PLUS, Operator.MINUS,\n    Operator.IS_NULL, Operator.IS_NOT_NULL,\n  ]);\n\n  private isWithRecursive: boolean = false;\n\n  public validate(query: SelectQuery | InsertQuery): void {\n    this.reset();\n    query.accept(this);\n  }\n\n  protected reset(): void {\n    super.reset();\n    this.isWithRecursive = false;\n  }\n\n  visitInsertQuery(node: InsertQuery): void {\n    super.visitInsertQuery(node);\n    // SQLite-specific validation (if any) can be added here\n  }\n\n  visitSelectQuery(node: SelectQuery): void {\n    super.visitSelectQuery(node);\n    if (node['_limit'] !== null && node['_limit'] !== undefined && !Number.isInteger(node['_limit'])) {\n      throw new Error('SQLite LIMIT must be an integer');\n    }\n    if (node['_offset'] !== null && node['_offset'] !== undefined && !Number.isInteger(node['_offset'])) {\n      throw new Error('SQLite OFFSET must be an integer');\n    }\n  }\n\n  visitJoinClause(node: Join): void {\n    if (node.type === JoinType.RIGHT || node.type === JoinType.FULL) {\n      throw new Error(`SQLite does not support ${node.type} JOIN`);\n    }\n    super.visitJoinClause(node);\n  }\n\n  visitWithClause(node: With): void {\n    const prevRecursive = this.isWithRecursive;\n    this.isWithRecursive = false;\n    node.query.accept(this);\n    if (this.isWithRecursive) {\n      throw new Error('Recursive WITH clauses are not supported in this validator');\n    }\n    this.isWithRecursive = prevRecursive;\n    super.visitWithClause(node);\n  }\n\n  visitFunctionExpression(node: FunctionExpression): void {\n    if (!this.supportedFunctions.has(node.name)) {\n      throw new Error(`Function ${node.name} is not supported in SQLite`);\n    }\n    super.visitFunctionExpression(node);\n  }\n\n  visitTableFrom(node: TableFrom): void {\n    if (this.isWithRecursive) {\n      throw new Error('Recursive reference to WITH clause detected');\n    }\n    super.visitTableFrom(node);\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): void {\n    super.visitJsonEachFrom(node);\n  }\n\n  visitUnaryExpression(node: UnaryExpression): void {\n    if (!this.supportedUnaryOperators.has(node.operator)) {\n      throw new Error(`Unary operator ${node.operator} is not supported in SQLite`);\n    }\n    super.visitUnaryExpression(node);\n  }\n\n  visitInExpression(node: InExpression): void {\n    super.visitInExpression(node);\n  }\n}\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SQLiteQueryValidator.js","sourceRoot":"","sources":["../../src/validate/SQLiteQueryValidator.ts"],"names":[],"mappings":"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","sourcesContent":["import { AlterTableQuery } from \"../ast/AlterTableQuery\";\nimport { CreateIndexQuery } from \"../ast/CreateIndexQuery\";\nimport { CreateTableQuery } from \"../ast/CreateTableQuery\";\nimport { CreateVirtualTableQuery } from \"../ast/CreateVirtualTableQuery\";\nimport { CreateViewQuery } from \"../ast/CreateViewQuery\";\nimport { DeleteQuery } from \"../ast/DeleteQuery\";\nimport { DropIndexQuery } from \"../ast/DropIndexQuery\";\nimport { DropTableQuery } from \"../ast/DropTableQuery\";\nimport { DropViewQuery } from \"../ast/DropViewQuery\";\nimport { JsonEachFrom, TableFrom } from \"../ast/From\";\nimport { UpdateQuery } from \"../ast/UpdateQuery\";\nimport { FunctionExpression } from \"../ast/FunctionExpression\";\nimport { FunctionName } from \"../ast/FunctionName\";\nimport { InExpression } from \"../ast/InExpression\";\nimport { InsertQuery } from \"../ast/InsertQuery\";\nimport { Join, JoinType } from \"../ast/Join\";\nimport { Operator } from \"../ast/Operator\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { UnaryExpression } from \"../ast/UnaryExpression\";\nimport { With } from \"../ast/With\";\nimport { SqlTreeNodeVisitor } from \"../visitor/SqlTreeNodeVisitor\";\nimport { CommonQueryValidator } from \"./CommonQueryValidator\";\nimport { QueryValidator } from \"./QueryValidator\";\n\ntype ValidatableQuery =\n  | SelectQuery\n  | InsertQuery\n  | UpdateQuery\n  | DeleteQuery\n  | CreateTableQuery\n  | CreateVirtualTableQuery\n  | CreateIndexQuery\n  | CreateViewQuery\n  | AlterTableQuery\n  | DropTableQuery\n  | DropIndexQuery\n  | DropViewQuery;\n\nexport class SQLiteQueryValidator\n  extends CommonQueryValidator\n  implements QueryValidator, SqlTreeNodeVisitor<void>\n{\n  private supportedFunctions: Set<FunctionName> = new Set([\n    // Core scalar functions\n    'ABS', 'CEIL', 'FLOOR', 'ROUND', 'TRUNC', 'RANDOM', 'RANDOMBLOB',\n    'LOWER', 'UPPER', 'LENGTH', 'SUBSTR', 'TRIM', 'LTRIM', 'RTRIM',\n    'REPLACE', 'INSTR', 'QUOTE', 'CHAR', 'UNICODE', 'HEX', 'ZEROBLOB',\n    'COALESCE', 'IFNULL', 'NULLIF', 'TYPEOF', 'TOTAL_CHANGES', 'CHANGES',\n    'LAST_INSERT_ROWID', 'CONCAT',\n    // Aggregate functions\n    'COUNT', 'SUM', 'AVG', 'MIN', 'MAX', 'TOTAL', 'GROUP_CONCAT',\n    // Date and time functions\n    'DATE', 'TIME', 'DATETIME', 'JULIANDAY', 'STRFTIME',\n    // JSON1 functions\n    'json', 'json_array', 'json_object', 'json_extract', 'json_insert',\n    'json_replace', 'json_set', 'json_remove', 'json_type', 'json_valid',\n    'json_quote', 'json_patch', 'json_array_length', 'json_group_array',\n    'json_group_object', 'json_each', 'json_tree',\n    // Window functions\n    'ROW_NUMBER', 'RANK', 'DENSE_RANK', 'NTILE',\n    'LAG', 'LEAD', 'FIRST_VALUE', 'LAST_VALUE', 'NTH_VALUE',\n    'CUME_DIST', 'PERCENT_RANK',\n    // FTS5 functions\n    'bm25', 'highlight', 'snippet', 'offsets', 'matchinfo'\n  ]);\n\n  private supportedUnaryOperators: Set<string> = new Set([\n    Operator.NOT, Operator.PLUS, Operator.MINUS,\n    Operator.IS_NULL, Operator.IS_NOT_NULL,\n  ]);\n\n  private isWithRecursive: boolean = false;\n\n  public validate(query: ValidatableQuery): void {\n    this.reset();\n    query.accept(this);\n  }\n\n  protected reset(): void {\n    super.reset();\n    this.isWithRecursive = false;\n  }\n\n  visitInsertQuery(node: InsertQuery): void {\n    super.visitInsertQuery(node);\n    // SQLite-specific validation (if any) can be added here\n  }\n\n  visitDeleteQuery(node: DeleteQuery): void {\n    super.visitDeleteQuery(node);\n    // SQLite-specific validation (if any) can be added here\n  }\n\n  visitUpdateQuery(node: UpdateQuery): void {\n    super.visitUpdateQuery(node);\n    // SQLite-specific validation (if any) can be added here\n  }\n\n  visitSelectQuery(node: SelectQuery): void {\n    super.visitSelectQuery(node);\n    if (node['_limit'] !== null && node['_limit'] !== undefined && !Number.isInteger(node['_limit'])) {\n      throw new Error('SQLite LIMIT must be an integer');\n    }\n    if (node['_offset'] !== null && node['_offset'] !== undefined && !Number.isInteger(node['_offset'])) {\n      throw new Error('SQLite OFFSET must be an integer');\n    }\n  }\n\n  visitJoinClause(node: Join): void {\n    if (node.type === JoinType.RIGHT || node.type === JoinType.FULL) {\n      throw new Error(`SQLite does not support ${node.type} JOIN`);\n    }\n    super.visitJoinClause(node);\n  }\n\n  visitWithClause(node: With): void {\n    const prevRecursive = this.isWithRecursive;\n    this.isWithRecursive = false;\n    node.query.accept(this);\n    if (this.isWithRecursive) {\n      throw new Error('Recursive WITH clauses are not supported in this validator');\n    }\n    this.isWithRecursive = prevRecursive;\n    super.visitWithClause(node);\n  }\n\n  visitFunctionExpression(node: FunctionExpression): void {\n    if (!this.supportedFunctions.has(node.name)) {\n      throw new Error(`Function ${node.name} is not supported in SQLite`);\n    }\n    super.visitFunctionExpression(node);\n  }\n\n  visitTableFrom(node: TableFrom): void {\n    if (this.isWithRecursive) {\n      throw new Error('Recursive reference to WITH clause detected');\n    }\n    super.visitTableFrom(node);\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): void {\n    super.visitJsonEachFrom(node);\n  }\n\n  visitUnaryExpression(node: UnaryExpression): void {\n    if (!this.supportedUnaryOperators.has(node.operator)) {\n      throw new Error(`Unary operator ${node.operator} is not supported in SQLite`);\n    }\n    super.visitUnaryExpression(node);\n  }\n\n  visitInExpression(node: InExpression): void {\n    super.visitInExpression(node);\n  }\n\n  visitCreateVirtualTableQuery(node: CreateVirtualTableQuery): void {\n    super.visitCreateVirtualTableQuery(node);\n\n    // FTS5-specific validation\n    if (node.module === 'fts5') {\n      // Validate content table reference if specified\n      if (node.options.content) {\n        // Content table name should be a valid identifier\n        // Note: we can't validate that the table exists at this point\n      }\n\n      // If contentRowid is specified, content must also be specified\n      if (node.options.contentRowid && !node.options.content) {\n        throw new Error('FTS5 content_rowid requires content option to be specified');\n      }\n    }\n  }\n}\n"]}
@@ -1,14 +1,29 @@
1
1
  import { AliasableExpression } from "../ast/Abstractions";
2
2
  import { Alias } from "../ast/Alias";
3
+ import { AlterTableQuery } from "../ast/AlterTableQuery";
4
+ import { BetweenExpression } from "../ast/BetweenExpression";
3
5
  import { BinaryExpression } from "../ast/BinaryExpression";
4
6
  import { CaseExpression } from "../ast/CaseExpression";
7
+ import { CastExpression } from "../ast/CastExpression";
8
+ import { CollateExpression } from "../ast/CollateExpression";
9
+ import { SubqueryExpression } from "../ast/SubqueryExpression";
10
+ import { WindowExpression } from "../ast/WindowExpression";
5
11
  import { Column } from "../ast/Column";
6
12
  import { Concat } from "../ast/Concat";
13
+ import { CreateIndexQuery } from "../ast/CreateIndexQuery";
14
+ import { CreateTableQuery } from "../ast/CreateTableQuery";
15
+ import { CreateVirtualTableQuery } from "../ast/CreateVirtualTableQuery";
16
+ import { CreateViewQuery } from "../ast/CreateViewQuery";
17
+ import { DeleteQuery } from "../ast/DeleteQuery";
18
+ import { DropIndexQuery } from "../ast/DropIndexQuery";
19
+ import { DropTableQuery } from "../ast/DropTableQuery";
20
+ import { DropViewQuery } from "../ast/DropViewQuery";
7
21
  import { ExistsExpression } from "../ast/ExistsExpression";
8
22
  import { From, JsonEachFrom, SubqueryFrom, TableFrom } from "../ast/From";
9
23
  import { FunctionExpression } from "../ast/FunctionExpression";
10
24
  import { InExpression } from "../ast/InExpression";
11
25
  import { InsertQuery } from "../ast/InsertQuery";
26
+ import { UpdateQuery } from "../ast/UpdateQuery";
12
27
  import { Join } from "../ast/Join";
13
28
  import { NullLiteral, NumberLiteral, Param, StringLiteral } from "../ast/Literals";
14
29
  import { OrderBy } from "../ast/OrderBy";
@@ -23,6 +38,16 @@ export declare class ParamCollectingVisitor implements SqlTreeNodeVisitor<any[]>
23
38
  private readonly params;
24
39
  constructor(keyValuePairs: Record<string, any>);
25
40
  visitInsertQuery(node: InsertQuery): any[];
41
+ visitDeleteQuery(node: DeleteQuery): any[];
42
+ visitUpdateQuery(node: UpdateQuery): any[];
43
+ visitDropTableQuery(_node: DropTableQuery): any[];
44
+ visitDropIndexQuery(_node: DropIndexQuery): any[];
45
+ visitDropViewQuery(_node: DropViewQuery): any[];
46
+ visitCreateViewQuery(node: CreateViewQuery): any[];
47
+ visitCreateIndexQuery(node: CreateIndexQuery): any[];
48
+ visitAlterTableQuery(node: AlterTableQuery): any[];
49
+ visitCreateTableQuery(node: CreateTableQuery): any[];
50
+ visitCreateVirtualTableQuery(_node: CreateVirtualTableQuery): any[];
26
51
  visitSelectQuery(node: SelectQuery): any[];
27
52
  visitTableFrom(_node: TableFrom): any[];
28
53
  visitSubqueryFrom(node: SubqueryFrom): any[];
@@ -33,6 +58,7 @@ export declare class ParamCollectingVisitor implements SqlTreeNodeVisitor<any[]>
33
58
  visitOrderBy(node: OrderBy): any[];
34
59
  visitWithClause(node: With): any[];
35
60
  visitBinaryExpression(node: BinaryExpression): any[];
61
+ visitBetweenExpression(node: BetweenExpression): any[];
36
62
  visitUnaryExpression(node: UnaryExpression): any[];
37
63
  visitInExpression(node: InExpression): any[];
38
64
  visitConcat(node: Concat): any[];
@@ -43,4 +69,8 @@ export declare class ParamCollectingVisitor implements SqlTreeNodeVisitor<any[]>
43
69
  visitNumberLiteral(_node: NumberLiteral): any[];
44
70
  visitNullLiteral(_node: NullLiteral): any[];
45
71
  visitExistsExpression(node: ExistsExpression): any[];
72
+ visitCastExpression(node: CastExpression): any[];
73
+ visitCollateExpression(node: CollateExpression): any[];
74
+ visitSubqueryExpression(node: SubqueryExpression): any[];
75
+ visitWindowExpression(node: WindowExpression): any[];
46
76
  }
@@ -11,7 +11,85 @@ class ParamCollectingVisitor {
11
11
  this.keyValuePairs = keyValuePairs;
12
12
  }
13
13
  visitInsertQuery(node) {
14
- node['_values'].forEach(v => v.accept(this));
14
+ if (node['_fromSelect']) {
15
+ node['_fromSelect'].accept(this);
16
+ }
17
+ else {
18
+ node['_values'].forEach(v => v.accept(this));
19
+ }
20
+ // Collect params from ON CONFLICT clause
21
+ node['_doUpdateSets'].forEach(s => s.value.accept(this));
22
+ if (node['_onConflictWhere']) {
23
+ node['_onConflictWhere'].accept(this);
24
+ }
25
+ node['_returning'].forEach(r => r.accept(this));
26
+ return this.params;
27
+ }
28
+ visitDeleteQuery(node) {
29
+ if (node['_where']) {
30
+ node['_where'].accept(this);
31
+ }
32
+ node['_returning'].forEach(r => r.accept(this));
33
+ return this.params;
34
+ }
35
+ visitUpdateQuery(node) {
36
+ node['_set'].forEach(s => s.value.accept(this));
37
+ if (node['_where']) {
38
+ node['_where'].accept(this);
39
+ }
40
+ node['_returning'].forEach(r => r.accept(this));
41
+ return this.params;
42
+ }
43
+ visitDropTableQuery(_node) {
44
+ // DROP TABLE has no parameters
45
+ return this.params;
46
+ }
47
+ visitDropIndexQuery(_node) {
48
+ // DROP INDEX has no parameters
49
+ return this.params;
50
+ }
51
+ visitDropViewQuery(_node) {
52
+ // DROP VIEW has no parameters
53
+ return this.params;
54
+ }
55
+ visitCreateViewQuery(node) {
56
+ // Collect params from the SELECT query
57
+ if (node.selectQuery) {
58
+ node.selectQuery.accept(this);
59
+ }
60
+ return this.params;
61
+ }
62
+ visitCreateIndexQuery(node) {
63
+ // Collect params from WHERE expression
64
+ if (node.whereExpression) {
65
+ node.whereExpression.accept(this);
66
+ }
67
+ return this.params;
68
+ }
69
+ visitAlterTableQuery(node) {
70
+ // Collect params from ADD COLUMN CHECK constraint
71
+ const op = node.operation;
72
+ if (op && op.type === 'ADD_COLUMN' && op.column.constraints.check) {
73
+ op.column.constraints.check.accept(this);
74
+ }
75
+ return this.params;
76
+ }
77
+ visitCreateTableQuery(node) {
78
+ // Collect params from CHECK constraints
79
+ for (const col of node.columns) {
80
+ if (col.constraints.check) {
81
+ col.constraints.check.accept(this);
82
+ }
83
+ }
84
+ for (const constraint of node.tableConstraints) {
85
+ if (constraint.check) {
86
+ constraint.check.accept(this);
87
+ }
88
+ }
89
+ return this.params;
90
+ }
91
+ visitCreateVirtualTableQuery(_node) {
92
+ // CREATE VIRTUAL TABLE has no parameters
15
93
  return this.params;
16
94
  }
17
95
  visitSelectQuery(node) {
@@ -26,6 +104,8 @@ class ParamCollectingVisitor {
26
104
  node['_having'].accept(this);
27
105
  }
28
106
  node['_union'].forEach(u => u.accept(this));
107
+ node['_intersect'].forEach(i => i.accept(this));
108
+ node['_except'].forEach(e => e.accept(this));
29
109
  node['_orderBy'].forEach(o => o.accept(this));
30
110
  return this.params;
31
111
  }
@@ -67,6 +147,12 @@ class ParamCollectingVisitor {
67
147
  node.right.accept(this);
68
148
  return this.params;
69
149
  }
150
+ visitBetweenExpression(node) {
151
+ node.operand.accept(this);
152
+ node.low.accept(this);
153
+ node.high.accept(this);
154
+ return this.params;
155
+ }
70
156
  visitUnaryExpression(node) {
71
157
  node.operand.accept(this);
72
158
  return this.params;
@@ -124,6 +210,27 @@ class ParamCollectingVisitor {
124
210
  node.subquery.accept(this);
125
211
  return this.params;
126
212
  }
213
+ visitCastExpression(node) {
214
+ node.expression.accept(this);
215
+ return this.params;
216
+ }
217
+ visitCollateExpression(node) {
218
+ node.expression.accept(this);
219
+ return this.params;
220
+ }
221
+ visitSubqueryExpression(node) {
222
+ node.subquery.accept(this);
223
+ return this.params;
224
+ }
225
+ visitWindowExpression(node) {
226
+ // Collect params from the underlying function
227
+ node.function.accept(this);
228
+ // Collect params from partition by columns
229
+ node.windowSpec.partitionByColumns.forEach(c => c.accept(this));
230
+ // Collect params from order by clauses
231
+ node.windowSpec.orderByColumns.forEach(o => o.accept(this));
232
+ return this.params;
233
+ }
127
234
  }
128
235
  exports.ParamCollectingVisitor = ParamCollectingVisitor;
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ParamCollector.js","sourceRoot":"","sources":["../../src/visitor/ParamCollector.ts"],"names":[],"mappings":"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","sourcesContent":["import { AliasableExpression } from \"../ast/Abstractions\";\nimport { Alias } from \"../ast/Alias\";\nimport { BinaryExpression } from \"../ast/BinaryExpression\";\nimport { CaseExpression } from \"../ast/CaseExpression\";\nimport { Column } from \"../ast/Column\";\nimport { Concat } from \"../ast/Concat\";\nimport { ExistsExpression } from \"../ast/ExistsExpression\";\nimport { From, JsonEachFrom, SubqueryFrom, TableFrom } from \"../ast/From\";\nimport { FunctionExpression } from \"../ast/FunctionExpression\";\nimport { InExpression } from \"../ast/InExpression\";\nimport { InsertQuery } from \"../ast/InsertQuery\";\nimport { Join } from \"../ast/Join\";\nimport { NullLiteral, NumberLiteral, Param, StringLiteral } from \"../ast/Literals\";\nimport { OrderBy } from \"../ast/OrderBy\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { UnaryExpression } from \"../ast/UnaryExpression\";\nimport { With } from \"../ast/With\";\nimport { ColumnLikeVisitorAcceptor, FromLikeAndJoinVisitorAcceptor, SqlTreeNodeVisitor } from \"./SqlTreeNodeVisitor\";\n\nexport class ParamCollectingVisitor implements SqlTreeNodeVisitor<any[]> {\n\n  protected fromLikeAndJoinAcceptor = new FromLikeAndJoinVisitorAcceptor<any[]>();\n  protected columnLikeAcceptor = new ColumnLikeVisitorAcceptor<any[]>();\n\n  private readonly keyValuePairs: Record<string, any>;\n  private readonly params: any[] = [];\n\n  constructor(keyValuePairs: Record<string, any>) {\n    this.keyValuePairs = keyValuePairs;\n  }\n\n  visitInsertQuery(node: InsertQuery): any[] {\n    node['_values'].forEach(v => v.accept(this));\n    return this.params;\n  }\n\n  visitSelectQuery(node: SelectQuery): any[] {\n    node['_with'].forEach(w => w.accept(this));\n    node['_fromsAndJoins'].forEach(item => this.fromLikeAndJoinAcceptor.accept(this, item));\n    node['_columns'].forEach(c => this.columnLikeAcceptor.accept(this, c));\n    if (node['_where']) {\n      node['_where'].accept(this);\n    }\n    node['_groupBy'].forEach(c => c.accept(this));\n    if (node['_having']) {\n      node['_having'].accept(this);\n    }\n    node['_union'].forEach(u => u.accept(this));\n    node['_orderBy'].forEach(o => o.accept(this));\n    return this.params;\n  }\n\n  visitTableFrom(_node: TableFrom): any[] {\n    return this.params;\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): any[] {\n    node.subquery.accept(this);\n    return this.params;\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): any[] {\n    node.jsonExpression.accept(this);\n    if (node.jsonPath) {\n      node.jsonPath.accept(this);\n    }\n    return this.params;\n  }\n\n  visitColumn(_node: Column): any[] {\n    return this.params;\n  }\n\n  visitAlias(node: Alias<From|AliasableExpression>): any[] {\n    node.referent.accept(this);\n    return this.params;\n  }\n\n  visitJoinClause(node: Join): any[] {\n    node.on.accept(this);\n    return this.params;\n  }\n\n  visitOrderBy(node: OrderBy): any[] {\n    node.column.accept(this);\n    return this.params;\n  }\n\n  visitWithClause(node: With): any[] {\n    node.query.accept(this);\n    return this.params;\n  }\n\n  visitBinaryExpression(node: BinaryExpression): any[] {\n    node.left.accept(this);\n    node.right.accept(this);\n    return this.params;\n  }\n\n  visitUnaryExpression(node: UnaryExpression): any[] {\n    node.operand.accept(this);\n    return this.params;\n  }\n\n  visitInExpression(node: InExpression): any[] {\n    node.left.forEach(l => l.accept(this));\n    if (node.values instanceof SelectQuery) {\n      node.values.accept(this);\n    } else {\n      node.values.forEach(set => set.forEach(v => v.accept(this)));\n    }\n    return this.params;\n  }\n\n  visitConcat(node: Concat): any[] {\n    node.expressions.forEach(e => e.accept(this));\n    return this.params;\n  }\n\n  visitCaseExpression(node: CaseExpression): any[] {\n    node.cases.forEach(c => {\n      c.when.accept(this);\n      c.then.accept(this);\n    });\n    if (node.else) {\n      node.else.accept(this);\n    }\n    return this.params;\n  }\n\n  visitFunctionExpression(node: FunctionExpression): any[] {\n    node.args.forEach(a => a.accept(this));\n    return this.params;\n  }\n\n  visitParamExpression(node: Param): any[] {\n    if (node.paramName) {\n      if (!this.keyValuePairs || typeof this.keyValuePairs !== 'object' || !(node.paramName in this.keyValuePairs)) {\n        throw new Error(`No value provided for parameter: ${node.paramName}`);\n      }\n      this.params.push(this.keyValuePairs[node.paramName]);\n    } else {\n      this.params.push(undefined);\n    }\n    return this.params;\n  }\n\n  visitStringLiteral(_node: StringLiteral): any[] {\n    return this.params;\n  }\n\n  visitNumberLiteral(_node: NumberLiteral): any[] {\n    return this.params;\n  }\n\n  visitNullLiteral(_node: NullLiteral): any[] {\n    return this.params;\n  }\n\n  visitExistsExpression(node: ExistsExpression): any[] {\n    node.subquery.accept(this);\n    return this.params;\n  }\n}\n"]}
236
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ParamCollector.js","sourceRoot":"","sources":["../../src/visitor/ParamCollector.ts"],"names":[],"mappings":"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","sourcesContent":["import { AliasableExpression } from \"../ast/Abstractions\";\nimport { Alias } from \"../ast/Alias\";\nimport { AlterTableQuery } from \"../ast/AlterTableQuery\";\nimport { BetweenExpression } from \"../ast/BetweenExpression\";\nimport { BinaryExpression } from \"../ast/BinaryExpression\";\nimport { CaseExpression } from \"../ast/CaseExpression\";\nimport { CastExpression } from \"../ast/CastExpression\";\nimport { CollateExpression } from \"../ast/CollateExpression\";\nimport { SubqueryExpression } from \"../ast/SubqueryExpression\";\nimport { WindowExpression } from \"../ast/WindowExpression\";\nimport { Column } from \"../ast/Column\";\nimport { Concat } from \"../ast/Concat\";\nimport { CreateIndexQuery } from \"../ast/CreateIndexQuery\";\nimport { CreateTableQuery } from \"../ast/CreateTableQuery\";\nimport { CreateVirtualTableQuery } from \"../ast/CreateVirtualTableQuery\";\nimport { CreateViewQuery } from \"../ast/CreateViewQuery\";\nimport { DeleteQuery } from \"../ast/DeleteQuery\";\nimport { DropIndexQuery } from \"../ast/DropIndexQuery\";\nimport { DropTableQuery } from \"../ast/DropTableQuery\";\nimport { DropViewQuery } from \"../ast/DropViewQuery\";\nimport { ExistsExpression } from \"../ast/ExistsExpression\";\nimport { From, JsonEachFrom, SubqueryFrom, TableFrom } from \"../ast/From\";\nimport { FunctionExpression } from \"../ast/FunctionExpression\";\nimport { InExpression } from \"../ast/InExpression\";\nimport { InsertQuery } from \"../ast/InsertQuery\";\nimport { UpdateQuery } from \"../ast/UpdateQuery\";\nimport { Join } from \"../ast/Join\";\nimport { NullLiteral, NumberLiteral, Param, StringLiteral } from \"../ast/Literals\";\nimport { OrderBy } from \"../ast/OrderBy\";\nimport { SelectQuery } from \"../ast/SelectQuery\";\nimport { UnaryExpression } from \"../ast/UnaryExpression\";\nimport { With } from \"../ast/With\";\nimport { ColumnLikeVisitorAcceptor, FromLikeAndJoinVisitorAcceptor, SqlTreeNodeVisitor } from \"./SqlTreeNodeVisitor\";\n\nexport class ParamCollectingVisitor implements SqlTreeNodeVisitor<any[]> {\n\n  protected fromLikeAndJoinAcceptor = new FromLikeAndJoinVisitorAcceptor<any[]>();\n  protected columnLikeAcceptor = new ColumnLikeVisitorAcceptor<any[]>();\n\n  private readonly keyValuePairs: Record<string, any>;\n  private readonly params: any[] = [];\n\n  constructor(keyValuePairs: Record<string, any>) {\n    this.keyValuePairs = keyValuePairs;\n  }\n\n  visitInsertQuery(node: InsertQuery): any[] {\n    if (node['_fromSelect']) {\n      node['_fromSelect'].accept(this);\n    } else {\n      node['_values'].forEach(v => v.accept(this));\n    }\n    // Collect params from ON CONFLICT clause\n    node['_doUpdateSets'].forEach(s => s.value.accept(this));\n    if (node['_onConflictWhere']) {\n      node['_onConflictWhere'].accept(this);\n    }\n    node['_returning'].forEach(r => r.accept(this));\n    return this.params;\n  }\n\n  visitDeleteQuery(node: DeleteQuery): any[] {\n    if (node['_where']) {\n      node['_where'].accept(this);\n    }\n    node['_returning'].forEach(r => r.accept(this));\n    return this.params;\n  }\n\n  visitUpdateQuery(node: UpdateQuery): any[] {\n    node['_set'].forEach(s => s.value.accept(this));\n    if (node['_where']) {\n      node['_where'].accept(this);\n    }\n    node['_returning'].forEach(r => r.accept(this));\n    return this.params;\n  }\n\n  visitDropTableQuery(_node: DropTableQuery): any[] {\n    // DROP TABLE has no parameters\n    return this.params;\n  }\n\n  visitDropIndexQuery(_node: DropIndexQuery): any[] {\n    // DROP INDEX has no parameters\n    return this.params;\n  }\n\n  visitDropViewQuery(_node: DropViewQuery): any[] {\n    // DROP VIEW has no parameters\n    return this.params;\n  }\n\n  visitCreateViewQuery(node: CreateViewQuery): any[] {\n    // Collect params from the SELECT query\n    if (node.selectQuery) {\n      node.selectQuery.accept(this);\n    }\n    return this.params;\n  }\n\n  visitCreateIndexQuery(node: CreateIndexQuery): any[] {\n    // Collect params from WHERE expression\n    if (node.whereExpression) {\n      node.whereExpression.accept(this);\n    }\n    return this.params;\n  }\n\n  visitAlterTableQuery(node: AlterTableQuery): any[] {\n    // Collect params from ADD COLUMN CHECK constraint\n    const op = node.operation;\n    if (op && op.type === 'ADD_COLUMN' && op.column.constraints.check) {\n      op.column.constraints.check.accept(this);\n    }\n    return this.params;\n  }\n\n  visitCreateTableQuery(node: CreateTableQuery): any[] {\n    // Collect params from CHECK constraints\n    for (const col of node.columns) {\n      if (col.constraints.check) {\n        col.constraints.check.accept(this);\n      }\n    }\n    for (const constraint of node.tableConstraints) {\n      if (constraint.check) {\n        constraint.check.accept(this);\n      }\n    }\n    return this.params;\n  }\n\n  visitCreateVirtualTableQuery(_node: CreateVirtualTableQuery): any[] {\n    // CREATE VIRTUAL TABLE has no parameters\n    return this.params;\n  }\n\n  visitSelectQuery(node: SelectQuery): any[] {\n    node['_with'].forEach(w => w.accept(this));\n    node['_fromsAndJoins'].forEach(item => this.fromLikeAndJoinAcceptor.accept(this, item));\n    node['_columns'].forEach(c => this.columnLikeAcceptor.accept(this, c));\n    if (node['_where']) {\n      node['_where'].accept(this);\n    }\n    node['_groupBy'].forEach(c => c.accept(this));\n    if (node['_having']) {\n      node['_having'].accept(this);\n    }\n    node['_union'].forEach(u => u.accept(this));\n    node['_intersect'].forEach(i => i.accept(this));\n    node['_except'].forEach(e => e.accept(this));\n    node['_orderBy'].forEach(o => o.accept(this));\n    return this.params;\n  }\n\n  visitTableFrom(_node: TableFrom): any[] {\n    return this.params;\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): any[] {\n    node.subquery.accept(this);\n    return this.params;\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): any[] {\n    node.jsonExpression.accept(this);\n    if (node.jsonPath) {\n      node.jsonPath.accept(this);\n    }\n    return this.params;\n  }\n\n  visitColumn(_node: Column): any[] {\n    return this.params;\n  }\n\n  visitAlias(node: Alias<From|AliasableExpression>): any[] {\n    node.referent.accept(this);\n    return this.params;\n  }\n\n  visitJoinClause(node: Join): any[] {\n    node.on.accept(this);\n    return this.params;\n  }\n\n  visitOrderBy(node: OrderBy): any[] {\n    node.column.accept(this);\n    return this.params;\n  }\n\n  visitWithClause(node: With): any[] {\n    node.query.accept(this);\n    return this.params;\n  }\n\n  visitBinaryExpression(node: BinaryExpression): any[] {\n    node.left.accept(this);\n    node.right.accept(this);\n    return this.params;\n  }\n\n  visitBetweenExpression(node: BetweenExpression): any[] {\n    node.operand.accept(this);\n    node.low.accept(this);\n    node.high.accept(this);\n    return this.params;\n  }\n\n  visitUnaryExpression(node: UnaryExpression): any[] {\n    node.operand.accept(this);\n    return this.params;\n  }\n\n  visitInExpression(node: InExpression): any[] {\n    node.left.forEach(l => l.accept(this));\n    if (node.values instanceof SelectQuery) {\n      node.values.accept(this);\n    } else {\n      node.values.forEach(set => set.forEach(v => v.accept(this)));\n    }\n    return this.params;\n  }\n\n  visitConcat(node: Concat): any[] {\n    node.expressions.forEach(e => e.accept(this));\n    return this.params;\n  }\n\n  visitCaseExpression(node: CaseExpression): any[] {\n    node.cases.forEach(c => {\n      c.when.accept(this);\n      c.then.accept(this);\n    });\n    if (node.else) {\n      node.else.accept(this);\n    }\n    return this.params;\n  }\n\n  visitFunctionExpression(node: FunctionExpression): any[] {\n    node.args.forEach(a => a.accept(this));\n    return this.params;\n  }\n\n  visitParamExpression(node: Param): any[] {\n    if (node.paramName) {\n      if (!this.keyValuePairs || typeof this.keyValuePairs !== 'object' || !(node.paramName in this.keyValuePairs)) {\n        throw new Error(`No value provided for parameter: ${node.paramName}`);\n      }\n      this.params.push(this.keyValuePairs[node.paramName]);\n    } else {\n      this.params.push(undefined);\n    }\n    return this.params;\n  }\n\n  visitStringLiteral(_node: StringLiteral): any[] {\n    return this.params;\n  }\n\n  visitNumberLiteral(_node: NumberLiteral): any[] {\n    return this.params;\n  }\n\n  visitNullLiteral(_node: NullLiteral): any[] {\n    return this.params;\n  }\n\n  visitExistsExpression(node: ExistsExpression): any[] {\n    node.subquery.accept(this);\n    return this.params;\n  }\n\n  visitCastExpression(node: CastExpression): any[] {\n    node.expression.accept(this);\n    return this.params;\n  }\n\n  visitCollateExpression(node: CollateExpression): any[] {\n    node.expression.accept(this);\n    return this.params;\n  }\n\n  visitSubqueryExpression(node: SubqueryExpression): any[] {\n    node.subquery.accept(this);\n    return this.params;\n  }\n\n  visitWindowExpression(node: WindowExpression): any[] {\n    // Collect params from the underlying function\n    node.function.accept(this);\n    // Collect params from partition by columns\n    node.windowSpec.partitionByColumns.forEach(c => c.accept(this));\n    // Collect params from order by clauses\n    node.windowSpec.orderByColumns.forEach(o => o.accept(this));\n    return this.params;\n  }\n}\n"]}
@@ -1,14 +1,29 @@
1
1
  import { Aliasable, SqlTreeNode } from "../ast/Abstractions";
2
2
  import { Alias } from "../ast/Alias";
3
+ import { AlterTableQuery } from "../ast/AlterTableQuery";
4
+ import { BetweenExpression } from "../ast/BetweenExpression";
3
5
  import { BinaryExpression } from "../ast/BinaryExpression";
4
6
  import { CaseExpression } from "../ast/CaseExpression";
7
+ import { CastExpression } from "../ast/CastExpression";
8
+ import { CollateExpression } from "../ast/CollateExpression";
9
+ import { SubqueryExpression } from "../ast/SubqueryExpression";
10
+ import { WindowExpression } from "../ast/WindowExpression";
5
11
  import { Column } from "../ast/Column";
6
12
  import { Concat } from "../ast/Concat";
13
+ import { CreateIndexQuery } from "../ast/CreateIndexQuery";
14
+ import { CreateTableQuery } from "../ast/CreateTableQuery";
15
+ import { CreateVirtualTableQuery } from "../ast/CreateVirtualTableQuery";
16
+ import { CreateViewQuery } from "../ast/CreateViewQuery";
17
+ import { DeleteQuery } from "../ast/DeleteQuery";
18
+ import { DropIndexQuery } from "../ast/DropIndexQuery";
19
+ import { DropTableQuery } from "../ast/DropTableQuery";
20
+ import { DropViewQuery } from "../ast/DropViewQuery";
7
21
  import { ExistsExpression } from "../ast/ExistsExpression";
8
22
  import { JsonEachFrom, SubqueryFrom, TableFrom } from "../ast/From";
9
23
  import { FunctionExpression } from "../ast/FunctionExpression";
10
24
  import { InExpression } from "../ast/InExpression";
11
25
  import { InsertQuery } from "../ast/InsertQuery";
26
+ import { UpdateQuery } from "../ast/UpdateQuery";
12
27
  import { Join } from "../ast/Join";
13
28
  import { NullLiteral, NumberLiteral, Param, StringLiteral } from "../ast/Literals";
14
29
  import { OrderBy } from "../ast/OrderBy";
@@ -23,6 +38,16 @@ export declare class QueryIdentityTransformer implements SqlTreeNodeTransformer
23
38
  protected flatList2D(results: (SqlTreeNode | SqlTreeNode[])[][]): SqlTreeNode[][];
24
39
  visitSelectQuery(node: SelectQuery): SqlTreeNode | SqlTreeNode[];
25
40
  visitInsertQuery(node: InsertQuery): SqlTreeNode | SqlTreeNode[];
41
+ visitDeleteQuery(node: DeleteQuery): SqlTreeNode | SqlTreeNode[];
42
+ visitUpdateQuery(node: UpdateQuery): SqlTreeNode | SqlTreeNode[];
43
+ visitDropTableQuery(node: DropTableQuery): SqlTreeNode | SqlTreeNode[];
44
+ visitDropIndexQuery(node: DropIndexQuery): SqlTreeNode | SqlTreeNode[];
45
+ visitDropViewQuery(node: DropViewQuery): SqlTreeNode | SqlTreeNode[];
46
+ visitCreateViewQuery(node: CreateViewQuery): SqlTreeNode | SqlTreeNode[];
47
+ visitCreateIndexQuery(node: CreateIndexQuery): SqlTreeNode | SqlTreeNode[];
48
+ visitAlterTableQuery(node: AlterTableQuery): SqlTreeNode | SqlTreeNode[];
49
+ visitCreateTableQuery(node: CreateTableQuery): SqlTreeNode | SqlTreeNode[];
50
+ visitCreateVirtualTableQuery(node: CreateVirtualTableQuery): SqlTreeNode | SqlTreeNode[];
26
51
  visitTableFrom(node: TableFrom): SqlTreeNode | SqlTreeNode[];
27
52
  visitSubqueryFrom(node: SubqueryFrom): SqlTreeNode | SqlTreeNode[];
28
53
  visitJsonEachFrom(node: JsonEachFrom): SqlTreeNode | SqlTreeNode[];
@@ -32,6 +57,7 @@ export declare class QueryIdentityTransformer implements SqlTreeNodeTransformer
32
57
  visitOrderBy(node: OrderBy): SqlTreeNode | SqlTreeNode[];
33
58
  visitWithClause(node: With): SqlTreeNode | SqlTreeNode[];
34
59
  visitBinaryExpression(node: BinaryExpression): SqlTreeNode | SqlTreeNode[];
60
+ visitBetweenExpression(node: BetweenExpression): SqlTreeNode | SqlTreeNode[];
35
61
  visitUnaryExpression(node: UnaryExpression): SqlTreeNode | SqlTreeNode[];
36
62
  visitInExpression(node: InExpression): SqlTreeNode | SqlTreeNode[];
37
63
  visitConcat(node: Concat): SqlTreeNode | SqlTreeNode[];
@@ -42,4 +68,8 @@ export declare class QueryIdentityTransformer implements SqlTreeNodeTransformer
42
68
  visitNumberLiteral(node: NumberLiteral): SqlTreeNode | SqlTreeNode[];
43
69
  visitNullLiteral(node: NullLiteral): SqlTreeNode | SqlTreeNode[];
44
70
  visitExistsExpression(node: ExistsExpression): SqlTreeNode | SqlTreeNode[];
71
+ visitCastExpression(node: CastExpression): SqlTreeNode | SqlTreeNode[];
72
+ visitCollateExpression(node: CollateExpression): SqlTreeNode | SqlTreeNode[];
73
+ visitSubqueryExpression(node: SubqueryExpression): SqlTreeNode | SqlTreeNode[];
74
+ visitWindowExpression(node: WindowExpression): SqlTreeNode | SqlTreeNode[];
45
75
  }