@shaxpir/squilt 1.0.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/LICENSE +201 -0
- package/README.md +133 -0
- package/dist/ast/Abstractions.d.ts +14 -0
- package/dist/ast/Abstractions.js +11 -0
- package/dist/ast/Alias.d.ts +11 -0
- package/dist/ast/Alias.js +23 -0
- package/dist/ast/BinaryExpression.d.ts +13 -0
- package/dist/ast/BinaryExpression.js +26 -0
- package/dist/ast/CaseExpression.d.ts +14 -0
- package/dist/ast/CaseExpression.js +22 -0
- package/dist/ast/Column.d.ts +17 -0
- package/dist/ast/Column.js +38 -0
- package/dist/ast/Concat.d.ts +8 -0
- package/dist/ast/Concat.js +19 -0
- package/dist/ast/ExistsExpression.d.ts +9 -0
- package/dist/ast/ExistsExpression.js +18 -0
- package/dist/ast/From.d.ts +33 -0
- package/dist/ast/From.js +60 -0
- package/dist/ast/FunctionExpression.d.ts +13 -0
- package/dist/ast/FunctionExpression.js +27 -0
- package/dist/ast/FunctionName.d.ts +1 -0
- package/dist/ast/FunctionName.js +3 -0
- package/dist/ast/InExpression.d.ts +13 -0
- package/dist/ast/InExpression.js +35 -0
- package/dist/ast/InsertQuery.d.ts +17 -0
- package/dist/ast/InsertQuery.js +42 -0
- package/dist/ast/Join.d.ts +21 -0
- package/dist/ast/Join.js +37 -0
- package/dist/ast/Literals.d.ts +31 -0
- package/dist/ast/Literals.js +65 -0
- package/dist/ast/Operator.d.ts +18 -0
- package/dist/ast/Operator.js +23 -0
- package/dist/ast/OrderBy.d.ts +14 -0
- package/dist/ast/OrderBy.js +25 -0
- package/dist/ast/SelectQuery.d.ts +39 -0
- package/dist/ast/SelectQuery.js +109 -0
- package/dist/ast/UnaryExpression.d.ts +11 -0
- package/dist/ast/UnaryExpression.js +22 -0
- package/dist/ast/With.d.ts +11 -0
- package/dist/ast/With.js +21 -0
- package/dist/builder/QueryBuilder.d.ts +8 -0
- package/dist/builder/QueryBuilder.js +20 -0
- package/dist/builder/Shorthand.d.ts +77 -0
- package/dist/builder/Shorthand.js +375 -0
- package/dist/index.d.ts +32 -0
- package/dist/index.js +133 -0
- package/dist/renderer/CompactQueryRenderer.d.ts +45 -0
- package/dist/renderer/CompactQueryRenderer.js +192 -0
- package/dist/renderer/IndentedQueryRenderer.d.ts +51 -0
- package/dist/renderer/IndentedQueryRenderer.js +230 -0
- package/dist/renderer/QueryRenderer.d.ts +8 -0
- package/dist/renderer/QueryRenderer.js +77 -0
- package/dist/validate/CommonQueryValidator.d.ts +50 -0
- package/dist/validate/CommonQueryValidator.js +262 -0
- package/dist/validate/QueryValidator.d.ts +6 -0
- package/dist/validate/QueryValidator.js +3 -0
- package/dist/validate/SQLiteQueryValidator.d.ts +27 -0
- package/dist/validate/SQLiteQueryValidator.js +96 -0
- package/dist/visitor/ParamCollector.d.ts +46 -0
- package/dist/visitor/ParamCollector.js +129 -0
- package/dist/visitor/QueryIdentityTransformer.d.ts +45 -0
- package/dist/visitor/QueryIdentityTransformer.js +173 -0
- package/dist/visitor/QueryParamRewriteTransformer.d.ts +11 -0
- package/dist/visitor/QueryParamRewriteTransformer.js +26 -0
- package/dist/visitor/SqlTreeNodeTransformer.d.ts +5 -0
- package/dist/visitor/SqlTreeNodeTransformer.js +3 -0
- package/dist/visitor/SqlTreeNodeVisitor.d.ts +45 -0
- package/dist/visitor/SqlTreeNodeVisitor.js +47 -0
- package/package.json +36 -0
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { AliasableExpression } from "../ast/Abstractions";
|
|
2
|
+
import { Alias } from "../ast/Alias";
|
|
3
|
+
import { BinaryExpression } from "../ast/BinaryExpression";
|
|
4
|
+
import { CaseExpression } from "../ast/CaseExpression";
|
|
5
|
+
import { Column } from "../ast/Column";
|
|
6
|
+
import { Concat } from "../ast/Concat";
|
|
7
|
+
import { ExistsExpression } from "../ast/ExistsExpression";
|
|
8
|
+
import { From, JsonEachFrom, SubqueryFrom, TableFrom } from "../ast/From";
|
|
9
|
+
import { FunctionExpression } from "../ast/FunctionExpression";
|
|
10
|
+
import { InExpression } from "../ast/InExpression";
|
|
11
|
+
import { InsertQuery } from "../ast/InsertQuery";
|
|
12
|
+
import { Join } from "../ast/Join";
|
|
13
|
+
import { NullLiteral, NumberLiteral, Param, StringLiteral } from "../ast/Literals";
|
|
14
|
+
import { OrderBy } from "../ast/OrderBy";
|
|
15
|
+
import { SelectQuery } from "../ast/SelectQuery";
|
|
16
|
+
import { UnaryExpression } from "../ast/UnaryExpression";
|
|
17
|
+
import { With } from "../ast/With";
|
|
18
|
+
import { ColumnLikeVisitorAcceptor, FromLikeAndJoinVisitorAcceptor, SqlTreeNodeVisitor } from "../visitor/SqlTreeNodeVisitor";
|
|
19
|
+
import { QueryRenderer } from "./QueryRenderer";
|
|
20
|
+
export declare class CompactQueryRenderer implements QueryRenderer, SqlTreeNodeVisitor<string> {
|
|
21
|
+
protected fromLikeAndJoinAcceptor: FromLikeAndJoinVisitorAcceptor<void>;
|
|
22
|
+
protected columnLikeAcceptor: ColumnLikeVisitorAcceptor<string>;
|
|
23
|
+
render(node: SelectQuery | InsertQuery): string;
|
|
24
|
+
visitInsertQuery(node: InsertQuery): string;
|
|
25
|
+
visitSelectQuery(node: SelectQuery): string;
|
|
26
|
+
visitTableFrom(node: TableFrom): string;
|
|
27
|
+
visitSubqueryFrom(node: SubqueryFrom): string;
|
|
28
|
+
visitJsonEachFrom(node: JsonEachFrom): string;
|
|
29
|
+
visitColumn(node: Column): string;
|
|
30
|
+
visitAlias(node: Alias<From | AliasableExpression>): string;
|
|
31
|
+
visitJoinClause(node: Join): string;
|
|
32
|
+
visitOrderBy(node: OrderBy): string;
|
|
33
|
+
visitWithClause(node: With): string;
|
|
34
|
+
visitBinaryExpression(node: BinaryExpression): string;
|
|
35
|
+
visitUnaryExpression(node: UnaryExpression): string;
|
|
36
|
+
visitInExpression(node: InExpression): string;
|
|
37
|
+
visitConcat(node: Concat): string;
|
|
38
|
+
visitCaseExpression(node: CaseExpression): string;
|
|
39
|
+
visitFunctionExpression(node: FunctionExpression): string;
|
|
40
|
+
visitParamExpression(_node: Param): string;
|
|
41
|
+
visitStringLiteral(node: StringLiteral): string;
|
|
42
|
+
visitNumberLiteral(node: NumberLiteral): string;
|
|
43
|
+
visitNullLiteral(_node: NullLiteral): string;
|
|
44
|
+
visitExistsExpression(node: ExistsExpression): string;
|
|
45
|
+
}
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CompactQueryRenderer = void 0;
|
|
4
|
+
const Alias_1 = require("../ast/Alias");
|
|
5
|
+
const From_1 = require("../ast/From");
|
|
6
|
+
const Join_1 = require("../ast/Join");
|
|
7
|
+
const Operator_1 = require("../ast/Operator");
|
|
8
|
+
const SelectQuery_1 = require("../ast/SelectQuery");
|
|
9
|
+
const SqlTreeNodeVisitor_1 = require("../visitor/SqlTreeNodeVisitor");
|
|
10
|
+
const QueryRenderer_1 = require("./QueryRenderer");
|
|
11
|
+
class CompactQueryRenderer {
|
|
12
|
+
constructor() {
|
|
13
|
+
this.fromLikeAndJoinAcceptor = new SqlTreeNodeVisitor_1.FromLikeAndJoinVisitorAcceptor();
|
|
14
|
+
this.columnLikeAcceptor = new SqlTreeNodeVisitor_1.ColumnLikeVisitorAcceptor();
|
|
15
|
+
}
|
|
16
|
+
render(node) {
|
|
17
|
+
return node.accept(this);
|
|
18
|
+
}
|
|
19
|
+
visitInsertQuery(node) {
|
|
20
|
+
const parts = [];
|
|
21
|
+
parts.push(`INSERT${node.isOrReplace() ? ' OR REPLACE' : ''}`);
|
|
22
|
+
parts.push(`INTO ${(0, QueryRenderer_1.quoteIdentifier)(node['_tableName'])}`);
|
|
23
|
+
if (node['_columns'].length > 0) {
|
|
24
|
+
parts.push(`(${node['_columns'].map(QueryRenderer_1.quoteIdentifier).join(', ')})`);
|
|
25
|
+
}
|
|
26
|
+
parts.push(`VALUES (${node['_values'].map(v => v.accept(this)).join(', ')})`);
|
|
27
|
+
return parts.join(' ');
|
|
28
|
+
}
|
|
29
|
+
visitSelectQuery(node) {
|
|
30
|
+
const parts = [];
|
|
31
|
+
if (node['_with'].length > 0) {
|
|
32
|
+
parts.push(`WITH ${node['_with'].map(w => w.accept(this)).join(', ')}`);
|
|
33
|
+
}
|
|
34
|
+
parts.push(`SELECT${node.isDistinct() ? ' DISTINCT' : ''}`);
|
|
35
|
+
if (node['_columns'].length > 0) {
|
|
36
|
+
parts.push(node['_columns'].map(c => this.columnLikeAcceptor.accept(this, c)).join(', '));
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
parts.push('*');
|
|
40
|
+
}
|
|
41
|
+
if (node['_fromsAndJoins'].length > 0) {
|
|
42
|
+
let fromsAndJoinsText = '';
|
|
43
|
+
for (const fromOrJoin of node['_fromsAndJoins']) {
|
|
44
|
+
if (fromOrJoin instanceof Join_1.Join) {
|
|
45
|
+
fromsAndJoinsText += ` ${fromOrJoin.accept(this)}`;
|
|
46
|
+
}
|
|
47
|
+
else if (fromOrJoin instanceof Alias_1.Alias ||
|
|
48
|
+
fromOrJoin instanceof From_1.From ||
|
|
49
|
+
fromOrJoin instanceof From_1.TableFrom ||
|
|
50
|
+
fromOrJoin instanceof From_1.SubqueryFrom ||
|
|
51
|
+
fromOrJoin instanceof From_1.JsonEachFrom) {
|
|
52
|
+
if (fromsAndJoinsText) {
|
|
53
|
+
fromsAndJoinsText += `, ${fromOrJoin.accept(this)}`;
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
fromsAndJoinsText += `FROM ${fromOrJoin.accept(this)}`;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
parts.push(fromsAndJoinsText);
|
|
61
|
+
}
|
|
62
|
+
if (node['_where']) {
|
|
63
|
+
parts.push(`WHERE ${node['_where'].accept(this)}`);
|
|
64
|
+
}
|
|
65
|
+
if (node['_groupBy'].length > 0) {
|
|
66
|
+
parts.push(`GROUP BY ${node['_groupBy'].map(c => c.accept(this)).join(', ')}`);
|
|
67
|
+
}
|
|
68
|
+
if (node['_having']) {
|
|
69
|
+
parts.push(`HAVING ${node['_having'].accept(this)}`);
|
|
70
|
+
}
|
|
71
|
+
if (node['_union'].length > 0) {
|
|
72
|
+
parts.push(node['_union'].map(u => `UNION ${u.accept(this)}`).join(' '));
|
|
73
|
+
}
|
|
74
|
+
if (node['_orderBy'].length > 0) {
|
|
75
|
+
parts.push(`ORDER BY ${node['_orderBy'].map(o => o.accept(this)).join(', ')}`);
|
|
76
|
+
}
|
|
77
|
+
if (node['_limit'] !== null && node['_limit'] !== undefined) {
|
|
78
|
+
parts.push(`LIMIT ${node['_limit']}`);
|
|
79
|
+
if (node['_offset'] !== null && node['_offset'] !== undefined) {
|
|
80
|
+
parts.push(`OFFSET ${node['_offset']}`);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
return parts.filter(p => p).join(' ');
|
|
84
|
+
}
|
|
85
|
+
visitTableFrom(node) {
|
|
86
|
+
return `${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)}`;
|
|
87
|
+
}
|
|
88
|
+
visitSubqueryFrom(node) {
|
|
89
|
+
return `(${node.subquery.accept(this)})`;
|
|
90
|
+
}
|
|
91
|
+
visitJsonEachFrom(node) {
|
|
92
|
+
const expr = node.jsonExpression.accept(this);
|
|
93
|
+
const path = node.jsonPath ? `, ${node.jsonPath.accept(this)}` : '';
|
|
94
|
+
return `json_each(${expr}${path})`;
|
|
95
|
+
}
|
|
96
|
+
visitColumn(node) {
|
|
97
|
+
if (node.hasTableName()) {
|
|
98
|
+
return `${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)}.${(0, QueryRenderer_1.quoteIdentifier)(node.columnName)}`;
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
return `${(0, QueryRenderer_1.quoteIdentifier)(node.columnName)}`;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
visitAlias(node) {
|
|
105
|
+
const isSubquery = node.referent instanceof From_1.SubqueryFrom || node.referent instanceof SelectQuery_1.SelectQuery;
|
|
106
|
+
const renderedReferent = node.referent.accept(this);
|
|
107
|
+
const renderedAliasName = (0, QueryRenderer_1.quoteIdentifier)(node.alias);
|
|
108
|
+
if (node.referent instanceof From_1.From) {
|
|
109
|
+
return `${renderedReferent} ${renderedAliasName}`;
|
|
110
|
+
}
|
|
111
|
+
else if (isSubquery) {
|
|
112
|
+
return `(${renderedReferent}) AS ${renderedAliasName}`;
|
|
113
|
+
}
|
|
114
|
+
else {
|
|
115
|
+
return `${renderedReferent} AS ${renderedAliasName}`;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
visitJoinClause(node) {
|
|
119
|
+
return `${node.type} JOIN ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} ${(0, QueryRenderer_1.quoteIdentifier)(node.alias)} ON ${node.on.accept(this)}`;
|
|
120
|
+
}
|
|
121
|
+
visitOrderBy(node) {
|
|
122
|
+
return `${node.column.accept(this)} ${node.direction}`;
|
|
123
|
+
}
|
|
124
|
+
visitWithClause(node) {
|
|
125
|
+
return `${(0, QueryRenderer_1.quoteIdentifier)(node.name)} AS (${node.query.accept(this)})`;
|
|
126
|
+
}
|
|
127
|
+
visitBinaryExpression(node) {
|
|
128
|
+
return `(${node.left.accept(this)} ${node.operator} ${node.right.accept(this)})`;
|
|
129
|
+
}
|
|
130
|
+
visitUnaryExpression(node) {
|
|
131
|
+
const operand = node.operand.accept(this);
|
|
132
|
+
if (node.operator === Operator_1.Operator.IS_NULL || node.operator === Operator_1.Operator.IS_NOT_NULL) {
|
|
133
|
+
return `(${operand} ${node.operator})`;
|
|
134
|
+
}
|
|
135
|
+
else if (node.operator === 'NOT') {
|
|
136
|
+
return `(NOT ${operand})`;
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
return `(${node.operator}${operand})`;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
visitInExpression(node) {
|
|
143
|
+
const leftStr = node.left.length > 1
|
|
144
|
+
? `(${node.left.map(l => l.accept(this)).join(', ')})`
|
|
145
|
+
: node.left[0].accept(this);
|
|
146
|
+
const not = node.not ? ' NOT' : '';
|
|
147
|
+
let right;
|
|
148
|
+
if (node.values instanceof SelectQuery_1.SelectQuery) {
|
|
149
|
+
right = `(${node.values.accept(this)})`;
|
|
150
|
+
}
|
|
151
|
+
else {
|
|
152
|
+
right = `(${node.values.map(set => set.length > 1 ? `(${set.map(v => v.accept(this)).join(', ')})` : set[0].accept(this)).join(', ')})`;
|
|
153
|
+
}
|
|
154
|
+
return `(${leftStr}${not} IN ${right})`;
|
|
155
|
+
}
|
|
156
|
+
visitConcat(node) {
|
|
157
|
+
return `(${node.expressions.map(e => e.accept(this)).join(' || ')})`;
|
|
158
|
+
}
|
|
159
|
+
visitCaseExpression(node) {
|
|
160
|
+
const parts = ['CASE'];
|
|
161
|
+
for (const c of node.cases) {
|
|
162
|
+
parts.push(`WHEN ${c.when.accept(this)} THEN ${c.then.accept(this)}`);
|
|
163
|
+
}
|
|
164
|
+
if (node.else) {
|
|
165
|
+
parts.push(`ELSE ${node.else.accept(this)}`);
|
|
166
|
+
}
|
|
167
|
+
parts.push('END');
|
|
168
|
+
return parts.join(' ');
|
|
169
|
+
}
|
|
170
|
+
visitFunctionExpression(node) {
|
|
171
|
+
const args = node.args.map(a => a.accept(this)).join(', ');
|
|
172
|
+
const distinctPrefix = node.distinct ? 'DISTINCT ' : '';
|
|
173
|
+
return `${node.name}(${distinctPrefix}${args})`;
|
|
174
|
+
}
|
|
175
|
+
visitParamExpression(_node) {
|
|
176
|
+
return '?';
|
|
177
|
+
}
|
|
178
|
+
visitStringLiteral(node) {
|
|
179
|
+
return `'${node.value.replace(/'/g, "''")}'`;
|
|
180
|
+
}
|
|
181
|
+
visitNumberLiteral(node) {
|
|
182
|
+
return node.value.toString();
|
|
183
|
+
}
|
|
184
|
+
visitNullLiteral(_node) {
|
|
185
|
+
return 'NULL';
|
|
186
|
+
}
|
|
187
|
+
visitExistsExpression(node) {
|
|
188
|
+
return `EXISTS (${node.subquery.accept(this)})`;
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
exports.CompactQueryRenderer = CompactQueryRenderer;
|
|
192
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CompactQueryRenderer.js","sourceRoot":"","sources":["../../src/renderer/CompactQueryRenderer.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 { Operator } from \"../ast/Operator\";\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 \"../visitor/SqlTreeNodeVisitor\";\nimport { QueryRenderer, quoteIdentifier } from \"./QueryRenderer\";\n\nexport class CompactQueryRenderer\n  implements QueryRenderer, SqlTreeNodeVisitor<string>\n{\n  protected fromLikeAndJoinAcceptor = new FromLikeAndJoinVisitorAcceptor<void>();\n  protected columnLikeAcceptor = new ColumnLikeVisitorAcceptor<string>();\n\n  public render(node: SelectQuery | InsertQuery): string {\n    return node.accept(this);\n  }\n\n  visitInsertQuery(node: InsertQuery): string {\n    const parts: string[] = [];\n    parts.push(`INSERT${node.isOrReplace() ? ' OR REPLACE' : ''}`);\n    parts.push(`INTO ${quoteIdentifier(node['_tableName'])}`);\n    if (node['_columns'].length > 0) {\n      parts.push(`(${node['_columns'].map(quoteIdentifier).join(', ')})`);\n    }\n    parts.push(`VALUES (${node['_values'].map(v => v.accept(this)).join(', ')})`);\n    return parts.join(' ');\n  }\n\n  visitSelectQuery(node: SelectQuery): string {\n    const parts: string[] = [];\n    if (node['_with'].length > 0) {\n      parts.push(`WITH ${node['_with'].map(w => w.accept(this)).join(', ')}`);\n    }\n    parts.push(`SELECT${node.isDistinct() ? ' DISTINCT' : ''}`);\n    if (node['_columns'].length > 0) {\n      parts.push(node['_columns'].map(c => this.columnLikeAcceptor.accept(this, c)).join(', '));\n    } else {\n      parts.push('*');\n    }\n    if (node['_fromsAndJoins'].length > 0) {\n      let fromsAndJoinsText = '';\n      for (const fromOrJoin of node['_fromsAndJoins']) {\n        if (fromOrJoin instanceof Join) {\n          fromsAndJoinsText += ` ${fromOrJoin.accept(this)}`;\n        } else if (\n          fromOrJoin instanceof Alias ||\n          fromOrJoin instanceof From ||\n          fromOrJoin instanceof TableFrom ||\n          fromOrJoin instanceof SubqueryFrom ||\n          fromOrJoin instanceof JsonEachFrom\n        ) {\n          if (fromsAndJoinsText) {\n            fromsAndJoinsText += `, ${fromOrJoin.accept(this)}`;\n          } else {\n            fromsAndJoinsText += `FROM ${fromOrJoin.accept(this)}`;\n          }\n        }\n      }\n      parts.push(fromsAndJoinsText);\n    }\n    if (node['_where']) {\n      parts.push(`WHERE ${node['_where'].accept(this)}`);\n    }\n    if (node['_groupBy'].length > 0) {\n      parts.push(`GROUP BY ${node['_groupBy'].map(c => c.accept(this)).join(', ')}`);\n    }\n    if (node['_having']) {\n      parts.push(`HAVING ${node['_having'].accept(this)}`);\n    }\n    if (node['_union'].length > 0) {\n      parts.push(node['_union'].map(u => `UNION ${u.accept(this)}`).join(' '));\n    }\n    if (node['_orderBy'].length > 0) {\n      parts.push(`ORDER BY ${node['_orderBy'].map(o => o.accept(this)).join(', ')}`);\n    }\n    if (node['_limit'] !== null && node['_limit'] !== undefined) {\n      parts.push(`LIMIT ${node['_limit']}`);\n      if (node['_offset'] !== null && node['_offset'] !== undefined) {\n        parts.push(`OFFSET ${node['_offset']}`);\n      }\n    }\n    return parts.filter(p => p).join(' ');\n  }\n\n  visitTableFrom(node: TableFrom): string {\n    return `${quoteIdentifier(node.tableName)}`;\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): string {\n    return `(${node.subquery.accept(this)})`;\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): string {\n    const expr = node.jsonExpression.accept(this);\n    const path = node.jsonPath ? `, ${node.jsonPath.accept(this)}` : '';\n    return `json_each(${expr}${path})`;\n  }\n\n  visitColumn(node: Column): string {\n    if (node.hasTableName()) {\n      return `${quoteIdentifier(node.tableName as string)}.${quoteIdentifier(node.columnName)}`;\n    } else {\n      return `${quoteIdentifier(node.columnName)}`;\n    }\n  }\n\n  visitAlias(node: Alias<From|AliasableExpression>): string {\n    const isSubquery = node.referent instanceof SubqueryFrom || node.referent instanceof SelectQuery;\n    const renderedReferent = node.referent.accept(this);\n    const renderedAliasName = quoteIdentifier(node.alias as string);\n    if (node.referent instanceof From) {\n      return `${renderedReferent} ${renderedAliasName}`;\n    } else if (isSubquery) {\n      return `(${renderedReferent}) AS ${renderedAliasName}`;\n    } else {\n      return `${renderedReferent} AS ${renderedAliasName}`;\n    }\n  }\n\n  visitJoinClause(node: Join): string {\n    return `${node.type} JOIN ${quoteIdentifier(node.tableName)} ${quoteIdentifier(node.alias)} ON ${node.on.accept(this)}`;\n  }\n\n  visitOrderBy(node: OrderBy): string {\n    return `${node.column.accept(this)} ${node.direction}`;\n  }\n\n  visitWithClause(node: With): string {\n    return `${quoteIdentifier(node.name)} AS (${node.query.accept(this)})`;\n  }\n\n  visitBinaryExpression(node: BinaryExpression): string {\n    return `(${node.left.accept(this)} ${node.operator} ${node.right.accept(this)})`;\n  }\n\n  visitUnaryExpression(node: UnaryExpression): string {\n    const operand = node.operand.accept(this);\n    if (node.operator === Operator.IS_NULL || node.operator === Operator.IS_NOT_NULL) {\n      return `(${operand} ${node.operator})`;\n    } else if (node.operator === 'NOT') {\n      return `(NOT ${operand})`;\n    } else {\n      return `(${node.operator}${operand})`;\n    }\n  }\n\n  visitInExpression(node: InExpression): string {\n    const leftStr = node.left.length > 1\n      ? `(${node.left.map(l => l.accept(this)).join(', ')})`\n      : node.left[0].accept(this);\n    const not = node.not ? ' NOT' : '';\n    let right: string;\n    if (node.values instanceof SelectQuery) {\n      right = `(${node.values.accept(this)})`;\n    } else {\n      right = `(${node.values.map(set =>\n        set.length > 1 ? `(${set.map(v => v.accept(this)).join(', ')})` : set[0].accept(this)\n      ).join(', ')})`;\n    }\n    return `(${leftStr}${not} IN ${right})`;\n  }\n\n  visitConcat(node: Concat): string {\n    return `(${node.expressions.map(e => e.accept(this)).join(' || ')})`;\n  }\n\n  visitCaseExpression(node: CaseExpression): string {\n    const parts: string[] = ['CASE'];\n    for (const c of node.cases) {\n      parts.push(`WHEN ${c.when.accept(this)} THEN ${c.then.accept(this)}`);\n    }\n    if (node.else) {\n      parts.push(`ELSE ${node.else.accept(this)}`);\n    }\n    parts.push('END');\n    return parts.join(' ');\n  }\n\n  visitFunctionExpression(node: FunctionExpression): string {\n    const args = node.args.map(a => a.accept(this)).join(', ');\n    const distinctPrefix = node.distinct ? 'DISTINCT ' : '';\n    return `${node.name}(${distinctPrefix}${args})`;\n  }\n\n  visitParamExpression(_node: Param): string {\n    return '?';\n  }\n\n  visitStringLiteral(node: StringLiteral): string {\n    return `'${node.value.replace(/'/g, \"''\")}'`;\n  }\n\n  visitNumberLiteral(node: NumberLiteral): string {\n    return node.value.toString();\n  }\n\n  visitNullLiteral(_node: NullLiteral): string {\n    return 'NULL';\n  }\n\n  visitExistsExpression(node: ExistsExpression): string {\n    return `EXISTS (${node.subquery.accept(this)})`;\n  }\n}\n"]}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { AliasableExpression } from "../ast/Abstractions";
|
|
2
|
+
import { Alias } from "../ast/Alias";
|
|
3
|
+
import { BinaryExpression } from "../ast/BinaryExpression";
|
|
4
|
+
import { CaseExpression } from "../ast/CaseExpression";
|
|
5
|
+
import { Column } from "../ast/Column";
|
|
6
|
+
import { Concat } from "../ast/Concat";
|
|
7
|
+
import { ExistsExpression } from "../ast/ExistsExpression";
|
|
8
|
+
import { From, JsonEachFrom, SubqueryFrom, TableFrom } from "../ast/From";
|
|
9
|
+
import { FunctionExpression } from "../ast/FunctionExpression";
|
|
10
|
+
import { InExpression } from "../ast/InExpression";
|
|
11
|
+
import { InsertQuery } from "../ast/InsertQuery";
|
|
12
|
+
import { Join } from "../ast/Join";
|
|
13
|
+
import { NullLiteral, NumberLiteral, Param, StringLiteral } from "../ast/Literals";
|
|
14
|
+
import { OrderBy } from "../ast/OrderBy";
|
|
15
|
+
import { SelectQuery } from "../ast/SelectQuery";
|
|
16
|
+
import { UnaryExpression } from "../ast/UnaryExpression";
|
|
17
|
+
import { With } from "../ast/With";
|
|
18
|
+
import { ColumnLikeVisitorAcceptor, FromLikeAndJoinVisitorAcceptor, SqlTreeNodeVisitor } from "../visitor/SqlTreeNodeVisitor";
|
|
19
|
+
import { QueryRenderer } from "./QueryRenderer";
|
|
20
|
+
export declare class IndentedQueryRenderer implements QueryRenderer, SqlTreeNodeVisitor<string> {
|
|
21
|
+
protected fromLikeAndJoinAcceptor: FromLikeAndJoinVisitorAcceptor<string>;
|
|
22
|
+
protected columnLikeAcceptor: ColumnLikeVisitorAcceptor<string>;
|
|
23
|
+
private readonly spacesPerLevel;
|
|
24
|
+
private indentationLevel;
|
|
25
|
+
constructor(spacesPerLevel: number);
|
|
26
|
+
render(node: SelectQuery | InsertQuery): string;
|
|
27
|
+
private getIndent;
|
|
28
|
+
private indent;
|
|
29
|
+
private dedent;
|
|
30
|
+
visitInsertQuery(node: InsertQuery): string;
|
|
31
|
+
visitSelectQuery(node: SelectQuery): string;
|
|
32
|
+
visitTableFrom(node: TableFrom): string;
|
|
33
|
+
visitSubqueryFrom(node: SubqueryFrom): string;
|
|
34
|
+
visitJsonEachFrom(node: JsonEachFrom): string;
|
|
35
|
+
visitColumn(node: Column): string;
|
|
36
|
+
visitAlias(node: Alias<From | AliasableExpression>): string;
|
|
37
|
+
visitJoinClause(node: Join): string;
|
|
38
|
+
visitOrderBy(node: OrderBy): string;
|
|
39
|
+
visitWithClause(node: With): string;
|
|
40
|
+
visitBinaryExpression(node: BinaryExpression): string;
|
|
41
|
+
visitUnaryExpression(node: UnaryExpression): string;
|
|
42
|
+
visitInExpression(node: InExpression): string;
|
|
43
|
+
visitConcat(node: Concat): string;
|
|
44
|
+
visitCaseExpression(node: CaseExpression): string;
|
|
45
|
+
visitFunctionExpression(node: FunctionExpression): string;
|
|
46
|
+
visitParamExpression(_node: Param): string;
|
|
47
|
+
visitStringLiteral(node: StringLiteral): string;
|
|
48
|
+
visitNumberLiteral(node: NumberLiteral): string;
|
|
49
|
+
visitNullLiteral(_node: NullLiteral): string;
|
|
50
|
+
visitExistsExpression(node: ExistsExpression): string;
|
|
51
|
+
}
|
|
@@ -0,0 +1,230 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.IndentedQueryRenderer = void 0;
|
|
4
|
+
const Alias_1 = require("../ast/Alias");
|
|
5
|
+
const From_1 = require("../ast/From");
|
|
6
|
+
const Join_1 = require("../ast/Join");
|
|
7
|
+
const Operator_1 = require("../ast/Operator");
|
|
8
|
+
const SelectQuery_1 = require("../ast/SelectQuery");
|
|
9
|
+
const SqlTreeNodeVisitor_1 = require("../visitor/SqlTreeNodeVisitor");
|
|
10
|
+
const QueryRenderer_1 = require("./QueryRenderer");
|
|
11
|
+
class IndentedQueryRenderer {
|
|
12
|
+
constructor(spacesPerLevel) {
|
|
13
|
+
this.fromLikeAndJoinAcceptor = new SqlTreeNodeVisitor_1.FromLikeAndJoinVisitorAcceptor();
|
|
14
|
+
this.columnLikeAcceptor = new SqlTreeNodeVisitor_1.ColumnLikeVisitorAcceptor();
|
|
15
|
+
this.indentationLevel = -1;
|
|
16
|
+
if (!Number.isInteger(spacesPerLevel) || spacesPerLevel <= 0) {
|
|
17
|
+
throw new Error('spacesPerLevel must be a positive integer');
|
|
18
|
+
}
|
|
19
|
+
this.spacesPerLevel = spacesPerLevel;
|
|
20
|
+
}
|
|
21
|
+
render(node) {
|
|
22
|
+
return node.accept(this);
|
|
23
|
+
}
|
|
24
|
+
getIndent() {
|
|
25
|
+
return ' '.repeat(this.indentationLevel * this.spacesPerLevel);
|
|
26
|
+
}
|
|
27
|
+
indent() {
|
|
28
|
+
this.indentationLevel++;
|
|
29
|
+
}
|
|
30
|
+
dedent() {
|
|
31
|
+
this.indentationLevel--;
|
|
32
|
+
}
|
|
33
|
+
visitInsertQuery(node) {
|
|
34
|
+
this.indent();
|
|
35
|
+
const parts = [];
|
|
36
|
+
parts.push(`${this.getIndent()}INSERT${node.isOrReplace() ? ' OR REPLACE' : ''}`);
|
|
37
|
+
parts.push(`${this.getIndent()}INTO ${(0, QueryRenderer_1.quoteIdentifier)(node['_tableName'])}`);
|
|
38
|
+
if (node['_columns'].length > 0) {
|
|
39
|
+
parts.push(`${this.getIndent()}(${node['_columns'].map(QueryRenderer_1.quoteIdentifier).join(', ')})`);
|
|
40
|
+
}
|
|
41
|
+
parts.push(`${this.getIndent()}VALUES`);
|
|
42
|
+
parts.push(`${this.getIndent()}(${node['_values'].map(v => v.accept(this)).join(', ')})`);
|
|
43
|
+
this.dedent();
|
|
44
|
+
return parts.join('\n');
|
|
45
|
+
}
|
|
46
|
+
visitSelectQuery(node) {
|
|
47
|
+
const parts = [];
|
|
48
|
+
if (node['_with'].length > 0) {
|
|
49
|
+
this.indent();
|
|
50
|
+
parts.push('WITH');
|
|
51
|
+
parts.push(node['_with'].map(w => w.accept(this)).join(',\n'));
|
|
52
|
+
this.dedent();
|
|
53
|
+
}
|
|
54
|
+
this.indent();
|
|
55
|
+
parts.push(`${this.getIndent()}SELECT${node.isDistinct() ? ' DISTINCT' : ''}`);
|
|
56
|
+
if (node['_columns'].length > 0) {
|
|
57
|
+
parts.push(node['_columns'].map(c => `${this.getIndent()} ${this.columnLikeAcceptor.accept(this, c)}`).join(',\n'));
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
parts.push(`${this.getIndent()} *`);
|
|
61
|
+
}
|
|
62
|
+
if (node['_fromsAndJoins'].length > 0) {
|
|
63
|
+
let fromsAndJoinsText = '';
|
|
64
|
+
for (const fromOrJoin of node['_fromsAndJoins']) {
|
|
65
|
+
if (fromOrJoin instanceof Join_1.Join) {
|
|
66
|
+
fromsAndJoinsText += `\n${this.getIndent()}${fromOrJoin.accept(this)}`;
|
|
67
|
+
}
|
|
68
|
+
else if (fromOrJoin instanceof Alias_1.Alias ||
|
|
69
|
+
fromOrJoin instanceof From_1.From ||
|
|
70
|
+
fromOrJoin instanceof From_1.TableFrom ||
|
|
71
|
+
fromOrJoin instanceof From_1.SubqueryFrom ||
|
|
72
|
+
fromOrJoin instanceof From_1.JsonEachFrom) {
|
|
73
|
+
if (fromsAndJoinsText) {
|
|
74
|
+
fromsAndJoinsText += `,\n${this.getIndent()}${fromOrJoin.accept(this)}`;
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
fromsAndJoinsText += `${this.getIndent()}FROM ${fromOrJoin.accept(this)}`;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
parts.push(fromsAndJoinsText);
|
|
82
|
+
}
|
|
83
|
+
if (node['_where']) {
|
|
84
|
+
parts.push(`${this.getIndent()}WHERE ${node['_where'].accept(this)}`);
|
|
85
|
+
}
|
|
86
|
+
if (node['_groupBy'].length > 0) {
|
|
87
|
+
parts.push(`${this.getIndent()}GROUP BY ${node['_groupBy'].map(c => c.accept(this)).join(', ')}`);
|
|
88
|
+
}
|
|
89
|
+
if (node['_having']) {
|
|
90
|
+
parts.push(`${this.getIndent()}HAVING ${node['_having'].accept(this)}`);
|
|
91
|
+
}
|
|
92
|
+
if (node['_union'].length > 0) {
|
|
93
|
+
parts.push(node['_union'].map(u => `${this.getIndent()}UNION\n${u.accept(this)}`).join('\n'));
|
|
94
|
+
}
|
|
95
|
+
if (node['_orderBy'].length > 0) {
|
|
96
|
+
parts.push(`${this.getIndent()}ORDER BY ${node['_orderBy'].map(o => o.accept(this)).join(', ')}`);
|
|
97
|
+
}
|
|
98
|
+
if (node['_limit'] !== null && node['_limit'] !== undefined) {
|
|
99
|
+
parts.push(`${this.getIndent()}LIMIT ${node['_limit']}`);
|
|
100
|
+
if (node['_offset'] !== null && node['_offset'] !== undefined) {
|
|
101
|
+
parts.push(`${this.getIndent()}OFFSET ${node['_offset']}`);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
this.dedent();
|
|
105
|
+
return parts.filter(p => p).join('\n');
|
|
106
|
+
}
|
|
107
|
+
visitTableFrom(node) {
|
|
108
|
+
return `${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)}`;
|
|
109
|
+
}
|
|
110
|
+
visitSubqueryFrom(node) {
|
|
111
|
+
this.indent();
|
|
112
|
+
const result = `(\n${node.subquery.accept(this)}\n${this.getIndent()})`;
|
|
113
|
+
this.dedent();
|
|
114
|
+
return result;
|
|
115
|
+
}
|
|
116
|
+
visitJsonEachFrom(node) {
|
|
117
|
+
const expr = node.jsonExpression.accept(this);
|
|
118
|
+
const path = node.jsonPath ? `, ${node.jsonPath.accept(this)}` : '';
|
|
119
|
+
return `json_each(${expr}${path})`;
|
|
120
|
+
}
|
|
121
|
+
visitColumn(node) {
|
|
122
|
+
if (node.hasTableName()) {
|
|
123
|
+
return `${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)}.${(0, QueryRenderer_1.quoteIdentifier)(node.columnName)}`;
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
return `${(0, QueryRenderer_1.quoteIdentifier)(node.columnName)}`;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
visitAlias(node) {
|
|
130
|
+
const renderedAliasName = (0, QueryRenderer_1.quoteIdentifier)(node.alias);
|
|
131
|
+
if (node.referent instanceof From_1.From) {
|
|
132
|
+
return `${node.referent.accept(this)} ${renderedAliasName}`;
|
|
133
|
+
}
|
|
134
|
+
else if (node.referent instanceof From_1.SubqueryFrom ||
|
|
135
|
+
node.referent instanceof SelectQuery_1.SelectQuery) {
|
|
136
|
+
this.indent();
|
|
137
|
+
const renderedSubquery = `${node.referent.accept(this)}\n`;
|
|
138
|
+
const result = `(\n${renderedSubquery}${this.getIndent()}) AS ${renderedAliasName}`;
|
|
139
|
+
this.dedent();
|
|
140
|
+
return result;
|
|
141
|
+
}
|
|
142
|
+
else {
|
|
143
|
+
return `${node.referent.accept(this)} AS ${renderedAliasName}`;
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
visitJoinClause(node) {
|
|
147
|
+
return `${node.type} JOIN ${(0, QueryRenderer_1.quoteIdentifier)(node.tableName)} ${(0, QueryRenderer_1.quoteIdentifier)(node.alias)} ON ${node.on.accept(this)}`;
|
|
148
|
+
}
|
|
149
|
+
visitOrderBy(node) {
|
|
150
|
+
return `${node.column.accept(this)} ${node.direction}`;
|
|
151
|
+
}
|
|
152
|
+
visitWithClause(node) {
|
|
153
|
+
this.indent();
|
|
154
|
+
const result = `${this.getIndent()}${(0, QueryRenderer_1.quoteIdentifier)(node.name)} AS (\n${node.query.accept(this)}\n${this.getIndent()})`;
|
|
155
|
+
this.dedent();
|
|
156
|
+
return result;
|
|
157
|
+
}
|
|
158
|
+
visitBinaryExpression(node) {
|
|
159
|
+
return `(${node.left.accept(this)} ${node.operator} ${node.right.accept(this)})`;
|
|
160
|
+
}
|
|
161
|
+
visitUnaryExpression(node) {
|
|
162
|
+
const operand = node.operand.accept(this);
|
|
163
|
+
if (node.operator === Operator_1.Operator.IS_NULL || node.operator === Operator_1.Operator.IS_NOT_NULL) {
|
|
164
|
+
return `(${operand} ${node.operator})`;
|
|
165
|
+
}
|
|
166
|
+
else if (node.operator === 'NOT') {
|
|
167
|
+
return `(NOT ${operand})`;
|
|
168
|
+
}
|
|
169
|
+
else {
|
|
170
|
+
return `(${node.operator}${operand})`;
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
visitInExpression(node) {
|
|
174
|
+
const leftStr = node.left.length > 1
|
|
175
|
+
? `(${node.left.map(l => l.accept(this)).join(', ')})`
|
|
176
|
+
: node.left[0].accept(this);
|
|
177
|
+
const not = node.not ? ' NOT' : '';
|
|
178
|
+
let right;
|
|
179
|
+
if (node.values instanceof SelectQuery_1.SelectQuery) {
|
|
180
|
+
right = `(\n${node.values.accept(this)}\n${this.getIndent()})`;
|
|
181
|
+
}
|
|
182
|
+
else {
|
|
183
|
+
right = `(${node.values.map(set => set.length > 1 ? `(${set.map(v => v.accept(this)).join(', ')})` : set[0].accept(this)).join(', ')})`;
|
|
184
|
+
}
|
|
185
|
+
return `(${leftStr}${not} IN ${right})`;
|
|
186
|
+
}
|
|
187
|
+
visitConcat(node) {
|
|
188
|
+
return `(${node.expressions.map(e => e.accept(this)).join(' || ')})`;
|
|
189
|
+
}
|
|
190
|
+
visitCaseExpression(node) {
|
|
191
|
+
const parts = [`${this.getIndent()}CASE`];
|
|
192
|
+
this.indent();
|
|
193
|
+
for (const c of node.cases) {
|
|
194
|
+
this.indent();
|
|
195
|
+
parts.push(`${this.getIndent()}WHEN ${c.when.accept(this)} THEN ${c.then.accept(this)}`);
|
|
196
|
+
this.dedent();
|
|
197
|
+
}
|
|
198
|
+
if (node.else) {
|
|
199
|
+
this.indent();
|
|
200
|
+
parts.push(`${this.getIndent()}ELSE ${node.else.accept(this)}`);
|
|
201
|
+
this.dedent();
|
|
202
|
+
}
|
|
203
|
+
parts.push(`${this.getIndent()}END`);
|
|
204
|
+
this.dedent();
|
|
205
|
+
return parts.join('\n');
|
|
206
|
+
}
|
|
207
|
+
visitFunctionExpression(node) {
|
|
208
|
+
const args = node.args.map(a => a.accept(this)).join(', ');
|
|
209
|
+
const distinctPrefix = node.distinct ? 'DISTINCT ' : '';
|
|
210
|
+
return `${node.name}(${distinctPrefix}${args})`;
|
|
211
|
+
}
|
|
212
|
+
visitParamExpression(_node) {
|
|
213
|
+
return '?';
|
|
214
|
+
}
|
|
215
|
+
visitStringLiteral(node) {
|
|
216
|
+
return `'${node.value.replace(/'/g, "''")}'`;
|
|
217
|
+
}
|
|
218
|
+
visitNumberLiteral(node) {
|
|
219
|
+
return node.value.toString();
|
|
220
|
+
}
|
|
221
|
+
visitNullLiteral(_node) {
|
|
222
|
+
return 'NULL';
|
|
223
|
+
}
|
|
224
|
+
visitExistsExpression(node) {
|
|
225
|
+
const subquerySql = node.subquery.accept(this);
|
|
226
|
+
return `EXISTS (\n${subquerySql}\n${this.getIndent()})`;
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
exports.IndentedQueryRenderer = IndentedQueryRenderer;
|
|
230
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"IndentedQueryRenderer.js","sourceRoot":"","sources":["../../src/renderer/IndentedQueryRenderer.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 { Operator } from \"../ast/Operator\";\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 \"../visitor/SqlTreeNodeVisitor\";\nimport { QueryRenderer, quoteIdentifier } from \"./QueryRenderer\";\n\nexport class IndentedQueryRenderer\n  implements QueryRenderer, SqlTreeNodeVisitor<string>\n{\n  protected fromLikeAndJoinAcceptor = new FromLikeAndJoinVisitorAcceptor<string>();\n  protected columnLikeAcceptor = new ColumnLikeVisitorAcceptor<string>();\n\n  private readonly spacesPerLevel: number;\n  private indentationLevel: number = -1;\n\n  public constructor(spacesPerLevel: number) {\n    if (!Number.isInteger(spacesPerLevel) || spacesPerLevel <= 0) {\n      throw new Error('spacesPerLevel must be a positive integer');\n    }\n    this.spacesPerLevel = spacesPerLevel;\n  }\n\n  public render(node: SelectQuery | InsertQuery): string {\n    return node.accept(this);\n  }\n\n  private getIndent(): string {\n    return ' '.repeat(this.indentationLevel * this.spacesPerLevel);\n  }\n\n  private indent(): void {\n    this.indentationLevel++;\n  }\n\n  private dedent(): void {\n    this.indentationLevel--;\n  }\n\n  visitInsertQuery(node: InsertQuery): string {\n    this.indent();\n    const parts: string[] = [];\n    parts.push(`${this.getIndent()}INSERT${node.isOrReplace() ? ' OR REPLACE' : ''}`);\n    parts.push(`${this.getIndent()}INTO ${quoteIdentifier(node['_tableName'])}`);\n    if (node['_columns'].length > 0) {\n      parts.push(`${this.getIndent()}(${node['_columns'].map(quoteIdentifier).join(', ')})`);\n    }\n    parts.push(`${this.getIndent()}VALUES`);\n    parts.push(`${this.getIndent()}(${node['_values'].map(v => v.accept(this)).join(', ')})`);\n    this.dedent();\n    return parts.join('\\n');\n  }\n\n  visitSelectQuery(node: SelectQuery): string {\n    const parts: string[] = [];\n    if (node['_with'].length > 0) {\n      this.indent();\n      parts.push('WITH');\n      parts.push(node['_with'].map(w => w.accept(this)).join(',\\n'));\n      this.dedent();\n    }\n    this.indent();\n    parts.push(`${this.getIndent()}SELECT${node.isDistinct() ? ' DISTINCT' : ''}`);\n    if (node['_columns'].length > 0) {\n      parts.push(node['_columns'].map(c => `${this.getIndent()}  ${this.columnLikeAcceptor.accept(this, c)}`).join(',\\n'));\n    } else {\n      parts.push(`${this.getIndent()}  *`);\n    }\n    if (node['_fromsAndJoins'].length > 0) {\n      let fromsAndJoinsText = '';\n      for (const fromOrJoin of node['_fromsAndJoins']) {\n        if (fromOrJoin instanceof Join) {\n          fromsAndJoinsText += `\\n${this.getIndent()}${fromOrJoin.accept(this)}`;\n        } else if (\n          fromOrJoin instanceof Alias ||\n          fromOrJoin instanceof From ||\n          fromOrJoin instanceof TableFrom ||\n          fromOrJoin instanceof SubqueryFrom ||\n          fromOrJoin instanceof JsonEachFrom\n        ) {\n          if (fromsAndJoinsText) {\n            fromsAndJoinsText += `,\\n${this.getIndent()}${fromOrJoin.accept(this)}`;\n          } else {\n            fromsAndJoinsText += `${this.getIndent()}FROM ${fromOrJoin.accept(this)}`;\n          }\n        }\n      }\n      parts.push(fromsAndJoinsText);\n    }\n    if (node['_where']) {\n      parts.push(`${this.getIndent()}WHERE ${node['_where'].accept(this)}`);\n    }\n    if (node['_groupBy'].length > 0) {\n      parts.push(`${this.getIndent()}GROUP BY ${node['_groupBy'].map(c => c.accept(this)).join(', ')}`);\n    }\n    if (node['_having']) {\n      parts.push(`${this.getIndent()}HAVING ${node['_having'].accept(this)}`);\n    }\n    if (node['_union'].length > 0) {\n      parts.push(node['_union'].map(u => `${this.getIndent()}UNION\\n${u.accept(this)}`).join('\\n'));\n    }\n    if (node['_orderBy'].length > 0) {\n      parts.push(`${this.getIndent()}ORDER BY ${node['_orderBy'].map(o => o.accept(this)).join(', ')}`);\n    }\n    if (node['_limit'] !== null && node['_limit'] !== undefined) {\n      parts.push(`${this.getIndent()}LIMIT ${node['_limit']}`);\n      if (node['_offset'] !== null && node['_offset'] !== undefined) {\n        parts.push(`${this.getIndent()}OFFSET ${node['_offset']}`);\n      }\n    }\n    this.dedent();\n    return parts.filter(p => p).join('\\n');\n  }\n\n  visitTableFrom(node: TableFrom): string {\n    return `${quoteIdentifier(node.tableName)}`;\n  }\n\n  visitSubqueryFrom(node: SubqueryFrom): string {\n    this.indent();\n    const result = `(\\n${node.subquery.accept(this)}\\n${this.getIndent()})`;\n    this.dedent();\n    return result;\n  }\n\n  visitJsonEachFrom(node: JsonEachFrom): string {\n    const expr = node.jsonExpression.accept(this);\n    const path = node.jsonPath ? `, ${node.jsonPath.accept(this)}` : '';\n    return `json_each(${expr}${path})`;\n  }\n\n  visitColumn(node: Column): string {\n    if (node.hasTableName()) {\n      return `${quoteIdentifier(node.tableName as string)}.${quoteIdentifier(node.columnName)}`;\n    } else {\n      return `${quoteIdentifier(node.columnName)}`;\n    }\n  }\n\n  visitAlias(node: Alias<From|AliasableExpression>): string {\n    const renderedAliasName = quoteIdentifier(node.alias as string);\n    if (node.referent instanceof From) {\n      return `${node.referent.accept(this)} ${renderedAliasName}`;\n    } else if (\n      node.referent instanceof SubqueryFrom ||\n      node.referent instanceof SelectQuery\n    ) {\n      this.indent();\n      const renderedSubquery = `${node.referent.accept(this)}\\n`;\n      const result = `(\\n${renderedSubquery}${this.getIndent()}) AS ${renderedAliasName}`;\n      this.dedent();\n      return result;\n    } else {\n      return `${node.referent.accept(this)} AS ${renderedAliasName}`;\n    }\n  }\n\n  visitJoinClause(node: Join): string {\n    return `${node.type} JOIN ${quoteIdentifier(node.tableName)} ${quoteIdentifier(node.alias)} ON ${node.on.accept(this)}`;\n  }\n\n  visitOrderBy(node: OrderBy): string {\n    return `${node.column.accept(this)} ${node.direction}`;\n  }\n\n  visitWithClause(node: With): string {\n    this.indent();\n    const result = `${this.getIndent()}${quoteIdentifier(node.name)} AS (\\n${node.query.accept(this)}\\n${this.getIndent()})`;\n    this.dedent();\n    return result;\n  }\n\n  visitBinaryExpression(node: BinaryExpression): string {\n    return `(${node.left.accept(this)} ${node.operator} ${node.right.accept(this)})`;\n  }\n\n  visitUnaryExpression(node: UnaryExpression): string {\n    const operand = node.operand.accept(this);\n    if (node.operator === Operator.IS_NULL || node.operator === Operator.IS_NOT_NULL) {\n      return `(${operand} ${node.operator})`;\n    } else if (node.operator === 'NOT') {\n      return `(NOT ${operand})`;\n    } else {\n      return `(${node.operator}${operand})`;\n    }\n  }\n\n  visitInExpression(node: InExpression): string {\n    const leftStr = node.left.length > 1\n      ? `(${node.left.map(l => l.accept(this)).join(', ')})`\n      : node.left[0].accept(this);\n    const not = node.not ? ' NOT' : '';\n    let right: string;\n    if (node.values instanceof SelectQuery) {\n      right = `(\\n${node.values.accept(this)}\\n${this.getIndent()})`;\n    } else {\n      right = `(${node.values.map(set =>\n        set.length > 1 ? `(${set.map(v => v.accept(this)).join(', ')})` : set[0].accept(this)\n      ).join(', ')})`;\n    }\n    return `(${leftStr}${not} IN ${right})`;\n  }\n\n  visitConcat(node: Concat): string {\n    return `(${node.expressions.map(e => e.accept(this)).join(' || ')})`;\n  }\n\n  visitCaseExpression(node: CaseExpression): string {\n    const parts: string[] = [`${this.getIndent()}CASE`];\n    this.indent();\n    for (const c of node.cases) {\n      this.indent();\n      parts.push(`${this.getIndent()}WHEN ${c.when.accept(this)} THEN ${c.then.accept(this)}`);\n      this.dedent();\n    }\n    if (node.else) {\n      this.indent();\n      parts.push(`${this.getIndent()}ELSE ${node.else.accept(this)}`);\n      this.dedent();\n    }\n    parts.push(`${this.getIndent()}END`);\n    this.dedent();\n    return parts.join('\\n');\n  }\n\n  visitFunctionExpression(node: FunctionExpression): string {\n    const args = node.args.map(a => a.accept(this)).join(', ');\n    const distinctPrefix = node.distinct ? 'DISTINCT ' : '';\n    return `${node.name}(${distinctPrefix}${args})`;\n  }\n\n  visitParamExpression(_node: Param): string {\n    return '?';\n  }\n\n  visitStringLiteral(node: StringLiteral): string {\n    return `'${node.value.replace(/'/g, \"''\")}'`;\n  }\n\n  visitNumberLiteral(node: NumberLiteral): string {\n    return node.value.toString();\n  }\n\n  visitNullLiteral(_node: NullLiteral): string {\n    return 'NULL';\n  }\n\n  visitExistsExpression(node: ExistsExpression): string {\n    const subquerySql = node.subquery.accept(this);\n    return `EXISTS (\\n${subquerySql}\\n${this.getIndent()})`;\n  }\n}\n"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { InsertQuery } from "../ast/InsertQuery";
|
|
2
|
+
import { SelectQuery } from "../ast/SelectQuery";
|
|
3
|
+
import { SqlTreeNodeVisitor } from "../visitor/SqlTreeNodeVisitor";
|
|
4
|
+
export declare function quoteIdentifier(identifier: string): string;
|
|
5
|
+
export interface QueryRenderer extends SqlTreeNodeVisitor<string> {
|
|
6
|
+
render(node: SelectQuery | InsertQuery): string;
|
|
7
|
+
}
|
|
8
|
+
export declare function shouldQuoteIdentifier(identifier: string): boolean;
|