@eggjs/dal-runtime 4.0.0-beta.7 → 4.0.0-beta.9

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.
@@ -1,224 +1,392 @@
1
- import { ColumnModel, TableModel } from "@eggjs/dal-decorator";
2
- import { ColumnType, IndexType } from "@eggjs/tegg-types";
3
-
4
- //#region src/SqlGenerator.ts
5
- var SqlGenerator = class {
6
- formatComment(comment) {
7
- return comment.replace(/\n/g, "\\n");
8
- }
9
- generateColumn(column) {
10
- const sqls = [
11
- " ",
12
- column.columnName,
13
- this.generateColumnType(column.type)
14
- ];
15
- if (column.canNull) sqls.push("NULL");
16
- else sqls.push("NOT NULL");
17
- if ([
18
- ColumnType.POINT,
19
- ColumnType.GEOMETRY,
20
- ColumnType.POINT,
21
- ColumnType.LINESTRING,
22
- ColumnType.POLYGON,
23
- ColumnType.MULTIPOINT,
24
- ColumnType.MULTILINESTRING,
25
- ColumnType.MULTIPOLYGON,
26
- ColumnType.GEOMETRYCOLLECTION
27
- ].includes(column.type.type)) {
28
- const SRID = column.type.SRID;
29
- if (SRID) sqls.push(`SRID ${SRID}`);
30
- }
31
- if (typeof column.default !== "undefined") sqls.push(`DEFAULT ${column.default}`);
32
- if (column.autoIncrement) sqls.push("AUTO_INCREMENT");
33
- if (column.uniqueKey) sqls.push("UNIQUE KEY");
34
- if (column.primaryKey) sqls.push("PRIMARY KEY");
35
- if (column.comment) sqls.push(`COMMENT '${this.formatComment(column.comment)}'`);
36
- if (column.collate) sqls.push(`COLLATE ${column.collate}`);
37
- if (column.columnFormat) sqls.push(`COLUMN_FORMAT ${column.columnFormat}`);
38
- if (column.engineAttribute) sqls.push(`ENGINE_ATTRIBUTE='${column.engineAttribute}'`);
39
- if (column.secondaryEngineAttribute) sqls.push(`SECONDARY_ENGINE_ATTRIBUTE='${column.secondaryEngineAttribute}'`);
40
- return sqls.join(" ");
41
- }
42
- generateColumnType(columnType) {
43
- const sqls = [];
44
- switch (columnType.type) {
45
- case ColumnType.BOOL:
46
- sqls.push("BOOL");
47
- break;
48
- case ColumnType.BIT:
49
- if (columnType.length) sqls.push(`BIT(${columnType.length})`);
50
- else sqls.push("BIT");
51
- break;
52
- case ColumnType.TINYINT:
53
- case ColumnType.SMALLINT:
54
- case ColumnType.MEDIUMINT:
55
- case ColumnType.INT:
56
- case ColumnType.BIGINT:
57
- if (typeof columnType.length === "number") sqls.push(`${columnType.type}(${columnType.length})`);
58
- else sqls.push(columnType.type);
59
- if (columnType.unsigned) sqls.push("UNSIGNED");
60
- if (columnType.zeroFill) sqls.push("ZEROFILL");
61
- break;
62
- case ColumnType.DECIMAL:
63
- case ColumnType.FLOAT:
64
- case ColumnType.DOUBLE:
65
- if (typeof columnType.length === "number" && typeof columnType.fractionalLength === "number") sqls.push(`${columnType.type}(${columnType.length},${columnType.fractionalLength})`);
66
- else if (typeof columnType.length === "number") sqls.push(`${columnType.type}(${columnType.length})`);
67
- else sqls.push("TINYINT");
68
- if (columnType.unsigned) sqls.push("UNSIGNED");
69
- if (columnType.zeroFill) sqls.push("ZEROFILL");
70
- break;
71
- case ColumnType.DATE:
72
- sqls.push("DATE");
73
- break;
74
- case ColumnType.DATETIME:
75
- case ColumnType.TIMESTAMP:
76
- if (columnType.precision) sqls.push(`${columnType.type}(${columnType.precision})`);
77
- else sqls.push(columnType.type);
78
- if (columnType.autoUpdate) if (columnType.precision) sqls.push(`ON UPDATE CURRENT_TIMESTAMP(${columnType.precision})`);
79
- else sqls.push("ON UPDATE CURRENT_TIMESTAMP");
80
- break;
81
- case ColumnType.TIME:
82
- if (columnType.precision) sqls.push(`${columnType.type}(${columnType.precision})`);
83
- else sqls.push(columnType.type);
84
- break;
85
- case ColumnType.YEAR:
86
- sqls.push("YEAR");
87
- break;
88
- case ColumnType.CHAR:
89
- case ColumnType.TEXT:
90
- if (columnType.length) sqls.push(`${columnType.type}(${columnType.length})`);
91
- else sqls.push(columnType.type);
92
- if (columnType.characterSet) sqls.push(`CHARACTER SET ${columnType.characterSet}`);
93
- if (columnType.collate) sqls.push(`COLLATE ${columnType.collate}`);
94
- break;
95
- case ColumnType.VARCHAR:
96
- sqls.push(`${columnType.type}(${columnType.length})`);
97
- if (columnType.characterSet) sqls.push(`CHARACTER SET ${columnType.characterSet}`);
98
- if (columnType.collate) sqls.push(`COLLATE ${columnType.collate}`);
99
- break;
100
- case ColumnType.BINARY:
101
- if (columnType.length) sqls.push(`${columnType.type}(${columnType.length})`);
102
- else sqls.push(columnType.type);
103
- break;
104
- case ColumnType.VARBINARY:
105
- sqls.push(`${columnType.type}(${columnType.length})`);
106
- break;
107
- case ColumnType.TINYBLOB:
108
- sqls.push("TINYBLOB");
109
- break;
110
- case ColumnType.TINYTEXT:
111
- case ColumnType.MEDIUMTEXT:
112
- case ColumnType.LONGTEXT:
113
- sqls.push(columnType.type);
114
- if (columnType.characterSet) sqls.push(`CHARACTER SET ${columnType.characterSet}`);
115
- if (columnType.collate) sqls.push(`COLLATE ${columnType.collate}`);
116
- break;
117
- case ColumnType.BLOB:
118
- if (columnType.length) sqls.push(`${columnType.type}(${columnType.length})`);
119
- else sqls.push(columnType.type);
120
- break;
121
- case ColumnType.MEDIUMBLOB:
122
- sqls.push("MEDIUMBLOB");
123
- break;
124
- case ColumnType.LONGBLOB:
125
- sqls.push("LONGBLOB");
126
- break;
127
- case ColumnType.ENUM: {
128
- const enumValue = columnType.enums.map((t) => `'${t}'`).join(",");
129
- sqls.push(`ENUM(${enumValue})`);
130
- if (columnType.characterSet) sqls.push(`CHARACTER SET ${columnType.characterSet}`);
131
- if (columnType.collate) sqls.push(`COLLATE ${columnType.collate}`);
132
- break;
133
- }
134
- case ColumnType.SET: {
135
- const enumValue = columnType.enums.map((t) => `'${t}'`).join(",");
136
- sqls.push(`SET(${enumValue})`);
137
- if (columnType.characterSet) sqls.push(`CHARACTER SET ${columnType.characterSet}`);
138
- if (columnType.collate) sqls.push(`COLLATE ${columnType.collate}`);
139
- break;
140
- }
141
- case ColumnType.JSON:
142
- sqls.push("JSON");
143
- break;
144
- case ColumnType.GEOMETRY:
145
- case ColumnType.POINT:
146
- case ColumnType.LINESTRING:
147
- case ColumnType.POLYGON:
148
- case ColumnType.MULTIPOINT:
149
- case ColumnType.MULTILINESTRING:
150
- case ColumnType.MULTIPOLYGON:
151
- case ColumnType.GEOMETRYCOLLECTION:
152
- sqls.push(columnType.type);
153
- break;
154
- default: throw new Error(`unknown ColumnType ${columnType}`);
155
- }
156
- return sqls.join(" ");
157
- }
158
- generateIndex(indexModel) {
159
- const indexSql = [" "];
160
- switch (indexModel.type) {
161
- case IndexType.INDEX:
162
- indexSql.push("KEY");
163
- break;
164
- case IndexType.UNIQUE:
165
- indexSql.push("UNIQUE KEY");
166
- break;
167
- case IndexType.PRIMARY:
168
- indexSql.push("PRIMARY KEY");
169
- break;
170
- case IndexType.FULLTEXT:
171
- indexSql.push("FULLTEXT KEY");
172
- break;
173
- case IndexType.SPATIAL:
174
- indexSql.push("SPATIAL KEY");
175
- break;
176
- default: throw new Error(`unknown IndexType ${indexModel.type}`);
177
- }
178
- indexSql.push(indexModel.name);
179
- indexSql.push(`(${indexModel.keys.map((t) => t.columnName).join(",")})`);
180
- if (indexModel.storeType) indexSql.push(`USING ${indexModel.storeType}`);
181
- if (indexModel.parser) indexSql.push(`WITH PARSER ${indexModel.parser}`);
182
- if (indexModel.comment) indexSql.push(`COMMENT '${this.formatComment(indexModel.comment)}'`);
183
- if (indexModel.engineAttribute) indexSql.push(`ENGINE_ATTRIBUTE='${indexModel.engineAttribute}'`);
184
- if (indexModel.secondaryEngineAttribute) indexSql.push(`SECONDARY_ENGINE_ATTRIBUTE='${indexModel.secondaryEngineAttribute}'`);
185
- return indexSql.join(" ");
186
- }
187
- generateTableOptions(tableModel) {
188
- const sqls = [];
189
- if (tableModel.autoExtendSize) sqls.push(`AUTOEXTEND_SIZE=${tableModel.autoExtendSize}`);
190
- if (tableModel.autoIncrement) sqls.push(`AUTO_INCREMENT=${tableModel.autoIncrement}`);
191
- if (tableModel.avgRowLength) sqls.push(`AVG_ROW_LENGTH=${tableModel.avgRowLength}`);
192
- if (tableModel.characterSet) sqls.push(`DEFAULT CHARACTER SET ${tableModel.characterSet}`);
193
- if (tableModel.collate) sqls.push(`DEFAULT COLLATE ${tableModel.collate}`);
194
- if (tableModel.comment) sqls.push(`COMMENT='${this.formatComment(tableModel.comment)}'`);
195
- if (tableModel.compression) sqls.push(`COMPRESSION='${tableModel.compression}'`);
196
- if (typeof tableModel.encryption !== "undefined") sqls.push(`ENCRYPTION='${tableModel.encryption ? "Y" : "N"}'`);
197
- if (typeof tableModel.engine !== "undefined") sqls.push(`ENGINE=${tableModel.engine}`);
198
- if (tableModel.engineAttribute) sqls.push(`ENGINE_ATTRIBUTE='${tableModel.engineAttribute}'`);
199
- if (tableModel.secondaryEngineAttribute) sqls.push(`SECONDARY_ENGINE_ATTRIBUTE = '${tableModel.secondaryEngineAttribute}'`);
200
- if (tableModel.insertMethod) sqls.push(`INSERT_METHOD=${tableModel.insertMethod}`);
201
- if (tableModel.keyBlockSize) sqls.push(`KEY_BLOCK_SIZE=${tableModel.keyBlockSize}`);
202
- if (tableModel.maxRows) sqls.push(`MAX_ROWS=${tableModel.maxRows}`);
203
- if (tableModel.minRows) sqls.push(`MIN_ROWS=${tableModel.minRows}`);
204
- if (tableModel.rowFormat) sqls.push(`ROW_FORMAT=${tableModel.rowFormat}`);
205
- return sqls.join(", ");
206
- }
207
- generate(tableModel) {
208
- const createSql = [];
209
- createSql.push(`CREATE TABLE IF NOT EXISTS ${tableModel.name} (`);
210
- const columnSql = [];
211
- for (const column of tableModel.columns) columnSql.push(this.generateColumn(column));
212
- const indexSql = [];
213
- for (const index of tableModel.indices) indexSql.push(this.generateIndex(index));
214
- if (indexSql.length) {
215
- createSql.push(columnSql.join(",\n") + ",");
216
- createSql.push(indexSql.join(",\n"));
217
- } else createSql.push(columnSql.join(",\n"));
218
- createSql.push(`) ${this.generateTableOptions(tableModel)};`);
219
- return createSql.join("\n");
220
- }
221
- };
222
-
223
- //#endregion
224
- export { SqlGenerator };
1
+ import { ColumnModel, IndexModel, TableModel, } from '@eggjs/dal-decorator';
2
+ import { ColumnType, IndexType } from '@eggjs/tegg-types';
3
+ // TODO diff 实现
4
+ export class SqlGenerator {
5
+ formatComment(comment) {
6
+ return comment.replace(/\n/g, '\\n');
7
+ }
8
+ generateColumn(column) {
9
+ const sqls = [
10
+ ' ',
11
+ column.columnName,
12
+ this.generateColumnType(column.type),
13
+ ];
14
+ if (column.canNull) {
15
+ sqls.push('NULL');
16
+ }
17
+ else {
18
+ sqls.push('NOT NULL');
19
+ }
20
+ if ([
21
+ ColumnType.POINT,
22
+ ColumnType.GEOMETRY,
23
+ ColumnType.POINT,
24
+ ColumnType.LINESTRING,
25
+ ColumnType.POLYGON,
26
+ ColumnType.MULTIPOINT,
27
+ ColumnType.MULTILINESTRING,
28
+ ColumnType.MULTIPOLYGON,
29
+ ColumnType.GEOMETRYCOLLECTION,
30
+ ].includes(column.type.type)) {
31
+ const SRID = column.type.SRID;
32
+ if (SRID) {
33
+ sqls.push(`SRID ${SRID}`);
34
+ }
35
+ }
36
+ if (typeof column.default !== 'undefined') {
37
+ sqls.push(`DEFAULT ${column.default}`);
38
+ }
39
+ if (column.autoIncrement) {
40
+ sqls.push('AUTO_INCREMENT');
41
+ }
42
+ if (column.uniqueKey) {
43
+ sqls.push('UNIQUE KEY');
44
+ }
45
+ if (column.primaryKey) {
46
+ sqls.push('PRIMARY KEY');
47
+ }
48
+ if (column.comment) {
49
+ sqls.push(`COMMENT '${this.formatComment(column.comment)}'`);
50
+ }
51
+ if (column.collate) {
52
+ sqls.push(`COLLATE ${column.collate}`);
53
+ }
54
+ if (column.columnFormat) {
55
+ sqls.push(`COLUMN_FORMAT ${column.columnFormat}`);
56
+ }
57
+ if (column.engineAttribute) {
58
+ sqls.push(`ENGINE_ATTRIBUTE='${column.engineAttribute}'`);
59
+ }
60
+ if (column.secondaryEngineAttribute) {
61
+ sqls.push(`SECONDARY_ENGINE_ATTRIBUTE='${column.secondaryEngineAttribute}'`);
62
+ }
63
+ return sqls.join(' ');
64
+ }
65
+ generateColumnType(columnType) {
66
+ const sqls = [];
67
+ switch (columnType.type) {
68
+ case ColumnType.BOOL: {
69
+ sqls.push('BOOL');
70
+ break;
71
+ }
72
+ case ColumnType.BIT: {
73
+ if (columnType.length) {
74
+ sqls.push(`BIT(${columnType.length})`);
75
+ }
76
+ else {
77
+ sqls.push('BIT');
78
+ }
79
+ break;
80
+ }
81
+ case ColumnType.TINYINT:
82
+ case ColumnType.SMALLINT:
83
+ case ColumnType.MEDIUMINT:
84
+ case ColumnType.INT:
85
+ case ColumnType.BIGINT: {
86
+ if (typeof columnType.length === 'number') {
87
+ sqls.push(`${columnType.type}(${columnType.length})`);
88
+ }
89
+ else {
90
+ sqls.push(columnType.type);
91
+ }
92
+ if (columnType.unsigned) {
93
+ sqls.push('UNSIGNED');
94
+ }
95
+ if (columnType.zeroFill) {
96
+ sqls.push('ZEROFILL');
97
+ }
98
+ break;
99
+ }
100
+ case ColumnType.DECIMAL:
101
+ case ColumnType.FLOAT:
102
+ case ColumnType.DOUBLE: {
103
+ if (typeof columnType.length === 'number' && typeof columnType.fractionalLength === 'number') {
104
+ sqls.push(`${columnType.type}(${columnType.length},${columnType.fractionalLength})`);
105
+ }
106
+ else if (typeof columnType.length === 'number') {
107
+ sqls.push(`${columnType.type}(${columnType.length})`);
108
+ }
109
+ else {
110
+ sqls.push('TINYINT');
111
+ }
112
+ if (columnType.unsigned) {
113
+ sqls.push('UNSIGNED');
114
+ }
115
+ if (columnType.zeroFill) {
116
+ sqls.push('ZEROFILL');
117
+ }
118
+ break;
119
+ }
120
+ case ColumnType.DATE: {
121
+ sqls.push('DATE');
122
+ break;
123
+ }
124
+ case ColumnType.DATETIME:
125
+ case ColumnType.TIMESTAMP: {
126
+ if (columnType.precision) {
127
+ sqls.push(`${columnType.type}(${columnType.precision})`);
128
+ }
129
+ else {
130
+ sqls.push(columnType.type);
131
+ }
132
+ if (columnType.autoUpdate) {
133
+ if (columnType.precision) {
134
+ sqls.push(`ON UPDATE CURRENT_TIMESTAMP(${columnType.precision})`);
135
+ }
136
+ else {
137
+ sqls.push('ON UPDATE CURRENT_TIMESTAMP');
138
+ }
139
+ }
140
+ break;
141
+ }
142
+ case ColumnType.TIME: {
143
+ if (columnType.precision) {
144
+ sqls.push(`${columnType.type}(${columnType.precision})`);
145
+ }
146
+ else {
147
+ sqls.push(columnType.type);
148
+ }
149
+ break;
150
+ }
151
+ case ColumnType.YEAR: {
152
+ sqls.push('YEAR');
153
+ break;
154
+ }
155
+ case ColumnType.CHAR:
156
+ case ColumnType.TEXT: {
157
+ if (columnType.length) {
158
+ sqls.push(`${columnType.type}(${columnType.length})`);
159
+ }
160
+ else {
161
+ sqls.push(columnType.type);
162
+ }
163
+ if (columnType.characterSet) {
164
+ sqls.push(`CHARACTER SET ${columnType.characterSet}`);
165
+ }
166
+ if (columnType.collate) {
167
+ sqls.push(`COLLATE ${columnType.collate}`);
168
+ }
169
+ break;
170
+ }
171
+ case ColumnType.VARCHAR: {
172
+ sqls.push(`${columnType.type}(${columnType.length})`);
173
+ if (columnType.characterSet) {
174
+ sqls.push(`CHARACTER SET ${columnType.characterSet}`);
175
+ }
176
+ if (columnType.collate) {
177
+ sqls.push(`COLLATE ${columnType.collate}`);
178
+ }
179
+ break;
180
+ }
181
+ case ColumnType.BINARY: {
182
+ if (columnType.length) {
183
+ sqls.push(`${columnType.type}(${columnType.length})`);
184
+ }
185
+ else {
186
+ sqls.push(columnType.type);
187
+ }
188
+ break;
189
+ }
190
+ case ColumnType.VARBINARY: {
191
+ sqls.push(`${columnType.type}(${columnType.length})`);
192
+ break;
193
+ }
194
+ case ColumnType.TINYBLOB: {
195
+ sqls.push('TINYBLOB');
196
+ break;
197
+ }
198
+ case ColumnType.TINYTEXT:
199
+ case ColumnType.MEDIUMTEXT:
200
+ case ColumnType.LONGTEXT: {
201
+ sqls.push(columnType.type);
202
+ if (columnType.characterSet) {
203
+ sqls.push(`CHARACTER SET ${columnType.characterSet}`);
204
+ }
205
+ if (columnType.collate) {
206
+ sqls.push(`COLLATE ${columnType.collate}`);
207
+ }
208
+ break;
209
+ }
210
+ case ColumnType.BLOB: {
211
+ if (columnType.length) {
212
+ sqls.push(`${columnType.type}(${columnType.length})`);
213
+ }
214
+ else {
215
+ sqls.push(columnType.type);
216
+ }
217
+ break;
218
+ }
219
+ case ColumnType.MEDIUMBLOB: {
220
+ sqls.push('MEDIUMBLOB');
221
+ break;
222
+ }
223
+ case ColumnType.LONGBLOB: {
224
+ sqls.push('LONGBLOB');
225
+ break;
226
+ }
227
+ case ColumnType.ENUM: {
228
+ const enumValue = columnType.enums.map(t => `'${t}'`).join(',');
229
+ sqls.push(`ENUM(${enumValue})`);
230
+ if (columnType.characterSet) {
231
+ sqls.push(`CHARACTER SET ${columnType.characterSet}`);
232
+ }
233
+ if (columnType.collate) {
234
+ sqls.push(`COLLATE ${columnType.collate}`);
235
+ }
236
+ break;
237
+ }
238
+ case ColumnType.SET: {
239
+ const enumValue = columnType.enums.map(t => `'${t}'`).join(',');
240
+ sqls.push(`SET(${enumValue})`);
241
+ if (columnType.characterSet) {
242
+ sqls.push(`CHARACTER SET ${columnType.characterSet}`);
243
+ }
244
+ if (columnType.collate) {
245
+ sqls.push(`COLLATE ${columnType.collate}`);
246
+ }
247
+ break;
248
+ }
249
+ case ColumnType.JSON: {
250
+ sqls.push('JSON');
251
+ break;
252
+ }
253
+ case ColumnType.GEOMETRY:
254
+ case ColumnType.POINT:
255
+ case ColumnType.LINESTRING:
256
+ case ColumnType.POLYGON:
257
+ case ColumnType.MULTIPOINT:
258
+ case ColumnType.MULTILINESTRING:
259
+ case ColumnType.MULTIPOLYGON:
260
+ case ColumnType.GEOMETRYCOLLECTION: {
261
+ sqls.push(columnType.type);
262
+ break;
263
+ }
264
+ default: {
265
+ throw new Error(`unknown ColumnType ${columnType}`);
266
+ }
267
+ }
268
+ return sqls.join(' ');
269
+ }
270
+ generateIndex(indexModel) {
271
+ const indexSql = [
272
+ ' ',
273
+ ];
274
+ switch (indexModel.type) {
275
+ case IndexType.INDEX: {
276
+ indexSql.push('KEY');
277
+ break;
278
+ }
279
+ case IndexType.UNIQUE: {
280
+ indexSql.push('UNIQUE KEY');
281
+ break;
282
+ }
283
+ case IndexType.PRIMARY: {
284
+ indexSql.push('PRIMARY KEY');
285
+ break;
286
+ }
287
+ case IndexType.FULLTEXT: {
288
+ indexSql.push('FULLTEXT KEY');
289
+ break;
290
+ }
291
+ case IndexType.SPATIAL: {
292
+ indexSql.push('SPATIAL KEY');
293
+ break;
294
+ }
295
+ default: {
296
+ throw new Error(`unknown IndexType ${indexModel.type}`);
297
+ }
298
+ }
299
+ indexSql.push(indexModel.name);
300
+ indexSql.push(`(${indexModel.keys.map(t => t.columnName).join(',')})`);
301
+ if (indexModel.storeType) {
302
+ indexSql.push(`USING ${indexModel.storeType}`);
303
+ }
304
+ if (indexModel.parser) {
305
+ indexSql.push(`WITH PARSER ${indexModel.parser}`);
306
+ }
307
+ if (indexModel.comment) {
308
+ indexSql.push(`COMMENT '${this.formatComment(indexModel.comment)}'`);
309
+ }
310
+ if (indexModel.engineAttribute) {
311
+ indexSql.push(`ENGINE_ATTRIBUTE='${indexModel.engineAttribute}'`);
312
+ }
313
+ if (indexModel.secondaryEngineAttribute) {
314
+ indexSql.push(`SECONDARY_ENGINE_ATTRIBUTE='${indexModel.secondaryEngineAttribute}'`);
315
+ }
316
+ return indexSql.join(' ');
317
+ }
318
+ generateTableOptions(tableModel) {
319
+ const sqls = [];
320
+ if (tableModel.autoExtendSize) {
321
+ sqls.push(`AUTOEXTEND_SIZE=${tableModel.autoExtendSize}`);
322
+ }
323
+ if (tableModel.autoIncrement) {
324
+ sqls.push(`AUTO_INCREMENT=${tableModel.autoIncrement}`);
325
+ }
326
+ if (tableModel.avgRowLength) {
327
+ sqls.push(`AVG_ROW_LENGTH=${tableModel.avgRowLength}`);
328
+ }
329
+ if (tableModel.characterSet) {
330
+ sqls.push(`DEFAULT CHARACTER SET ${tableModel.characterSet}`);
331
+ }
332
+ if (tableModel.collate) {
333
+ sqls.push(`DEFAULT COLLATE ${tableModel.collate}`);
334
+ }
335
+ if (tableModel.comment) {
336
+ sqls.push(`COMMENT='${this.formatComment(tableModel.comment)}'`);
337
+ }
338
+ if (tableModel.compression) {
339
+ sqls.push(`COMPRESSION='${tableModel.compression}'`);
340
+ }
341
+ if (typeof tableModel.encryption !== 'undefined') {
342
+ sqls.push(`ENCRYPTION='${tableModel.encryption ? 'Y' : 'N'}'`);
343
+ }
344
+ if (typeof tableModel.engine !== 'undefined') {
345
+ sqls.push(`ENGINE=${tableModel.engine}`);
346
+ }
347
+ if (tableModel.engineAttribute) {
348
+ sqls.push(`ENGINE_ATTRIBUTE='${tableModel.engineAttribute}'`);
349
+ }
350
+ if (tableModel.secondaryEngineAttribute) {
351
+ sqls.push(`SECONDARY_ENGINE_ATTRIBUTE = '${tableModel.secondaryEngineAttribute}'`);
352
+ }
353
+ if (tableModel.insertMethod) {
354
+ sqls.push(`INSERT_METHOD=${tableModel.insertMethod}`);
355
+ }
356
+ if (tableModel.keyBlockSize) {
357
+ sqls.push(`KEY_BLOCK_SIZE=${tableModel.keyBlockSize}`);
358
+ }
359
+ if (tableModel.maxRows) {
360
+ sqls.push(`MAX_ROWS=${tableModel.maxRows}`);
361
+ }
362
+ if (tableModel.minRows) {
363
+ sqls.push(`MIN_ROWS=${tableModel.minRows}`);
364
+ }
365
+ if (tableModel.rowFormat) {
366
+ sqls.push(`ROW_FORMAT=${tableModel.rowFormat}`);
367
+ }
368
+ return sqls.join(', ');
369
+ }
370
+ generate(tableModel) {
371
+ const createSql = [];
372
+ createSql.push(`CREATE TABLE IF NOT EXISTS ${tableModel.name} (`);
373
+ const columnSql = [];
374
+ for (const column of tableModel.columns) {
375
+ columnSql.push(this.generateColumn(column));
376
+ }
377
+ const indexSql = [];
378
+ for (const index of tableModel.indices) {
379
+ indexSql.push(this.generateIndex(index));
380
+ }
381
+ if (indexSql.length) {
382
+ createSql.push(columnSql.join(',\n') + ',');
383
+ createSql.push(indexSql.join(',\n'));
384
+ }
385
+ else {
386
+ createSql.push(columnSql.join(',\n'));
387
+ }
388
+ createSql.push(`) ${this.generateTableOptions(tableModel)};`);
389
+ return createSql.join('\n');
390
+ }
391
+ }
392
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SqlGenerator.js","sourceRoot":"","sources":["../src/SqlGenerator.ts"],"names":[],"mappings":"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"}