typeorm 0.2.40-dev.ae858ad → 0.2.41-dev.15ad5ac

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 (203) hide show
  1. package/browser/cache/DbQueryResultCache.js +12 -3
  2. package/browser/cache/DbQueryResultCache.js.map +1 -1
  3. package/browser/decorator/columns/PrimaryGeneratedColumn.d.ts +1 -0
  4. package/browser/decorator/columns/PrimaryGeneratedColumn.js +1 -1
  5. package/browser/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  6. package/browser/decorator/options/ColumnCommonOptions.d.ts +1 -1
  7. package/browser/decorator/options/ColumnCommonOptions.js.map +1 -1
  8. package/browser/driver/Driver.d.ts +5 -0
  9. package/browser/driver/Driver.js.map +1 -1
  10. package/browser/driver/aurora-data-api/AuroraDataApiDriver.d.ts +4 -0
  11. package/browser/driver/aurora-data-api/AuroraDataApiDriver.js +4 -0
  12. package/browser/driver/aurora-data-api/AuroraDataApiDriver.js.map +1 -1
  13. package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.js +33 -39
  14. package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.js.map +1 -1
  15. package/browser/driver/cockroachdb/CockroachDriver.d.ts +4 -0
  16. package/browser/driver/cockroachdb/CockroachDriver.js +4 -0
  17. package/browser/driver/cockroachdb/CockroachDriver.js.map +1 -1
  18. package/browser/driver/cockroachdb/CockroachQueryRunner.js +24 -30
  19. package/browser/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  20. package/browser/driver/mongodb/MongoConnectionOptions.d.ts +4 -0
  21. package/browser/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  22. package/browser/driver/mongodb/MongoQueryRunner.d.ts +2 -0
  23. package/browser/driver/mongodb/MongoQueryRunner.js +3 -0
  24. package/browser/driver/mongodb/MongoQueryRunner.js.map +1 -1
  25. package/browser/driver/mysql/MysqlDriver.d.ts +4 -0
  26. package/browser/driver/mysql/MysqlDriver.js +10 -3
  27. package/browser/driver/mysql/MysqlDriver.js.map +1 -1
  28. package/browser/driver/mysql/MysqlQueryRunner.js +37 -39
  29. package/browser/driver/mysql/MysqlQueryRunner.js.map +1 -1
  30. package/browser/driver/oracle/OracleDriver.js +1 -1
  31. package/browser/driver/oracle/OracleDriver.js.map +1 -1
  32. package/browser/driver/oracle/OracleQueryRunner.js +13 -24
  33. package/browser/driver/oracle/OracleQueryRunner.js.map +1 -1
  34. package/browser/driver/postgres/PostgresDriver.d.ts +5 -0
  35. package/browser/driver/postgres/PostgresDriver.js +20 -7
  36. package/browser/driver/postgres/PostgresDriver.js.map +1 -1
  37. package/browser/driver/postgres/PostgresQueryRunner.d.ts +5 -0
  38. package/browser/driver/postgres/PostgresQueryRunner.js +333 -143
  39. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  40. package/browser/driver/sap/SapQueryRunner.js +36 -42
  41. package/browser/driver/sap/SapQueryRunner.js.map +1 -1
  42. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.d.ts +4 -0
  43. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js +4 -0
  44. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  45. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +8 -14
  46. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  47. package/browser/driver/sqlserver/SqlServerQueryRunner.js +31 -33
  48. package/browser/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  49. package/browser/driver/types/MetadataTableType.d.ts +5 -0
  50. package/browser/driver/types/MetadataTableType.js +8 -0
  51. package/browser/driver/types/MetadataTableType.js.map +1 -0
  52. package/browser/driver/types/UpsertType.d.ts +1 -0
  53. package/browser/driver/types/UpsertType.js +3 -0
  54. package/browser/driver/types/UpsertType.js.map +1 -0
  55. package/browser/entity-manager/EntityManager.d.ts +2 -0
  56. package/browser/entity-manager/EntityManager.js +42 -1
  57. package/browser/entity-manager/EntityManager.js.map +1 -1
  58. package/browser/find-options/FindConditions.d.ts +6 -2
  59. package/browser/find-options/FindConditions.js.map +1 -1
  60. package/browser/find-options/FindTreeOptions.d.ts +5 -1
  61. package/browser/find-options/FindTreeOptions.js.map +1 -1
  62. package/browser/metadata/EntityMetadata.d.ts +4 -0
  63. package/browser/metadata/EntityMetadata.js +14 -0
  64. package/browser/metadata/EntityMetadata.js.map +1 -1
  65. package/browser/migration/MigrationExecutor.js +55 -48
  66. package/browser/migration/MigrationExecutor.js.map +1 -1
  67. package/browser/query-builder/InsertQueryBuilder.js +8 -2
  68. package/browser/query-builder/InsertQueryBuilder.js.map +1 -1
  69. package/browser/query-builder/SelectQueryBuilder.d.ts +1 -1
  70. package/browser/query-builder/SelectQueryBuilder.js +4 -20
  71. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  72. package/browser/query-runner/BaseQueryRunner.d.ts +23 -0
  73. package/browser/query-runner/BaseQueryRunner.js +37 -0
  74. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  75. package/browser/query-runner/QueryRunner.d.ts +5 -0
  76. package/browser/query-runner/QueryRunner.js.map +1 -1
  77. package/browser/repository/BaseEntity.d.ts +7 -0
  78. package/browser/repository/BaseEntity.js +8 -0
  79. package/browser/repository/BaseEntity.js.map +1 -1
  80. package/browser/repository/FindTreesOptions.d.ts +9 -0
  81. package/browser/repository/FindTreesOptions.js +3 -0
  82. package/browser/repository/FindTreesOptions.js.map +1 -0
  83. package/browser/repository/Repository.d.ts +7 -0
  84. package/browser/repository/Repository.js +8 -0
  85. package/browser/repository/Repository.js.map +1 -1
  86. package/browser/repository/TreeRepository.d.ts +4 -1
  87. package/browser/repository/TreeRepository.js +8 -4
  88. package/browser/repository/TreeRepository.js.map +1 -1
  89. package/browser/repository/UpsertOptions.d.ts +6 -0
  90. package/browser/repository/UpsertOptions.js +3 -0
  91. package/browser/repository/UpsertOptions.js.map +1 -0
  92. package/browser/schema-builder/RdbmsSchemaBuilder.d.ts +5 -1
  93. package/browser/schema-builder/RdbmsSchemaBuilder.js +58 -49
  94. package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  95. package/browser/schema-builder/options/TableColumnOptions.d.ts +1 -1
  96. package/browser/schema-builder/options/TableColumnOptions.js.map +1 -1
  97. package/browser/schema-builder/table/TableColumn.d.ts +1 -1
  98. package/browser/schema-builder/table/TableColumn.js.map +1 -1
  99. package/browser/util/OrmUtils.d.ts +1 -0
  100. package/browser/util/OrmUtils.js +11 -0
  101. package/browser/util/OrmUtils.js.map +1 -1
  102. package/cache/DbQueryResultCache.js +12 -3
  103. package/cache/DbQueryResultCache.js.map +1 -1
  104. package/decorator/columns/PrimaryGeneratedColumn.d.ts +1 -0
  105. package/decorator/columns/PrimaryGeneratedColumn.js +1 -1
  106. package/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  107. package/decorator/options/ColumnCommonOptions.d.ts +1 -1
  108. package/decorator/options/ColumnCommonOptions.js.map +1 -1
  109. package/driver/Driver.d.ts +5 -0
  110. package/driver/Driver.js.map +1 -1
  111. package/driver/aurora-data-api/AuroraDataApiDriver.d.ts +4 -0
  112. package/driver/aurora-data-api/AuroraDataApiDriver.js +4 -0
  113. package/driver/aurora-data-api/AuroraDataApiDriver.js.map +1 -1
  114. package/driver/aurora-data-api/AuroraDataApiQueryRunner.js +33 -39
  115. package/driver/aurora-data-api/AuroraDataApiQueryRunner.js.map +1 -1
  116. package/driver/cockroachdb/CockroachDriver.d.ts +4 -0
  117. package/driver/cockroachdb/CockroachDriver.js +4 -0
  118. package/driver/cockroachdb/CockroachDriver.js.map +1 -1
  119. package/driver/cockroachdb/CockroachQueryRunner.js +24 -30
  120. package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  121. package/driver/mongodb/MongoConnectionOptions.d.ts +4 -0
  122. package/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  123. package/driver/mongodb/MongoQueryRunner.d.ts +2 -0
  124. package/driver/mongodb/MongoQueryRunner.js +3 -0
  125. package/driver/mongodb/MongoQueryRunner.js.map +1 -1
  126. package/driver/mysql/MysqlDriver.d.ts +4 -0
  127. package/driver/mysql/MysqlDriver.js +10 -3
  128. package/driver/mysql/MysqlDriver.js.map +1 -1
  129. package/driver/mysql/MysqlQueryRunner.js +37 -39
  130. package/driver/mysql/MysqlQueryRunner.js.map +1 -1
  131. package/driver/oracle/OracleDriver.js +1 -1
  132. package/driver/oracle/OracleDriver.js.map +1 -1
  133. package/driver/oracle/OracleQueryRunner.js +13 -24
  134. package/driver/oracle/OracleQueryRunner.js.map +1 -1
  135. package/driver/postgres/PostgresDriver.d.ts +5 -0
  136. package/driver/postgres/PostgresDriver.js +20 -7
  137. package/driver/postgres/PostgresDriver.js.map +1 -1
  138. package/driver/postgres/PostgresQueryRunner.d.ts +5 -0
  139. package/driver/postgres/PostgresQueryRunner.js +333 -143
  140. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  141. package/driver/sap/SapQueryRunner.js +36 -42
  142. package/driver/sap/SapQueryRunner.js.map +1 -1
  143. package/driver/sqlite-abstract/AbstractSqliteDriver.d.ts +4 -0
  144. package/driver/sqlite-abstract/AbstractSqliteDriver.js +4 -0
  145. package/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  146. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +8 -14
  147. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  148. package/driver/sqlserver/SqlServerQueryRunner.js +31 -33
  149. package/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  150. package/driver/types/MetadataTableType.d.ts +5 -0
  151. package/driver/types/MetadataTableType.js +11 -0
  152. package/driver/types/MetadataTableType.js.map +1 -0
  153. package/driver/types/UpsertType.d.ts +1 -0
  154. package/driver/types/UpsertType.js +4 -0
  155. package/driver/types/UpsertType.js.map +1 -0
  156. package/entity-manager/EntityManager.d.ts +2 -0
  157. package/entity-manager/EntityManager.js +41 -0
  158. package/entity-manager/EntityManager.js.map +1 -1
  159. package/find-options/FindConditions.d.ts +6 -2
  160. package/find-options/FindConditions.js.map +1 -1
  161. package/find-options/FindTreeOptions.d.ts +5 -1
  162. package/find-options/FindTreeOptions.js.map +1 -1
  163. package/metadata/EntityMetadata.d.ts +4 -0
  164. package/metadata/EntityMetadata.js +14 -0
  165. package/metadata/EntityMetadata.js.map +1 -1
  166. package/migration/MigrationExecutor.js +55 -48
  167. package/migration/MigrationExecutor.js.map +1 -1
  168. package/package.json +1 -1
  169. package/query-builder/InsertQueryBuilder.js +11 -5
  170. package/query-builder/InsertQueryBuilder.js.map +1 -1
  171. package/query-builder/SelectQueryBuilder.d.ts +1 -1
  172. package/query-builder/SelectQueryBuilder.js +4 -20
  173. package/query-builder/SelectQueryBuilder.js.map +1 -1
  174. package/query-runner/BaseQueryRunner.d.ts +23 -0
  175. package/query-runner/BaseQueryRunner.js +37 -0
  176. package/query-runner/BaseQueryRunner.js.map +1 -1
  177. package/query-runner/QueryRunner.d.ts +5 -0
  178. package/query-runner/QueryRunner.js.map +1 -1
  179. package/repository/BaseEntity.d.ts +7 -0
  180. package/repository/BaseEntity.js +8 -0
  181. package/repository/BaseEntity.js.map +1 -1
  182. package/repository/FindTreesOptions.d.ts +9 -0
  183. package/repository/FindTreesOptions.js +4 -0
  184. package/repository/FindTreesOptions.js.map +1 -0
  185. package/repository/Repository.d.ts +7 -0
  186. package/repository/Repository.js +8 -0
  187. package/repository/Repository.js.map +1 -1
  188. package/repository/TreeRepository.d.ts +4 -1
  189. package/repository/TreeRepository.js +7 -3
  190. package/repository/TreeRepository.js.map +1 -1
  191. package/repository/UpsertOptions.d.ts +6 -0
  192. package/repository/UpsertOptions.js +4 -0
  193. package/repository/UpsertOptions.js.map +1 -0
  194. package/schema-builder/RdbmsSchemaBuilder.d.ts +5 -1
  195. package/schema-builder/RdbmsSchemaBuilder.js +58 -49
  196. package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  197. package/schema-builder/options/TableColumnOptions.d.ts +1 -1
  198. package/schema-builder/options/TableColumnOptions.js.map +1 -1
  199. package/schema-builder/table/TableColumn.d.ts +1 -1
  200. package/schema-builder/table/TableColumn.js.map +1 -1
  201. package/util/OrmUtils.d.ts +1 -0
  202. package/util/OrmUtils.js +11 -0
  203. package/util/OrmUtils.js.map +1 -1
@@ -14,6 +14,7 @@ import { TableUnique } from "../../schema-builder/table/TableUnique";
14
14
  import { BaseQueryRunner } from "../../query-runner/BaseQueryRunner";
15
15
  import { Broadcaster } from "../../subscriber/Broadcaster";
16
16
  import { TypeORMError } from "../../error";
17
+ import { MetadataTableType } from "../types/MetadataTableType";
17
18
  /**
18
19
  * Runs queries on a single mysql database connection.
19
20
  */
@@ -1655,7 +1656,7 @@ var AuroraDataApiQueryRunner = /** @class */ (function (_super) {
1655
1656
  return "(`t`.`schema` = '" + database + "' AND `t`.`name` = '" + name + "')";
1656
1657
  }).join(" OR ");
1657
1658
  query = "SELECT `t`.*, `v`.`check_option` FROM " + this.escapePath(this.getTypeormMetadataTableName()) + " `t` " +
1658
- ("INNER JOIN `information_schema`.`views` `v` ON `v`.`table_schema` = `t`.`schema` AND `v`.`table_name` = `t`.`name` WHERE `t`.`type` = 'VIEW' " + (viewsCondition ? "AND (" + viewsCondition + ")" : ""));
1659
+ ("INNER JOIN `information_schema`.`views` `v` ON `v`.`table_schema` = `t`.`schema` AND `v`.`table_name` = `t`.`name` WHERE `t`.`type` = '" + MetadataTableType.VIEW + "' " + (viewsCondition ? "AND (" + viewsCondition + ")" : ""));
1659
1660
  return [4 /*yield*/, this.query(query)];
1660
1661
  case 3:
1661
1662
  dbViews = _a.sent();
@@ -1767,23 +1768,23 @@ var AuroraDataApiQueryRunner = /** @class */ (function (_super) {
1767
1768
  table.columns = dbColumns
1768
1769
  .filter(function (dbColumn) { return dbColumn["TABLE_NAME"] === dbTable["TABLE_NAME"] && dbColumn["TABLE_SCHEMA"] === dbTable["TABLE_SCHEMA"]; })
1769
1770
  .map(function (dbColumn) {
1770
- var columnUniqueIndex = dbIndices.find(function (dbIndex) {
1771
- if (dbIndex["TABLE_NAME"] !== dbTable["TABLE_NAME"] || dbIndex["TABLE_SCHEMA"] !== dbTable["TABLE_SCHEMA"]) {
1772
- return false;
1773
- }
1774
- // Index is not for this column
1775
- if (dbIndex["COLUMN_NAME"] !== dbColumn["COLUMN_NAME"]) {
1776
- return false;
1777
- }
1778
- var nonUnique = parseInt(dbIndex["NON_UNIQUE"], 10);
1779
- return nonUnique === 0;
1771
+ var columnUniqueIndices = dbIndices.filter(function (dbIndex) {
1772
+ return dbIndex["TABLE_NAME"] === dbTable["TABLE_NAME"]
1773
+ && dbIndex["TABLE_SCHEMA"] === dbTable["TABLE_SCHEMA"]
1774
+ && dbIndex["COLUMN_NAME"] === dbColumn["COLUMN_NAME"]
1775
+ && parseInt(dbIndex["NON_UNIQUE"], 10) === 0;
1780
1776
  });
1781
1777
  var tableMetadata = _this.connection.entityMetadatas.find(function (metadata) { return _this.getTablePath(table) === _this.getTablePath(metadata); });
1782
- var hasIgnoredIndex = columnUniqueIndex && tableMetadata && tableMetadata.indices
1783
- .some(function (index) { return index.name === columnUniqueIndex["INDEX_NAME"] && index.synchronize === false; });
1784
- var isConstraintComposite = columnUniqueIndex
1785
- ? !!dbIndices.find(function (dbIndex) { return dbIndex["INDEX_NAME"] === columnUniqueIndex["INDEX_NAME"] && dbIndex["COLUMN_NAME"] !== dbColumn["COLUMN_NAME"]; })
1786
- : false;
1778
+ var hasIgnoredIndex = columnUniqueIndices.length > 0
1779
+ && tableMetadata
1780
+ && tableMetadata.indices.some(function (index) {
1781
+ return columnUniqueIndices.some(function (uniqueIndex) {
1782
+ return index.name === uniqueIndex["INDEX_NAME"] && index.synchronize === false;
1783
+ });
1784
+ });
1785
+ var isConstraintComposite = columnUniqueIndices.every(function (uniqueIndex) {
1786
+ return dbIndices.some(function (dbIndex) { return dbIndex["INDEX_NAME"] === uniqueIndex["INDEX_NAME"] && dbIndex["COLUMN_NAME"] !== dbColumn["COLUMN_NAME"]; });
1787
+ });
1787
1788
  var tableColumn = new TableColumn();
1788
1789
  tableColumn.name = dbColumn["COLUMN_NAME"];
1789
1790
  tableColumn.type = dbColumn["DATA_TYPE"].toLowerCase();
@@ -1805,7 +1806,7 @@ var AuroraDataApiQueryRunner = /** @class */ (function (_super) {
1805
1806
  tableColumn.asExpression = dbColumn["GENERATION_EXPRESSION"];
1806
1807
  tableColumn.generatedType = dbColumn["EXTRA"].indexOf("VIRTUAL") !== -1 ? "VIRTUAL" : "STORED";
1807
1808
  }
1808
- tableColumn.isUnique = !!columnUniqueIndex && !hasIgnoredIndex && !isConstraintComposite;
1809
+ tableColumn.isUnique = columnUniqueIndices.length > 0 && !hasIgnoredIndex && !isConstraintComposite;
1809
1810
  tableColumn.isNullable = dbColumn["IS_NULLABLE"] === "YES";
1810
1811
  tableColumn.isPrimary = dbPrimaryKeys.some(function (dbPrimaryKey) {
1811
1812
  return (dbPrimaryKey["TABLE_NAME"] === dbColumn["TABLE_NAME"] &&
@@ -1986,19 +1987,19 @@ var AuroraDataApiQueryRunner = /** @class */ (function (_super) {
1986
1987
  };
1987
1988
  AuroraDataApiQueryRunner.prototype.insertViewDefinitionSql = function (view) {
1988
1989
  return __awaiter(this, void 0, void 0, function () {
1989
- var currentDatabase, expression, _a, query, parameters;
1990
- return __generator(this, function (_b) {
1991
- switch (_b.label) {
1990
+ var currentDatabase, expression;
1991
+ return __generator(this, function (_a) {
1992
+ switch (_a.label) {
1992
1993
  case 0: return [4 /*yield*/, this.getCurrentDatabase()];
1993
1994
  case 1:
1994
- currentDatabase = _b.sent();
1995
+ currentDatabase = _a.sent();
1995
1996
  expression = typeof view.expression === "string" ? view.expression.trim() : view.expression(this.connection).getQuery();
1996
- _a = __read(this.connection.createQueryBuilder()
1997
- .insert()
1998
- .into(this.getTypeormMetadataTableName())
1999
- .values({ type: "VIEW", schema: currentDatabase, name: view.name, value: expression })
2000
- .getQueryAndParameters(), 2), query = _a[0], parameters = _a[1];
2001
- return [2 /*return*/, new Query(query, parameters)];
1997
+ return [2 /*return*/, this.insertTypeormMetadataSql({
1998
+ type: MetadataTableType.VIEW,
1999
+ schema: currentDatabase,
2000
+ name: view.name,
2001
+ value: expression
2002
+ })];
2002
2003
  }
2003
2004
  });
2004
2005
  });
@@ -2014,21 +2015,14 @@ var AuroraDataApiQueryRunner = /** @class */ (function (_super) {
2014
2015
  */
2015
2016
  AuroraDataApiQueryRunner.prototype.deleteViewDefinitionSql = function (viewOrPath) {
2016
2017
  return __awaiter(this, void 0, void 0, function () {
2017
- var currentDatabase, viewName, qb, _a, query, parameters;
2018
- return __generator(this, function (_b) {
2019
- switch (_b.label) {
2018
+ var currentDatabase, viewName;
2019
+ return __generator(this, function (_a) {
2020
+ switch (_a.label) {
2020
2021
  case 0: return [4 /*yield*/, this.getCurrentDatabase()];
2021
2022
  case 1:
2022
- currentDatabase = _b.sent();
2023
+ currentDatabase = _a.sent();
2023
2024
  viewName = viewOrPath instanceof View ? viewOrPath.name : viewOrPath;
2024
- qb = this.connection.createQueryBuilder();
2025
- _a = __read(qb.delete()
2026
- .from(this.getTypeormMetadataTableName())
2027
- .where(qb.escape("type") + " = 'VIEW'")
2028
- .andWhere(qb.escape("schema") + " = :schema", { schema: currentDatabase })
2029
- .andWhere(qb.escape("name") + " = :name", { name: viewName })
2030
- .getQueryAndParameters(), 2), query = _a[0], parameters = _a[1];
2031
- return [2 /*return*/, new Query(query, parameters)];
2025
+ return [2 /*return*/, this.deleteTypeormMetadataSql({ type: MetadataTableType.VIEW, schema: currentDatabase, name: viewName })];
2032
2026
  }
2033
2027
  });
2034
2028
  });