@mikro-orm/knex 6.0.8-dev.16 → 6.0.8-dev.17

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mikro-orm/knex",
3
- "version": "6.0.8-dev.16",
3
+ "version": "6.0.8-dev.17",
4
4
  "description": "TypeScript ORM for Node.js based on Data Mapper, Unit of Work and Identity Map patterns. Supports MongoDB, MySQL, PostgreSQL and SQLite databases as well as usage with vanilla JavaScript.",
5
5
  "main": "index.js",
6
6
  "module": "index.mjs",
@@ -66,6 +66,6 @@
66
66
  "@mikro-orm/core": "^6.0.7"
67
67
  },
68
68
  "peerDependencies": {
69
- "@mikro-orm/core": "6.0.8-dev.16"
69
+ "@mikro-orm/core": "6.0.8-dev.17"
70
70
  }
71
71
  }
@@ -27,10 +27,11 @@ export declare abstract class SchemaHelper {
27
27
  getDropIndexSQL(tableName: string, index: IndexDef): string;
28
28
  getRenameIndexSQL(tableName: string, index: IndexDef, oldIndexName: string): string;
29
29
  hasNonDefaultPrimaryKeyName(table: DatabaseTable): boolean;
30
- createTableColumn(table: Knex.TableBuilder, column: Column, fromTable: DatabaseTable, changedProperties?: Set<string>): Knex.ColumnBuilder;
30
+ createTableColumn(table: Knex.TableBuilder, column: Column, fromTable: DatabaseTable, changedProperties?: Set<string>, alter?: boolean): Knex.ColumnBuilder;
31
31
  configureColumn(column: Column, col: Knex.ColumnBuilder, knex: Knex, changedProperties?: Set<string>): Knex.ColumnBuilder;
32
32
  configureColumnDefault(column: Column, col: Knex.ColumnBuilder, knex: Knex, changedProperties?: Set<string>): Knex.ColumnBuilder;
33
33
  getPreAlterTable(tableDiff: TableDifference, safe: boolean): string;
34
+ getPostAlterTable(tableDiff: TableDifference, safe: boolean): string;
34
35
  getAlterColumnAutoincrement(tableName: string, column: Column, schemaName?: string): string;
35
36
  getChangeColumnCommentSQL(tableName: string, to: Column, schemaName?: string): string;
36
37
  getNamespaces(connection: AbstractSqlConnection): Promise<string[]>;
@@ -104,7 +104,7 @@ class SchemaHelper {
104
104
  const defaultName = this.platform.getDefaultPrimaryName(table.name, pkIndex.columnNames);
105
105
  return pkIndex?.keyName !== defaultName;
106
106
  }
107
- createTableColumn(table, column, fromTable, changedProperties) {
107
+ createTableColumn(table, column, fromTable, changedProperties, alter) {
108
108
  const compositePK = fromTable.getPrimaryKey()?.composite;
109
109
  if (column.autoincrement && !column.generated && !compositePK && (!changedProperties || changedProperties.has('autoincrement') || changedProperties.has('type'))) {
110
110
  const primaryKey = !changedProperties && !this.hasNonDefaultPrimaryKeyName(fromTable);
@@ -144,6 +144,9 @@ class SchemaHelper {
144
144
  getPreAlterTable(tableDiff, safe) {
145
145
  return '';
146
146
  }
147
+ getPostAlterTable(tableDiff, safe) {
148
+ return '';
149
+ }
147
150
  getAlterColumnAutoincrement(tableName, column, schemaName) {
148
151
  return '';
149
152
  }
@@ -37,6 +37,7 @@ export declare class SqlSchemaGenerator extends AbstractSchemaGenerator<Abstract
37
37
  * We need to drop foreign keys first for all tables to allow dropping PK constraints.
38
38
  */
39
39
  private preAlterTable;
40
+ private postAlterTable;
40
41
  private splitTableName;
41
42
  private alterTable;
42
43
  /**
@@ -188,7 +188,7 @@ class SqlSchemaGenerator extends core_1.AbstractSchemaGenerator {
188
188
  }
189
189
  }
190
190
  for (const newTable of Object.values(schemaDiff.newTables)) {
191
- ret += await this.dump(this.createTable(newTable));
191
+ ret += await this.dump(this.createTable(newTable, true));
192
192
  }
193
193
  for (const newTable of Object.values(schemaDiff.newTables)) {
194
194
  ret += await this.dump(this.createSchemaBuilder(newTable.schema).alterTable(newTable.name, table => {
@@ -210,6 +210,11 @@ class SqlSchemaGenerator extends core_1.AbstractSchemaGenerator {
210
210
  ret += await this.dump(builder);
211
211
  }
212
212
  }
213
+ for (const changedTable of Object.values(schemaDiff.changedTables)) {
214
+ for (const builder of this.postAlterTable(changedTable, options.safe)) {
215
+ ret += await this.dump(builder);
216
+ }
217
+ }
213
218
  if (options.dropTables && !options.safe) {
214
219
  for (const removedNamespace of schemaDiff.removedNamespaces) {
215
220
  ret += await this.dump(this.knex.schema.dropSchema(removedNamespace));
@@ -263,6 +268,12 @@ class SqlSchemaGenerator extends core_1.AbstractSchemaGenerator {
263
268
  }));
264
269
  return ret;
265
270
  }
271
+ postAlterTable(diff, safe) {
272
+ const ret = [];
273
+ const push = (sql) => sql ? ret.push(this.knex.schema.raw(sql)) : undefined;
274
+ push(this.helper.getPostAlterTable(diff, safe));
275
+ return ret;
276
+ }
266
277
  splitTableName(name) {
267
278
  const parts = name.split('.');
268
279
  const tableName = parts.pop();
@@ -272,11 +283,19 @@ class SqlSchemaGenerator extends core_1.AbstractSchemaGenerator {
272
283
  alterTable(diff, safe) {
273
284
  const ret = [];
274
285
  const [schemaName, tableName] = this.splitTableName(diff.name);
275
- const changedNativeEnums = [];
276
- for (const { column, changedProperties } of Object.values(diff.changedColumns)) {
277
- if (column.nativeEnumName && changedProperties.has('enumItems') && column.nativeEnumName in diff.fromTable.nativeEnums) {
278
- changedNativeEnums.push([column.nativeEnumName, column.enumItems, diff.fromTable.getColumn(column.name).enumItems]);
286
+ if (this.platform.supportsNativeEnums()) {
287
+ const changedNativeEnums = [];
288
+ for (const { column, changedProperties } of Object.values(diff.changedColumns)) {
289
+ if (column.nativeEnumName && changedProperties.has('enumItems') && column.nativeEnumName in diff.fromTable.nativeEnums) {
290
+ changedNativeEnums.push([column.nativeEnumName, column.enumItems, diff.fromTable.getColumn(column.name).enumItems]);
291
+ }
279
292
  }
293
+ core_1.Utils.removeDuplicates(changedNativeEnums).forEach(([enumName, itemsNew, itemsOld]) => {
294
+ // postgres allows only adding new items, the values are case insensitive
295
+ itemsOld = itemsOld.map(v => v.toLowerCase());
296
+ const newItems = itemsNew.filter(val => !itemsOld.includes(val.toLowerCase()));
297
+ ret.push(...newItems.map(val => this.knex.schema.raw(this.helper.getAlterNativeEnumSQL(enumName, schemaName, val))));
298
+ });
280
299
  }
281
300
  ret.push(this.createSchemaBuilder(schemaName).alterTable(tableName, table => {
282
301
  for (const index of Object.values(diff.removedIndexes)) {
@@ -300,7 +319,7 @@ class SqlSchemaGenerator extends core_1.AbstractSchemaGenerator {
300
319
  }));
301
320
  ret.push(this.createSchemaBuilder(schemaName).alterTable(tableName, table => {
302
321
  for (const column of Object.values(diff.addedColumns)) {
303
- const col = this.helper.createTableColumn(table, column, diff.fromTable);
322
+ const col = this.helper.createTableColumn(table, column, diff.fromTable, undefined, true);
304
323
  this.helper.configureColumn(column, col, this.knex);
305
324
  const foreignKey = Object.values(diff.addedForeignKeys).find(fk => fk.columnNames.length === 1 && fk.columnNames[0] === column.name);
306
325
  if (foreignKey && this.options.createForeignKeyConstraints) {
@@ -319,7 +338,7 @@ class SqlSchemaGenerator extends core_1.AbstractSchemaGenerator {
319
338
  if (changedProperties.size === 1 && changedProperties.has('enumItems') && column.nativeEnumName) {
320
339
  continue;
321
340
  }
322
- const col = this.helper.createTableColumn(table, column, diff.fromTable, changedProperties).alter();
341
+ const col = this.helper.createTableColumn(table, column, diff.fromTable, changedProperties, true).alter();
323
342
  this.helper.configureColumn(column, col, this.knex, changedProperties);
324
343
  }
325
344
  for (const { column } of Object.values(diff.changedColumns).filter(diff => diff.changedProperties.has('autoincrement'))) {
@@ -366,13 +385,6 @@ class SqlSchemaGenerator extends core_1.AbstractSchemaGenerator {
366
385
  table.comment(comment);
367
386
  }
368
387
  }));
369
- if (this.platform.supportsNativeEnums()) {
370
- changedNativeEnums.forEach(([enumName, itemsNew, itemsOld]) => {
371
- // postgres allows only adding new items
372
- const newItems = itemsNew.filter(val => !itemsOld.includes(val));
373
- ret.push(...newItems.map(val => this.knex.schema.raw(this.helper.getAlterNativeEnumSQL(enumName, schemaName, val))));
374
- });
375
- }
376
388
  return ret;
377
389
  }
378
390
  /**
@@ -422,10 +434,10 @@ class SqlSchemaGenerator extends core_1.AbstractSchemaGenerator {
422
434
  }
423
435
  return builder;
424
436
  }
425
- createTable(tableDef) {
437
+ createTable(tableDef, alter) {
426
438
  return this.createSchemaBuilder(tableDef.schema).createTable(tableDef.name, table => {
427
439
  tableDef.getColumns().forEach(column => {
428
- const col = this.helper.createTableColumn(table, column, tableDef);
440
+ const col = this.helper.createTableColumn(table, column, tableDef, undefined, alter);
429
441
  this.helper.configureColumn(column, col, this.knex);
430
442
  });
431
443
  for (const index of tableDef.getIndexes()) {