@eggjs/dal-runtime 4.0.0-beta.34 → 4.0.0-beta.36

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