typeorm 0.2.40-dev.e80f97d → 0.2.41-dev.2d0abe7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (101) hide show
  1. package/browser/cache/DbQueryResultCache.js +12 -3
  2. package/browser/cache/DbQueryResultCache.js.map +1 -1
  3. package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.js +33 -39
  4. package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.js.map +1 -1
  5. package/browser/driver/cockroachdb/CockroachQueryRunner.js +24 -30
  6. package/browser/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  7. package/browser/driver/mongodb/MongoConnectionOptions.d.ts +4 -0
  8. package/browser/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  9. package/browser/driver/mongodb/MongoQueryRunner.d.ts +2 -0
  10. package/browser/driver/mongodb/MongoQueryRunner.js +3 -0
  11. package/browser/driver/mongodb/MongoQueryRunner.js.map +1 -1
  12. package/browser/driver/mysql/MysqlQueryRunner.js +37 -39
  13. package/browser/driver/mysql/MysqlQueryRunner.js.map +1 -1
  14. package/browser/driver/oracle/OracleDriver.js +1 -1
  15. package/browser/driver/oracle/OracleDriver.js.map +1 -1
  16. package/browser/driver/oracle/OracleQueryRunner.js +13 -24
  17. package/browser/driver/oracle/OracleQueryRunner.js.map +1 -1
  18. package/browser/driver/postgres/PostgresDriver.d.ts +1 -0
  19. package/browser/driver/postgres/PostgresDriver.js +16 -7
  20. package/browser/driver/postgres/PostgresDriver.js.map +1 -1
  21. package/browser/driver/postgres/PostgresQueryRunner.d.ts +5 -0
  22. package/browser/driver/postgres/PostgresQueryRunner.js +314 -135
  23. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  24. package/browser/driver/sap/SapQueryRunner.js +36 -42
  25. package/browser/driver/sap/SapQueryRunner.js.map +1 -1
  26. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +8 -14
  27. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  28. package/browser/driver/sqlserver/SqlServerQueryRunner.js +31 -33
  29. package/browser/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  30. package/browser/driver/types/MetadataTableType.d.ts +5 -0
  31. package/browser/driver/types/MetadataTableType.js +8 -0
  32. package/browser/driver/types/MetadataTableType.js.map +1 -0
  33. package/browser/find-options/FindTreeOptions.d.ts +5 -1
  34. package/browser/find-options/FindTreeOptions.js.map +1 -1
  35. package/browser/migration/MigrationExecutor.js +55 -48
  36. package/browser/migration/MigrationExecutor.js.map +1 -1
  37. package/browser/query-runner/BaseQueryRunner.d.ts +23 -0
  38. package/browser/query-runner/BaseQueryRunner.js +37 -0
  39. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  40. package/browser/query-runner/QueryRunner.d.ts +5 -0
  41. package/browser/query-runner/QueryRunner.js.map +1 -1
  42. package/browser/repository/FindTreesOptions.d.ts +9 -0
  43. package/browser/repository/FindTreesOptions.js +3 -0
  44. package/browser/repository/FindTreesOptions.js.map +1 -0
  45. package/browser/repository/TreeRepository.d.ts +4 -1
  46. package/browser/repository/TreeRepository.js +8 -4
  47. package/browser/repository/TreeRepository.js.map +1 -1
  48. package/browser/schema-builder/RdbmsSchemaBuilder.d.ts +5 -1
  49. package/browser/schema-builder/RdbmsSchemaBuilder.js +58 -49
  50. package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  51. package/cache/DbQueryResultCache.js +12 -3
  52. package/cache/DbQueryResultCache.js.map +1 -1
  53. package/driver/aurora-data-api/AuroraDataApiQueryRunner.js +33 -39
  54. package/driver/aurora-data-api/AuroraDataApiQueryRunner.js.map +1 -1
  55. package/driver/cockroachdb/CockroachQueryRunner.js +24 -30
  56. package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  57. package/driver/mongodb/MongoConnectionOptions.d.ts +4 -0
  58. package/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  59. package/driver/mongodb/MongoQueryRunner.d.ts +2 -0
  60. package/driver/mongodb/MongoQueryRunner.js +3 -0
  61. package/driver/mongodb/MongoQueryRunner.js.map +1 -1
  62. package/driver/mysql/MysqlQueryRunner.js +37 -39
  63. package/driver/mysql/MysqlQueryRunner.js.map +1 -1
  64. package/driver/oracle/OracleDriver.js +1 -1
  65. package/driver/oracle/OracleDriver.js.map +1 -1
  66. package/driver/oracle/OracleQueryRunner.js +13 -24
  67. package/driver/oracle/OracleQueryRunner.js.map +1 -1
  68. package/driver/postgres/PostgresDriver.d.ts +1 -0
  69. package/driver/postgres/PostgresDriver.js +16 -7
  70. package/driver/postgres/PostgresDriver.js.map +1 -1
  71. package/driver/postgres/PostgresQueryRunner.d.ts +5 -0
  72. package/driver/postgres/PostgresQueryRunner.js +314 -135
  73. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  74. package/driver/sap/SapQueryRunner.js +36 -42
  75. package/driver/sap/SapQueryRunner.js.map +1 -1
  76. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +8 -14
  77. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  78. package/driver/sqlserver/SqlServerQueryRunner.js +31 -33
  79. package/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  80. package/driver/types/MetadataTableType.d.ts +5 -0
  81. package/driver/types/MetadataTableType.js +11 -0
  82. package/driver/types/MetadataTableType.js.map +1 -0
  83. package/find-options/FindTreeOptions.d.ts +5 -1
  84. package/find-options/FindTreeOptions.js.map +1 -1
  85. package/migration/MigrationExecutor.js +55 -48
  86. package/migration/MigrationExecutor.js.map +1 -1
  87. package/package.json +1 -1
  88. package/query-runner/BaseQueryRunner.d.ts +23 -0
  89. package/query-runner/BaseQueryRunner.js +37 -0
  90. package/query-runner/BaseQueryRunner.js.map +1 -1
  91. package/query-runner/QueryRunner.d.ts +5 -0
  92. package/query-runner/QueryRunner.js.map +1 -1
  93. package/repository/FindTreesOptions.d.ts +9 -0
  94. package/repository/FindTreesOptions.js +4 -0
  95. package/repository/FindTreesOptions.js.map +1 -0
  96. package/repository/TreeRepository.d.ts +4 -1
  97. package/repository/TreeRepository.js +7 -3
  98. package/repository/TreeRepository.js.map +1 -1
  99. package/schema-builder/RdbmsSchemaBuilder.d.ts +5 -1
  100. package/schema-builder/RdbmsSchemaBuilder.js +58 -49
  101. package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
@@ -21,6 +21,7 @@ var Query_1 = require("../Query");
21
21
  var MssqlParameter_1 = require("./MssqlParameter");
22
22
  var error_1 = require("../../error");
23
23
  var QueryLock_1 = require("../../query-runner/QueryLock");
24
+ var MetadataTableType_1 = require("../types/MetadataTableType");
24
25
  /**
25
26
  * Runs queries on a single SQL Server database connection.
26
27
  */
@@ -2141,7 +2142,7 @@ var SqlServerQueryRunner = /** @class */ (function (_super) {
2141
2142
  }).join(" OR ");
2142
2143
  query = dbNames.map(function (dbName) {
2143
2144
  return "SELECT \"T\".*, \"V\".\"CHECK_OPTION\" FROM " + _this.escapePath(_this.getTypeormMetadataTableName()) + " \"t\" " +
2144
- ("INNER JOIN \"" + dbName + "\".\"INFORMATION_SCHEMA\".\"VIEWS\" \"V\" ON \"V\".\"TABLE_SCHEMA\" = \"T\".\"SCHEMA\" AND \"v\".\"TABLE_NAME\" = \"T\".\"NAME\" WHERE \"T\".\"TYPE\" = 'VIEW' " + (viewsCondition ? "AND (" + viewsCondition + ")" : ""));
2145
+ ("INNER JOIN \"" + dbName + "\".\"INFORMATION_SCHEMA\".\"VIEWS\" \"V\" ON \"V\".\"TABLE_SCHEMA\" = \"T\".\"SCHEMA\" AND \"v\".\"TABLE_NAME\" = \"T\".\"NAME\" WHERE \"T\".\"TYPE\" = '" + MetadataTableType_1.MetadataTableType.VIEW + "' " + (viewsCondition ? "AND (" + viewsCondition + ")" : ""));
2145
2146
  }).join(" UNION ALL ");
2146
2147
  return [4 /*yield*/, this.query(query)];
2147
2148
  case 4:
@@ -2352,14 +2353,14 @@ var SqlServerQueryRunner = /** @class */ (function (_super) {
2352
2353
  dbConstraint["TABLE_SCHEMA"] === dbColumn["TABLE_SCHEMA"] &&
2353
2354
  dbConstraint["TABLE_CATALOG"] === dbColumn["TABLE_CATALOG"] &&
2354
2355
  dbConstraint["COLUMN_NAME"] === dbColumn["COLUMN_NAME"]); });
2355
- var uniqueConstraint = columnConstraints.find(function (constraint) { return constraint["CONSTRAINT_TYPE"] === "UNIQUE"; });
2356
- var isConstraintComposite = uniqueConstraint
2357
- ? !!dbConstraints.find(function (dbConstraint) { return dbConstraint["CONSTRAINT_TYPE"] === "UNIQUE"
2356
+ var uniqueConstraints = columnConstraints.filter(function (constraint) { return constraint["CONSTRAINT_TYPE"] === "UNIQUE"; });
2357
+ var isConstraintComposite = uniqueConstraints.every(function (uniqueConstraint) {
2358
+ return dbConstraints.some(function (dbConstraint) { return dbConstraint["CONSTRAINT_TYPE"] === "UNIQUE"
2358
2359
  && dbConstraint["CONSTRAINT_NAME"] === uniqueConstraint["CONSTRAINT_NAME"]
2359
2360
  && dbConstraint["TABLE_SCHEMA"] === dbColumn["TABLE_SCHEMA"]
2360
2361
  && dbConstraint["TABLE_CATALOG"] === dbColumn["TABLE_CATALOG"]
2361
- && dbConstraint["COLUMN_NAME"] !== dbColumn["COLUMN_NAME"]; })
2362
- : false;
2362
+ && dbConstraint["COLUMN_NAME"] !== dbColumn["COLUMN_NAME"]; });
2363
+ });
2363
2364
  var isPrimary = !!columnConstraints.find(function (constraint) { return constraint["CONSTRAINT_TYPE"] === "PRIMARY KEY"; });
2364
2365
  var isGenerated = !!dbIdentityColumns.find(function (column) { return (column["TABLE_NAME"] === dbColumn["TABLE_NAME"] &&
2365
2366
  column["TABLE_SCHEMA"] === dbColumn["TABLE_SCHEMA"] &&
@@ -2419,7 +2420,7 @@ var SqlServerQueryRunner = /** @class */ (function (_super) {
2419
2420
  : undefined;
2420
2421
  tableColumn.isNullable = dbColumn["IS_NULLABLE"] === "YES";
2421
2422
  tableColumn.isPrimary = isPrimary;
2422
- tableColumn.isUnique = !!uniqueConstraint && !isConstraintComposite;
2423
+ tableColumn.isUnique = uniqueConstraints.length > 0 && !isConstraintComposite;
2423
2424
  tableColumn.isGenerated = isGenerated;
2424
2425
  if (isGenerated)
2425
2426
  tableColumn.generationStrategy = "increment";
@@ -2586,25 +2587,26 @@ var SqlServerQueryRunner = /** @class */ (function (_super) {
2586
2587
  };
2587
2588
  SqlServerQueryRunner.prototype.insertViewDefinitionSql = function (view) {
2588
2589
  return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
2589
- var parsedTableName, _a, expression, _b, query, parameters;
2590
- return (0, tslib_1.__generator)(this, function (_c) {
2591
- switch (_c.label) {
2590
+ var parsedTableName, _a, expression;
2591
+ return (0, tslib_1.__generator)(this, function (_b) {
2592
+ switch (_b.label) {
2592
2593
  case 0:
2593
2594
  parsedTableName = this.driver.parseTableName(view);
2594
2595
  if (!!parsedTableName.schema) return [3 /*break*/, 2];
2595
2596
  _a = parsedTableName;
2596
2597
  return [4 /*yield*/, this.getCurrentSchema()];
2597
2598
  case 1:
2598
- _a.schema = _c.sent();
2599
- _c.label = 2;
2599
+ _a.schema = _b.sent();
2600
+ _b.label = 2;
2600
2601
  case 2:
2601
2602
  expression = typeof view.expression === "string" ? view.expression.trim() : view.expression(this.connection).getQuery();
2602
- _b = (0, tslib_1.__read)(this.connection.createQueryBuilder()
2603
- .insert()
2604
- .into(this.getTypeormMetadataTableName())
2605
- .values({ type: "VIEW", database: parsedTableName.database, schema: parsedTableName.schema, name: parsedTableName.tableName, value: expression })
2606
- .getQueryAndParameters(), 2), query = _b[0], parameters = _b[1];
2607
- return [2 /*return*/, new Query_1.Query(query, parameters)];
2603
+ return [2 /*return*/, this.insertTypeormMetadataSql({
2604
+ type: MetadataTableType_1.MetadataTableType.VIEW,
2605
+ database: parsedTableName.database,
2606
+ schema: parsedTableName.schema,
2607
+ name: parsedTableName.tableName,
2608
+ value: expression
2609
+ })];
2608
2610
  }
2609
2611
  });
2610
2612
  });
@@ -2620,27 +2622,23 @@ var SqlServerQueryRunner = /** @class */ (function (_super) {
2620
2622
  */
2621
2623
  SqlServerQueryRunner.prototype.deleteViewDefinitionSql = function (viewOrPath) {
2622
2624
  return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
2623
- var parsedTableName, _a, qb, _b, query, parameters;
2624
- return (0, tslib_1.__generator)(this, function (_c) {
2625
- switch (_c.label) {
2625
+ var parsedTableName, _a;
2626
+ return (0, tslib_1.__generator)(this, function (_b) {
2627
+ switch (_b.label) {
2626
2628
  case 0:
2627
2629
  parsedTableName = this.driver.parseTableName(viewOrPath);
2628
2630
  if (!!parsedTableName.schema) return [3 /*break*/, 2];
2629
2631
  _a = parsedTableName;
2630
2632
  return [4 /*yield*/, this.getCurrentSchema()];
2631
2633
  case 1:
2632
- _a.schema = _c.sent();
2633
- _c.label = 2;
2634
- case 2:
2635
- qb = this.connection.createQueryBuilder();
2636
- _b = (0, tslib_1.__read)(qb.delete()
2637
- .from(this.getTypeormMetadataTableName())
2638
- .where(qb.escape("type") + " = 'VIEW'")
2639
- .andWhere(qb.escape("database") + " = :database", { database: parsedTableName.database })
2640
- .andWhere(qb.escape("schema") + " = :schema", { schema: parsedTableName.schema })
2641
- .andWhere(qb.escape("name") + " = :name", { name: parsedTableName.tableName })
2642
- .getQueryAndParameters(), 2), query = _b[0], parameters = _b[1];
2643
- return [2 /*return*/, new Query_1.Query(query, parameters)];
2634
+ _a.schema = _b.sent();
2635
+ _b.label = 2;
2636
+ case 2: return [2 /*return*/, this.deleteTypeormMetadataSql({
2637
+ type: MetadataTableType_1.MetadataTableType.VIEW,
2638
+ database: parsedTableName.database,
2639
+ schema: parsedTableName.schema,
2640
+ name: parsedTableName.tableName
2641
+ })];
2644
2642
  }
2645
2643
  });
2646
2644
  });