typeorm 0.2.42-dev.26581d0 → 0.2.42-dev.3284808

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 (125) hide show
  1. package/README.md +38 -0
  2. package/browser/common/RelationType.d.ts +14 -0
  3. package/browser/common/RelationType.js +3 -0
  4. package/browser/common/RelationType.js.map +1 -0
  5. package/browser/connection/BaseConnectionOptions.d.ts +5 -0
  6. package/browser/connection/BaseConnectionOptions.js.map +1 -1
  7. package/browser/connection/Connection.d.ts +5 -1
  8. package/browser/connection/Connection.js +46 -30
  9. package/browser/connection/Connection.js.map +1 -1
  10. package/browser/connection/ConnectionMetadataBuilder.d.ts +3 -3
  11. package/browser/connection/ConnectionMetadataBuilder.js +54 -22
  12. package/browser/connection/ConnectionMetadataBuilder.js.map +1 -1
  13. package/browser/connection/ConnectionOptionsReader.js +33 -28
  14. package/browser/connection/ConnectionOptionsReader.js.map +1 -1
  15. package/browser/connection/options-reader/ConnectionOptionsEnvReader.js +1 -0
  16. package/browser/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  17. package/browser/driver/postgres/PostgresQueryRunner.js +2 -1
  18. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  19. package/browser/find-options/FindOneOptions.d.ts +6 -0
  20. package/browser/find-options/FindOneOptions.js.map +1 -1
  21. package/browser/find-options/FindOptionsUtils.js +4 -0
  22. package/browser/find-options/FindOptionsUtils.js.map +1 -1
  23. package/browser/find-options/operator/Like.d.ts +1 -1
  24. package/browser/find-options/operator/Like.js +1 -1
  25. package/browser/find-options/operator/Like.js.map +1 -1
  26. package/browser/globals.js +34 -7
  27. package/browser/globals.js.map +1 -1
  28. package/browser/index.d.ts +1 -0
  29. package/browser/index.js +1 -0
  30. package/browser/index.js.map +1 -1
  31. package/browser/query-builder/DeleteQueryBuilder.d.ts +3 -1
  32. package/browser/query-builder/DeleteQueryBuilder.js +3 -1
  33. package/browser/query-builder/DeleteQueryBuilder.js.map +1 -1
  34. package/browser/query-builder/RelationLoader.js +11 -6
  35. package/browser/query-builder/RelationLoader.js.map +1 -1
  36. package/browser/query-builder/SelectQueryBuilder.d.ts +9 -0
  37. package/browser/query-builder/SelectQueryBuilder.js +27 -20
  38. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  39. package/browser/query-builder/UpdateQueryBuilder.d.ts +3 -1
  40. package/browser/query-builder/UpdateQueryBuilder.js +3 -1
  41. package/browser/query-builder/UpdateQueryBuilder.js.map +1 -1
  42. package/browser/query-builder/WhereExpressionBuilder.d.ts +3 -1
  43. package/browser/query-builder/WhereExpressionBuilder.js.map +1 -1
  44. package/browser/query-runner/BaseQueryRunner.d.ts +2 -2
  45. package/browser/query-runner/BaseQueryRunner.js +3 -3
  46. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  47. package/browser/repository/TreeRepository.js +1 -1
  48. package/browser/repository/TreeRepository.js.map +1 -1
  49. package/browser/schema-builder/RdbmsSchemaBuilder.js +1 -1
  50. package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  51. package/browser/util/DirectoryExportedClassesLoader.d.ts +1 -1
  52. package/browser/util/DirectoryExportedClassesLoader.js +55 -31
  53. package/browser/util/DirectoryExportedClassesLoader.js.map +1 -1
  54. package/browser/util/ImportUtils.d.ts +1 -0
  55. package/browser/util/ImportUtils.js +90 -0
  56. package/browser/util/ImportUtils.js.map +1 -0
  57. package/commands/CommandUtils.d.ts +4 -0
  58. package/commands/CommandUtils.js +10 -0
  59. package/commands/CommandUtils.js.map +1 -1
  60. package/commands/InitCommand.d.ts +9 -7
  61. package/commands/InitCommand.js +72 -43
  62. package/commands/InitCommand.js.map +1 -1
  63. package/commands/MigrationCreateCommand.d.ts +2 -0
  64. package/commands/MigrationCreateCommand.js +7 -1
  65. package/commands/MigrationCreateCommand.js.map +1 -1
  66. package/commands/MigrationGenerateCommand.d.ts +2 -0
  67. package/commands/MigrationGenerateCommand.js +7 -1
  68. package/commands/MigrationGenerateCommand.js.map +1 -1
  69. package/common/RelationType.d.ts +14 -0
  70. package/common/RelationType.js +4 -0
  71. package/common/RelationType.js.map +1 -0
  72. package/connection/BaseConnectionOptions.d.ts +5 -0
  73. package/connection/BaseConnectionOptions.js.map +1 -1
  74. package/connection/Connection.d.ts +5 -1
  75. package/connection/Connection.js +46 -30
  76. package/connection/Connection.js.map +1 -1
  77. package/connection/ConnectionMetadataBuilder.d.ts +3 -3
  78. package/connection/ConnectionMetadataBuilder.js +53 -21
  79. package/connection/ConnectionMetadataBuilder.js.map +1 -1
  80. package/connection/ConnectionOptionsReader.js +32 -27
  81. package/connection/ConnectionOptionsReader.js.map +1 -1
  82. package/connection/options-reader/ConnectionOptionsEnvReader.js +1 -0
  83. package/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  84. package/driver/postgres/PostgresQueryRunner.js +2 -1
  85. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  86. package/find-options/FindOneOptions.d.ts +6 -0
  87. package/find-options/FindOneOptions.js.map +1 -1
  88. package/find-options/FindOptionsUtils.js +4 -0
  89. package/find-options/FindOptionsUtils.js.map +1 -1
  90. package/find-options/operator/Like.d.ts +1 -1
  91. package/find-options/operator/Like.js +1 -1
  92. package/find-options/operator/Like.js.map +1 -1
  93. package/globals.js +33 -6
  94. package/globals.js.map +1 -1
  95. package/index.d.ts +1 -0
  96. package/index.js +1 -0
  97. package/index.js.map +1 -1
  98. package/index.mjs +352 -0
  99. package/package.json +1 -1
  100. package/query-builder/DeleteQueryBuilder.d.ts +3 -1
  101. package/query-builder/DeleteQueryBuilder.js +3 -1
  102. package/query-builder/DeleteQueryBuilder.js.map +1 -1
  103. package/query-builder/RelationLoader.js +11 -6
  104. package/query-builder/RelationLoader.js.map +1 -1
  105. package/query-builder/SelectQueryBuilder.d.ts +9 -0
  106. package/query-builder/SelectQueryBuilder.js +27 -20
  107. package/query-builder/SelectQueryBuilder.js.map +1 -1
  108. package/query-builder/UpdateQueryBuilder.d.ts +3 -1
  109. package/query-builder/UpdateQueryBuilder.js +3 -1
  110. package/query-builder/UpdateQueryBuilder.js.map +1 -1
  111. package/query-builder/WhereExpressionBuilder.d.ts +3 -1
  112. package/query-builder/WhereExpressionBuilder.js.map +1 -1
  113. package/query-runner/BaseQueryRunner.d.ts +2 -2
  114. package/query-runner/BaseQueryRunner.js +3 -3
  115. package/query-runner/BaseQueryRunner.js.map +1 -1
  116. package/repository/TreeRepository.js +1 -1
  117. package/repository/TreeRepository.js.map +1 -1
  118. package/schema-builder/RdbmsSchemaBuilder.js +1 -1
  119. package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  120. package/util/DirectoryExportedClassesLoader.d.ts +1 -1
  121. package/util/DirectoryExportedClassesLoader.js +54 -31
  122. package/util/DirectoryExportedClassesLoader.js.map +1 -1
  123. package/util/ImportUtils.d.ts +1 -0
  124. package/util/ImportUtils.js +94 -0
  125. package/util/ImportUtils.js.map +1 -0
@@ -584,6 +584,15 @@ export declare class SelectQueryBuilder<Entity> extends QueryBuilder<Entity> imp
584
584
  * Creates "LIMIT" and "OFFSET" parts of SQL query.
585
585
  */
586
586
  protected createLimitOffsetExpression(): string;
587
+ /**
588
+ * Creates "LOCK" part of SELECT Query after table Clause
589
+ * ex.
590
+ * SELECT 1
591
+ * FROM USER U WITH (NOLOCK)
592
+ * JOIN ORDER O WITH (NOLOCK)
593
+ * ON U.ID=O.OrderID
594
+ */
595
+ private createTableLockExpression;
587
596
  /**
588
597
  * Creates "LOCK" part of SQL query.
589
598
  */
@@ -1029,20 +1029,6 @@ var SelectQueryBuilder = /** @class */ (function (_super) {
1029
1029
  // if still selection is empty, then simply set it to all (*)
1030
1030
  if (allSelects.length === 0)
1031
1031
  allSelects.push({ selection: "*" });
1032
- var lock = "";
1033
- if (this.connection.driver instanceof SqlServerDriver_1.SqlServerDriver) {
1034
- switch (this.expressionMap.lockMode) {
1035
- case "pessimistic_read":
1036
- lock = " WITH (HOLDLOCK, ROWLOCK)";
1037
- break;
1038
- case "pessimistic_write":
1039
- lock = " WITH (UPDLOCK, ROWLOCK)";
1040
- break;
1041
- case "dirty_read":
1042
- lock = " WITH (NOLOCK)";
1043
- break;
1044
- }
1045
- }
1046
1032
  // Use certain index
1047
1033
  var useIndex = "";
1048
1034
  if (this.expressionMap.useIndex) {
@@ -1060,7 +1046,7 @@ var SelectQueryBuilder = /** @class */ (function (_super) {
1060
1046
  });
1061
1047
  var select = this.createSelectDistinctExpression();
1062
1048
  var selection = allSelects.map(function (select) { return select.selection + (select.aliasName ? " AS " + _this.escape(select.aliasName) : ""); }).join(", ");
1063
- return select + selection + " FROM " + froms.join(", ") + lock + useIndex;
1049
+ return select + selection + " FROM " + froms.join(", ") + this.createTableLockExpression() + useIndex;
1064
1050
  };
1065
1051
  /**
1066
1052
  * Creates select | select distinct part of SQL query.
@@ -1106,7 +1092,7 @@ var SelectQueryBuilder = /** @class */ (function (_super) {
1106
1092
  // table to join, without junction table involved. This means we simply join direct table.
1107
1093
  if (!parentAlias || !relation) {
1108
1094
  var destinationJoin = joinAttr.alias.subQuery ? joinAttr.alias.subQuery : _this.getTableName(destinationTableName);
1109
- return " " + joinAttr.direction + " JOIN " + destinationJoin + " " + _this.escape(destinationTableAlias) +
1095
+ return " " + joinAttr.direction + " JOIN " + destinationJoin + " " + _this.escape(destinationTableAlias) + _this.createTableLockExpression() +
1110
1096
  (joinAttr.condition ? " ON " + _this.replacePropertyNames(joinAttr.condition) : "");
1111
1097
  }
1112
1098
  // if real entity relation is involved
@@ -1116,7 +1102,7 @@ var SelectQueryBuilder = /** @class */ (function (_super) {
1116
1102
  return destinationTableAlias + "." + joinColumn.referencedColumn.propertyPath + "=" +
1117
1103
  parentAlias + "." + relation.propertyPath + "." + joinColumn.referencedColumn.propertyPath;
1118
1104
  }).join(" AND ");
1119
- return " " + joinAttr.direction + " JOIN " + _this.getTableName(destinationTableName) + " " + _this.escape(destinationTableAlias) + " ON " + _this.replacePropertyNames(condition + appendedCondition);
1105
+ return " " + joinAttr.direction + " JOIN " + _this.getTableName(destinationTableName) + " " + _this.escape(destinationTableAlias) + _this.createTableLockExpression() + " ON " + _this.replacePropertyNames(condition + appendedCondition);
1120
1106
  }
1121
1107
  else if (relation.isOneToMany || relation.isOneToOneNotOwner) {
1122
1108
  // JOIN `post` `post` ON `post`.`categoryId` = `category`.`id`
@@ -1127,7 +1113,7 @@ var SelectQueryBuilder = /** @class */ (function (_super) {
1127
1113
  return destinationTableAlias + "." + relation.inverseRelation.propertyPath + "." + joinColumn.referencedColumn.propertyPath + "=" +
1128
1114
  parentAlias + "." + joinColumn.referencedColumn.propertyPath;
1129
1115
  }).join(" AND ");
1130
- return " " + joinAttr.direction + " JOIN " + _this.getTableName(destinationTableName) + " " + _this.escape(destinationTableAlias) + " ON " + _this.replacePropertyNames(condition + appendedCondition);
1116
+ return " " + joinAttr.direction + " JOIN " + _this.getTableName(destinationTableName) + " " + _this.escape(destinationTableAlias) + _this.createTableLockExpression() + " ON " + _this.replacePropertyNames(condition + appendedCondition);
1131
1117
  }
1132
1118
  else { // means many-to-many
1133
1119
  var junctionTableName = relation.junctionEntityMetadata.tablePath;
@@ -1153,8 +1139,8 @@ var SelectQueryBuilder = /** @class */ (function (_super) {
1153
1139
  return destinationTableAlias + "." + joinColumn.referencedColumn.propertyPath + "=" + junctionAlias_1 + "." + joinColumn.propertyPath;
1154
1140
  }).join(" AND ");
1155
1141
  }
1156
- return " " + joinAttr.direction + " JOIN " + _this.getTableName(junctionTableName) + " " + _this.escape(junctionAlias_1) + " ON " + _this.replacePropertyNames(junctionCondition) +
1157
- " " + joinAttr.direction + " JOIN " + _this.getTableName(destinationTableName) + " " + _this.escape(destinationTableAlias) + " ON " + _this.replacePropertyNames(destinationCondition + appendedCondition);
1142
+ return " " + joinAttr.direction + " JOIN " + _this.getTableName(junctionTableName) + " " + _this.escape(junctionAlias_1) + _this.createTableLockExpression() + " ON " + _this.replacePropertyNames(junctionCondition) +
1143
+ " " + joinAttr.direction + " JOIN " + _this.getTableName(destinationTableName) + " " + _this.escape(destinationTableAlias) + _this.createTableLockExpression() + " ON " + _this.replacePropertyNames(destinationCondition + appendedCondition);
1158
1144
  }
1159
1145
  });
1160
1146
  return joins.join(" ");
@@ -1248,6 +1234,27 @@ var SelectQueryBuilder = /** @class */ (function (_super) {
1248
1234
  }
1249
1235
  return "";
1250
1236
  };
1237
+ /**
1238
+ * Creates "LOCK" part of SELECT Query after table Clause
1239
+ * ex.
1240
+ * SELECT 1
1241
+ * FROM USER U WITH (NOLOCK)
1242
+ * JOIN ORDER O WITH (NOLOCK)
1243
+ * ON U.ID=O.OrderID
1244
+ */
1245
+ SelectQueryBuilder.prototype.createTableLockExpression = function () {
1246
+ if (this.connection.driver instanceof SqlServerDriver_1.SqlServerDriver) {
1247
+ switch (this.expressionMap.lockMode) {
1248
+ case "pessimistic_read":
1249
+ return " WITH (HOLDLOCK, ROWLOCK)";
1250
+ case "pessimistic_write":
1251
+ return " WITH (UPDLOCK, ROWLOCK)";
1252
+ case "dirty_read":
1253
+ return " WITH (NOLOCK)";
1254
+ }
1255
+ }
1256
+ return "";
1257
+ };
1251
1258
  /**
1252
1259
  * Creates "LOCK" part of SQL query.
1253
1260
  */