typeorm 0.3.21 → 0.3.22-dev.673b6ce

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 (1024) hide show
  1. package/README.md +1315 -1315
  2. package/browser/cache/DbQueryResultCache.js.map +1 -1
  3. package/browser/cache/QueryResultCache.js.map +1 -1
  4. package/browser/cache/QueryResultCacheFactory.js.map +1 -1
  5. package/browser/cache/QueryResultCacheOptions.js.map +1 -1
  6. package/browser/cache/RedisQueryResultCache.js.map +1 -1
  7. package/browser/cli-ts-node-commonjs.js.map +1 -1
  8. package/browser/cli-ts-node-esm.js.map +1 -1
  9. package/browser/common/DeepPartial.js.map +1 -1
  10. package/browser/common/EntityTarget.js.map +1 -1
  11. package/browser/common/MixedList.js.map +1 -1
  12. package/browser/common/NonNever.js.map +1 -1
  13. package/browser/common/ObjectLiteral.js.map +1 -1
  14. package/browser/common/ObjectType.js.map +1 -1
  15. package/browser/common/PickKeysByType.js.map +1 -1
  16. package/browser/common/RelationType.js.map +1 -1
  17. package/browser/connection/BaseConnectionOptions.js.map +1 -1
  18. package/browser/connection/Connection.js.map +1 -1
  19. package/browser/connection/ConnectionManager.js.map +1 -1
  20. package/browser/connection/ConnectionMetadataBuilder.js.map +1 -1
  21. package/browser/connection/ConnectionOptions.js.map +1 -1
  22. package/browser/connection/ConnectionOptionsReader.js.map +1 -1
  23. package/browser/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  24. package/browser/container.js.map +1 -1
  25. package/browser/data-source/BaseDataSourceOptions.js.map +1 -1
  26. package/browser/data-source/DataSource.js.map +1 -1
  27. package/browser/data-source/DataSourceOptions.js.map +1 -1
  28. package/browser/data-source/index.js.map +1 -1
  29. package/browser/decorator/Check.js.map +1 -1
  30. package/browser/decorator/EntityRepository.js.map +1 -1
  31. package/browser/decorator/Exclusion.js.map +1 -1
  32. package/browser/decorator/Generated.js.map +1 -1
  33. package/browser/decorator/Index.js.map +1 -1
  34. package/browser/decorator/Unique.js.map +1 -1
  35. package/browser/decorator/columns/Column.js.map +1 -1
  36. package/browser/decorator/columns/CreateDateColumn.js.map +1 -1
  37. package/browser/decorator/columns/DeleteDateColumn.js.map +1 -1
  38. package/browser/decorator/columns/ObjectIdColumn.js.map +1 -1
  39. package/browser/decorator/columns/PrimaryColumn.js.map +1 -1
  40. package/browser/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  41. package/browser/decorator/columns/UpdateDateColumn.js.map +1 -1
  42. package/browser/decorator/columns/VersionColumn.js.map +1 -1
  43. package/browser/decorator/columns/ViewColumn.js.map +1 -1
  44. package/browser/decorator/columns/VirtualColumn.js.map +1 -1
  45. package/browser/decorator/entity/ChildEntity.js.map +1 -1
  46. package/browser/decorator/entity/Entity.js.map +1 -1
  47. package/browser/decorator/entity/TableInheritance.js.map +1 -1
  48. package/browser/decorator/entity-view/ViewEntity.js.map +1 -1
  49. package/browser/decorator/listeners/AfterInsert.js.map +1 -1
  50. package/browser/decorator/listeners/AfterLoad.js.map +1 -1
  51. package/browser/decorator/listeners/AfterRecover.js.map +1 -1
  52. package/browser/decorator/listeners/AfterRemove.js.map +1 -1
  53. package/browser/decorator/listeners/AfterSoftRemove.js.map +1 -1
  54. package/browser/decorator/listeners/AfterUpdate.js.map +1 -1
  55. package/browser/decorator/listeners/BeforeInsert.js.map +1 -1
  56. package/browser/decorator/listeners/BeforeRecover.js.map +1 -1
  57. package/browser/decorator/listeners/BeforeRemove.js.map +1 -1
  58. package/browser/decorator/listeners/BeforeSoftRemove.js.map +1 -1
  59. package/browser/decorator/listeners/BeforeUpdate.js.map +1 -1
  60. package/browser/decorator/listeners/EventSubscriber.js.map +1 -1
  61. package/browser/decorator/options/ColumnCommonOptions.js.map +1 -1
  62. package/browser/decorator/options/ColumnEmbeddedOptions.js.map +1 -1
  63. package/browser/decorator/options/ColumnEnumOptions.js.map +1 -1
  64. package/browser/decorator/options/ColumnHstoreOptions.js.map +1 -1
  65. package/browser/decorator/options/ColumnNumericOptions.js.map +1 -1
  66. package/browser/decorator/options/ColumnOptions.js.map +1 -1
  67. package/browser/decorator/options/ColumnWithLengthOptions.js.map +1 -1
  68. package/browser/decorator/options/ColumnWithWidthOptions.js.map +1 -1
  69. package/browser/decorator/options/EntityOptions.js.map +1 -1
  70. package/browser/decorator/options/IndexOptions.js.map +1 -1
  71. package/browser/decorator/options/JoinColumnOptions.js.map +1 -1
  72. package/browser/decorator/options/JoinTableMultipleColumnsOptions.js.map +1 -1
  73. package/browser/decorator/options/JoinTableOptions.js.map +1 -1
  74. package/browser/decorator/options/PrimaryGeneratedColumnIdentityOptions.js.map +1 -1
  75. package/browser/decorator/options/PrimaryGeneratedColumnNumericOptions.js.map +1 -1
  76. package/browser/decorator/options/PrimaryGeneratedColumnUUIDOptions.js.map +1 -1
  77. package/browser/decorator/options/RelationOptions.js.map +1 -1
  78. package/browser/decorator/options/SpatialColumnOptions.js.map +1 -1
  79. package/browser/decorator/options/TransactionOptions.js.map +1 -1
  80. package/browser/decorator/options/UniqueOptions.js.map +1 -1
  81. package/browser/decorator/options/ValueTransformer.js.map +1 -1
  82. package/browser/decorator/options/ViewColumnOptions.js.map +1 -1
  83. package/browser/decorator/options/ViewEntityOptions.js.map +1 -1
  84. package/browser/decorator/options/VirtualColumnOptions.js.map +1 -1
  85. package/browser/decorator/relations/JoinColumn.js.map +1 -1
  86. package/browser/decorator/relations/JoinTable.js.map +1 -1
  87. package/browser/decorator/relations/ManyToMany.js.map +1 -1
  88. package/browser/decorator/relations/ManyToOne.js.map +1 -1
  89. package/browser/decorator/relations/OneToMany.js.map +1 -1
  90. package/browser/decorator/relations/OneToOne.js.map +1 -1
  91. package/browser/decorator/relations/RelationCount.js.map +1 -1
  92. package/browser/decorator/relations/RelationId.js.map +1 -1
  93. package/browser/decorator/tree/Tree.js.map +1 -1
  94. package/browser/decorator/tree/TreeChildren.js.map +1 -1
  95. package/browser/decorator/tree/TreeLevelColumn.js.map +1 -1
  96. package/browser/decorator/tree/TreeParent.js.map +1 -1
  97. package/browser/driver/Driver.js.map +1 -1
  98. package/browser/driver/DriverFactory.js.map +1 -1
  99. package/browser/driver/DriverUtils.js.map +1 -1
  100. package/browser/driver/Query.js.map +1 -1
  101. package/browser/driver/SqlInMemory.js.map +1 -1
  102. package/browser/driver/aurora-mysql/AuroraMysqlConnection.js.map +1 -1
  103. package/browser/driver/aurora-mysql/AuroraMysqlConnectionCredentialsOptions.js.map +1 -1
  104. package/browser/driver/aurora-mysql/AuroraMysqlConnectionOptions.js.map +1 -1
  105. package/browser/driver/aurora-mysql/AuroraMysqlDriver.js.map +1 -1
  106. package/browser/driver/aurora-mysql/AuroraMysqlQueryRunner.js +6 -9
  107. package/browser/driver/aurora-mysql/AuroraMysqlQueryRunner.js.map +1 -1
  108. package/browser/driver/aurora-postgres/AuroraPostgresConnectionOptions.js.map +1 -1
  109. package/browser/driver/aurora-postgres/AuroraPostgresDriver.js.map +1 -1
  110. package/browser/driver/aurora-postgres/AuroraPostgresQueryRunner.js +6 -9
  111. package/browser/driver/aurora-postgres/AuroraPostgresQueryRunner.js.map +1 -1
  112. package/browser/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js.map +1 -1
  113. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  114. package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -1
  115. package/browser/driver/capacitor/CapacitorConnectionOptions.js.map +1 -1
  116. package/browser/driver/capacitor/CapacitorDriver.js.map +1 -1
  117. package/browser/driver/capacitor/CapacitorQueryRunner.js.map +1 -1
  118. package/browser/driver/cockroachdb/CockroachConnectionCredentialsOptions.js.map +1 -1
  119. package/browser/driver/cockroachdb/CockroachConnectionOptions.js.map +1 -1
  120. package/browser/driver/cockroachdb/CockroachDriver.js.map +1 -1
  121. package/browser/driver/cockroachdb/CockroachQueryRunner.js +7 -11
  122. package/browser/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  123. package/browser/driver/cordova/CordovaConnectionOptions.js.map +1 -1
  124. package/browser/driver/cordova/CordovaDriver.js.map +1 -1
  125. package/browser/driver/cordova/CordovaQueryRunner.js.map +1 -1
  126. package/browser/driver/expo/ExpoConnectionOptions.js.map +1 -1
  127. package/browser/driver/expo/ExpoDriver.js.map +1 -1
  128. package/browser/driver/expo/ExpoQueryRunner.js.map +1 -1
  129. package/browser/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  130. package/browser/driver/mongodb/MongoDriver.js.map +1 -1
  131. package/browser/driver/mongodb/MongoQueryRunner.js.map +1 -1
  132. package/browser/driver/mongodb/bson.typings.js.map +1 -1
  133. package/browser/driver/mongodb/typings.js.map +1 -1
  134. package/browser/driver/mysql/MysqlConnectionCredentialsOptions.js.map +1 -1
  135. package/browser/driver/mysql/MysqlConnectionOptions.js.map +1 -1
  136. package/browser/driver/mysql/MysqlDriver.js.map +1 -1
  137. package/browser/driver/mysql/MysqlQueryRunner.js +77 -80
  138. package/browser/driver/mysql/MysqlQueryRunner.js.map +1 -1
  139. package/browser/driver/nativescript/NativescriptConnectionOptions.js.map +1 -1
  140. package/browser/driver/nativescript/NativescriptDriver.js.map +1 -1
  141. package/browser/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  142. package/browser/driver/oracle/OracleConnectionCredentialsOptions.js.map +1 -1
  143. package/browser/driver/oracle/OracleConnectionOptions.js.map +1 -1
  144. package/browser/driver/oracle/OracleDriver.js.map +1 -1
  145. package/browser/driver/oracle/OracleQueryRunner.js +4 -6
  146. package/browser/driver/oracle/OracleQueryRunner.js.map +1 -1
  147. package/browser/driver/postgres/PostgresConnectionCredentialsOptions.js.map +1 -1
  148. package/browser/driver/postgres/PostgresConnectionOptions.js.map +1 -1
  149. package/browser/driver/postgres/PostgresDriver.js.map +1 -1
  150. package/browser/driver/postgres/PostgresQueryRunner.js +6 -9
  151. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  152. package/browser/driver/react-native/ReactNativeConnectionOptions.js.map +1 -1
  153. package/browser/driver/react-native/ReactNativeDriver.js.map +1 -1
  154. package/browser/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  155. package/browser/driver/sap/SapConnectionCredentialsOptions.js.map +1 -1
  156. package/browser/driver/sap/SapConnectionOptions.js.map +1 -1
  157. package/browser/driver/sap/SapDriver.js.map +1 -1
  158. package/browser/driver/sap/SapQueryRunner.js.map +1 -1
  159. package/browser/driver/spanner/SpannerConnectionCredentialsOptions.js.map +1 -1
  160. package/browser/driver/spanner/SpannerConnectionOptions.js.map +1 -1
  161. package/browser/driver/spanner/SpannerDriver.js.map +1 -1
  162. package/browser/driver/spanner/SpannerQueryRunner.js.map +1 -1
  163. package/browser/driver/sqlite/SqliteConnectionOptions.js.map +1 -1
  164. package/browser/driver/sqlite/SqliteDriver.js.map +1 -1
  165. package/browser/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  166. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  167. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +6 -9
  168. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  169. package/browser/driver/sqljs/SqljsConnectionOptions.js.map +1 -1
  170. package/browser/driver/sqljs/SqljsDriver.js.map +1 -1
  171. package/browser/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  172. package/browser/driver/sqlserver/MssqlParameter.js.map +1 -1
  173. package/browser/driver/sqlserver/SqlServerConnectionCredentialsOptions.js.map +1 -1
  174. package/browser/driver/sqlserver/SqlServerConnectionOptions.js.map +1 -1
  175. package/browser/driver/sqlserver/SqlServerDriver.js.map +1 -1
  176. package/browser/driver/sqlserver/SqlServerQueryRunner.js +31 -32
  177. package/browser/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  178. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryAccessTokenAuthentication.js.map +1 -1
  179. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryDefaultAuthentication.js.map +1 -1
  180. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryMsiAppServiceAuthentication.js.map +1 -1
  181. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryMsiVmAuthentication.js.map +1 -1
  182. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryPasswordAuthentication.js.map +1 -1
  183. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryServicePrincipalSecret.js.map +1 -1
  184. package/browser/driver/sqlserver/authentication/DefaultAuthentication.js.map +1 -1
  185. package/browser/driver/sqlserver/authentication/NtlmAuthentication.js.map +1 -1
  186. package/browser/driver/types/ColumnTypes.js.map +1 -1
  187. package/browser/driver/types/CteCapabilities.js.map +1 -1
  188. package/browser/driver/types/DataTypeDefaults.js.map +1 -1
  189. package/browser/driver/types/DatabaseType.js.map +1 -1
  190. package/browser/driver/types/GeoJsonTypes.js.map +1 -1
  191. package/browser/driver/types/IsolationLevel.js.map +1 -1
  192. package/browser/driver/types/MappedColumnTypes.js.map +1 -1
  193. package/browser/driver/types/MetadataTableType.js.map +1 -1
  194. package/browser/driver/types/ReplicationMode.js.map +1 -1
  195. package/browser/driver/types/UpsertType.js.map +1 -1
  196. package/browser/entity-manager/EntityManager.js.map +1 -1
  197. package/browser/entity-manager/EntityManagerFactory.js.map +1 -1
  198. package/browser/entity-manager/MongoEntityManager.js.map +1 -1
  199. package/browser/entity-manager/SqljsEntityManager.js.map +1 -1
  200. package/browser/entity-schema/EntitySchema.js.map +1 -1
  201. package/browser/entity-schema/EntitySchemaCheckOptions.js.map +1 -1
  202. package/browser/entity-schema/EntitySchemaColumnOptions.js.map +1 -1
  203. package/browser/entity-schema/EntitySchemaEmbeddedColumnOptions.js.map +1 -1
  204. package/browser/entity-schema/EntitySchemaEmbeddedError.js.map +1 -1
  205. package/browser/entity-schema/EntitySchemaExclusionOptions.js.map +1 -1
  206. package/browser/entity-schema/EntitySchemaIndexOptions.js.map +1 -1
  207. package/browser/entity-schema/EntitySchemaInheritanceOptions.js.map +1 -1
  208. package/browser/entity-schema/EntitySchemaOptions.js.map +1 -1
  209. package/browser/entity-schema/EntitySchemaRelationIdOptions.js.map +1 -1
  210. package/browser/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
  211. package/browser/entity-schema/EntitySchemaTransformer.js.map +1 -1
  212. package/browser/entity-schema/EntitySchemaUniqueOptions.js.map +1 -1
  213. package/browser/error/AlreadyHasActiveConnectionError.js.map +1 -1
  214. package/browser/error/CannotAttachTreeChildrenEntityError.js.map +1 -1
  215. package/browser/error/CannotConnectAlreadyConnectedError.js.map +1 -1
  216. package/browser/error/CannotCreateEntityIdMapError.js.map +1 -1
  217. package/browser/error/CannotDetermineEntityError.js.map +1 -1
  218. package/browser/error/CannotExecuteNotConnectedError.js.map +1 -1
  219. package/browser/error/CannotGetEntityManagerNotConnectedError.js.map +1 -1
  220. package/browser/error/CannotReflectMethodParameterTypeError.js.map +1 -1
  221. package/browser/error/CircularRelationsError.js.map +1 -1
  222. package/browser/error/ColumnTypeUndefinedError.js.map +1 -1
  223. package/browser/error/ConnectionIsNotSetError.js.map +1 -1
  224. package/browser/error/ConnectionNotFoundError.js.map +1 -1
  225. package/browser/error/CustomRepositoryCannotInheritRepositoryError.js.map +1 -1
  226. package/browser/error/CustomRepositoryDoesNotHaveEntityError.js.map +1 -1
  227. package/browser/error/CustomRepositoryNotFoundError.js.map +1 -1
  228. package/browser/error/DataTypeNotSupportedError.js.map +1 -1
  229. package/browser/error/DriverOptionNotSetError.js.map +1 -1
  230. package/browser/error/DriverPackageNotInstalledError.js.map +1 -1
  231. package/browser/error/EntityMetadataNotFoundError.js.map +1 -1
  232. package/browser/error/EntityNotFoundError.js.map +1 -1
  233. package/browser/error/EntityPropertyNotFoundError.js.map +1 -1
  234. package/browser/error/FindRelationsNotFoundError.js.map +1 -1
  235. package/browser/error/ForbiddenTransactionModeOverrideError.js.map +1 -1
  236. package/browser/error/InitializedRelationError.js.map +1 -1
  237. package/browser/error/InsertValuesMissingError.js.map +1 -1
  238. package/browser/error/LimitOnUpdateNotSupportedError.js.map +1 -1
  239. package/browser/error/LockNotSupportedOnGivenDriverError.js.map +1 -1
  240. package/browser/error/MetadataAlreadyExistsError.js.map +1 -1
  241. package/browser/error/MetadataWithSuchNameAlreadyExistsError.js.map +1 -1
  242. package/browser/error/MissingDeleteDateColumnError.js.map +1 -1
  243. package/browser/error/MissingDriverError.js.map +1 -1
  244. package/browser/error/MissingJoinColumnError.js.map +1 -1
  245. package/browser/error/MissingJoinTableError.js.map +1 -1
  246. package/browser/error/MissingPrimaryColumnError.js.map +1 -1
  247. package/browser/error/MustBeEntityError.js.map +1 -1
  248. package/browser/error/NamingStrategyNotFoundError.js.map +1 -1
  249. package/browser/error/NestedSetMultipleRootError.js.map +1 -1
  250. package/browser/error/NoConnectionForRepositoryError.js.map +1 -1
  251. package/browser/error/NoConnectionOptionError.js.map +1 -1
  252. package/browser/error/NoNeedToReleaseEntityManagerError.js.map +1 -1
  253. package/browser/error/NoVersionOrUpdateDateColumnError.js.map +1 -1
  254. package/browser/error/OffsetWithoutLimitNotSupportedError.js.map +1 -1
  255. package/browser/error/OptimisticLockCanNotBeUsedError.js.map +1 -1
  256. package/browser/error/OptimisticLockVersionMismatchError.js.map +1 -1
  257. package/browser/error/PersistedEntityNotFoundError.js.map +1 -1
  258. package/browser/error/PessimisticLockTransactionRequiredError.js.map +1 -1
  259. package/browser/error/PrimaryColumnCannotBeNullableError.js.map +1 -1
  260. package/browser/error/QueryFailedError.js.map +1 -1
  261. package/browser/error/QueryRunnerAlreadyReleasedError.js.map +1 -1
  262. package/browser/error/QueryRunnerProviderAlreadyReleasedError.js.map +1 -1
  263. package/browser/error/RepositoryNotTreeError.js.map +1 -1
  264. package/browser/error/ReturningStatementNotSupportedError.js.map +1 -1
  265. package/browser/error/SubjectRemovedAndUpdatedError.js.map +1 -1
  266. package/browser/error/SubjectWithoutIdentifierError.js.map +1 -1
  267. package/browser/error/TransactionAlreadyStartedError.js.map +1 -1
  268. package/browser/error/TransactionNotStartedError.js.map +1 -1
  269. package/browser/error/TreeRepositoryNotSupportedError.js.map +1 -1
  270. package/browser/error/TypeORMError.js.map +1 -1
  271. package/browser/error/UpdateValuesMissingError.js.map +1 -1
  272. package/browser/error/UsingJoinColumnIsNotAllowedError.js.map +1 -1
  273. package/browser/error/UsingJoinColumnOnlyOnOneSideAllowedError.js.map +1 -1
  274. package/browser/error/UsingJoinTableIsNotAllowedError.js.map +1 -1
  275. package/browser/error/UsingJoinTableOnlyOnOneSideAllowedError.js.map +1 -1
  276. package/browser/error/index.js.map +1 -1
  277. package/browser/find-options/EqualOperator.js.map +1 -1
  278. package/browser/find-options/FindManyOptions.js.map +1 -1
  279. package/browser/find-options/FindOneOptions.js.map +1 -1
  280. package/browser/find-options/FindOperator.js.map +1 -1
  281. package/browser/find-options/FindOperatorType.js.map +1 -1
  282. package/browser/find-options/FindOptionsOrder.js.map +1 -1
  283. package/browser/find-options/FindOptionsRelations.js.map +1 -1
  284. package/browser/find-options/FindOptionsSelect.js.map +1 -1
  285. package/browser/find-options/FindOptionsUtils.js.map +1 -1
  286. package/browser/find-options/FindOptionsWhere.js.map +1 -1
  287. package/browser/find-options/FindTreeOptions.js.map +1 -1
  288. package/browser/find-options/JoinOptions.js.map +1 -1
  289. package/browser/find-options/OrderByCondition.js.map +1 -1
  290. package/browser/find-options/mongodb/MongoFindManyOptions.js.map +1 -1
  291. package/browser/find-options/mongodb/MongoFindOneOptions.js.map +1 -1
  292. package/browser/find-options/operator/And.js.map +1 -1
  293. package/browser/find-options/operator/Any.js.map +1 -1
  294. package/browser/find-options/operator/ArrayContainedBy.js.map +1 -1
  295. package/browser/find-options/operator/ArrayContains.js.map +1 -1
  296. package/browser/find-options/operator/ArrayOverlap.js.map +1 -1
  297. package/browser/find-options/operator/Between.js.map +1 -1
  298. package/browser/find-options/operator/Equal.js.map +1 -1
  299. package/browser/find-options/operator/ILike.js.map +1 -1
  300. package/browser/find-options/operator/In.js.map +1 -1
  301. package/browser/find-options/operator/IsNull.js.map +1 -1
  302. package/browser/find-options/operator/JsonContains.js.map +1 -1
  303. package/browser/find-options/operator/LessThan.js.map +1 -1
  304. package/browser/find-options/operator/LessThanOrEqual.js.map +1 -1
  305. package/browser/find-options/operator/Like.js.map +1 -1
  306. package/browser/find-options/operator/MoreThan.js.map +1 -1
  307. package/browser/find-options/operator/MoreThanOrEqual.js.map +1 -1
  308. package/browser/find-options/operator/Not.js.map +1 -1
  309. package/browser/find-options/operator/Or.js.map +1 -1
  310. package/browser/find-options/operator/Raw.js.map +1 -1
  311. package/browser/globals.js.map +1 -1
  312. package/browser/index.js.map +1 -1
  313. package/browser/logger/AbstractLogger.js.map +1 -1
  314. package/browser/logger/AdvancedConsoleLogger.js.map +1 -1
  315. package/browser/logger/DebugLogger.js.map +1 -1
  316. package/browser/logger/FileLogger.js.map +1 -1
  317. package/browser/logger/Logger.js.map +1 -1
  318. package/browser/logger/LoggerFactory.js.map +1 -1
  319. package/browser/logger/LoggerOptions.js.map +1 -1
  320. package/browser/logger/SimpleConsoleLogger.js.map +1 -1
  321. package/browser/metadata/CheckMetadata.js.map +1 -1
  322. package/browser/metadata/ColumnMetadata.js.map +1 -1
  323. package/browser/metadata/EmbeddedMetadata.js.map +1 -1
  324. package/browser/metadata/EntityListenerMetadata.js.map +1 -1
  325. package/browser/metadata/EntityMetadata.js.map +1 -1
  326. package/browser/metadata/ExclusionMetadata.js.map +1 -1
  327. package/browser/metadata/ForeignKeyMetadata.js.map +1 -1
  328. package/browser/metadata/IndexMetadata.js.map +1 -1
  329. package/browser/metadata/RelationCountMetadata.js.map +1 -1
  330. package/browser/metadata/RelationIdMetadata.js.map +1 -1
  331. package/browser/metadata/RelationMetadata.js.map +1 -1
  332. package/browser/metadata/UniqueMetadata.js.map +1 -1
  333. package/browser/metadata/types/ClosureTreeOptions.js.map +1 -1
  334. package/browser/metadata/types/DeferrableType.js.map +1 -1
  335. package/browser/metadata/types/EventListenerTypes.js.map +1 -1
  336. package/browser/metadata/types/OnDeleteType.js.map +1 -1
  337. package/browser/metadata/types/OnUpdateType.js.map +1 -1
  338. package/browser/metadata/types/PropertyTypeInFunction.js.map +1 -1
  339. package/browser/metadata/types/RelationTypeInFunction.js.map +1 -1
  340. package/browser/metadata/types/RelationTypes.js.map +1 -1
  341. package/browser/metadata/types/TableTypes.js.map +1 -1
  342. package/browser/metadata/types/TreeTypes.js.map +1 -1
  343. package/browser/metadata-args/CheckMetadataArgs.js.map +1 -1
  344. package/browser/metadata-args/ColumnMetadataArgs.js.map +1 -1
  345. package/browser/metadata-args/DiscriminatorValueMetadataArgs.js.map +1 -1
  346. package/browser/metadata-args/EmbeddedMetadataArgs.js.map +1 -1
  347. package/browser/metadata-args/EntityListenerMetadataArgs.js.map +1 -1
  348. package/browser/metadata-args/EntityRepositoryMetadataArgs.js.map +1 -1
  349. package/browser/metadata-args/EntitySubscriberMetadataArgs.js.map +1 -1
  350. package/browser/metadata-args/ExclusionMetadataArgs.js.map +1 -1
  351. package/browser/metadata-args/GeneratedMetadataArgs.js.map +1 -1
  352. package/browser/metadata-args/IndexMetadataArgs.js.map +1 -1
  353. package/browser/metadata-args/InheritanceMetadataArgs.js.map +1 -1
  354. package/browser/metadata-args/JoinColumnMetadataArgs.js.map +1 -1
  355. package/browser/metadata-args/JoinTableMetadataArgs.js.map +1 -1
  356. package/browser/metadata-args/MetadataArgsStorage.js.map +1 -1
  357. package/browser/metadata-args/NamingStrategyMetadataArgs.js.map +1 -1
  358. package/browser/metadata-args/RelationCountMetadataArgs.js.map +1 -1
  359. package/browser/metadata-args/RelationIdMetadataArgs.js.map +1 -1
  360. package/browser/metadata-args/RelationMetadataArgs.js.map +1 -1
  361. package/browser/metadata-args/TableMetadataArgs.js.map +1 -1
  362. package/browser/metadata-args/TransactionEntityMetadataArgs.js.map +1 -1
  363. package/browser/metadata-args/TransactionRepositoryMetadataArgs.js.map +1 -1
  364. package/browser/metadata-args/TreeMetadataArgs.js.map +1 -1
  365. package/browser/metadata-args/UniqueMetadataArgs.js.map +1 -1
  366. package/browser/metadata-args/types/ColumnMode.js.map +1 -1
  367. package/browser/metadata-builder/ClosureJunctionEntityMetadataBuilder.js.map +1 -1
  368. package/browser/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  369. package/browser/metadata-builder/EntityMetadataValidator.js.map +1 -1
  370. package/browser/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
  371. package/browser/metadata-builder/MetadataUtils.js.map +1 -1
  372. package/browser/metadata-builder/RelationJoinColumnBuilder.js.map +1 -1
  373. package/browser/migration/Migration.js.map +1 -1
  374. package/browser/migration/MigrationExecutor.js.map +1 -1
  375. package/browser/migration/MigrationInterface.js.map +1 -1
  376. package/browser/naming-strategy/DefaultNamingStrategy.js.map +1 -1
  377. package/browser/naming-strategy/LegacyOracleNamingStrategy.js.map +1 -1
  378. package/browser/naming-strategy/NamingStrategyInterface.js.map +1 -1
  379. package/browser/persistence/EntityPersistExecutor.js.map +1 -1
  380. package/browser/persistence/Subject.js.map +1 -1
  381. package/browser/persistence/SubjectChangeMap.js.map +1 -1
  382. package/browser/persistence/SubjectChangedColumnsComputer.js.map +1 -1
  383. package/browser/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  384. package/browser/persistence/SubjectExecutor.js.map +1 -1
  385. package/browser/persistence/SubjectTopologicalSorter.js.map +1 -1
  386. package/browser/persistence/subject-builder/CascadesSubjectBuilder.js.map +1 -1
  387. package/browser/persistence/subject-builder/ManyToManySubjectBuilder.js.map +1 -1
  388. package/browser/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  389. package/browser/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js.map +1 -1
  390. package/browser/persistence/tree/ClosureSubjectExecutor.js.map +1 -1
  391. package/browser/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  392. package/browser/persistence/tree/NestedSetSubjectExecutor.js.map +1 -1
  393. package/browser/platform/BrowserConnectionOptionsReaderDummy.js.map +1 -1
  394. package/browser/platform/BrowserDirectoryExportedClassesLoader.js.map +1 -1
  395. package/browser/platform/BrowserDisabledDriversDummy.js.map +1 -1
  396. package/browser/platform/BrowserFileLoggerDummy.js.map +1 -1
  397. package/browser/platform/BrowserPlatformTools.js.map +1 -1
  398. package/browser/platform/PlatformTools.js.map +1 -1
  399. package/browser/query-builder/Alias.js.map +1 -1
  400. package/browser/query-builder/Brackets.js.map +1 -1
  401. package/browser/query-builder/DeleteQueryBuilder.js.map +1 -1
  402. package/browser/query-builder/InsertOrUpdateOptions.js.map +1 -1
  403. package/browser/query-builder/InsertQueryBuilder.js.map +1 -1
  404. package/browser/query-builder/JoinAttribute.js.map +1 -1
  405. package/browser/query-builder/JoinOptions.js.map +1 -1
  406. package/browser/query-builder/NotBrackets.js.map +1 -1
  407. package/browser/query-builder/QueryBuilder.js.map +1 -1
  408. package/browser/query-builder/QueryBuilderCte.js.map +1 -1
  409. package/browser/query-builder/QueryBuilderUtils.js.map +1 -1
  410. package/browser/query-builder/QueryExpressionMap.js.map +1 -1
  411. package/browser/query-builder/QueryPartialEntity.js.map +1 -1
  412. package/browser/query-builder/RelationIdLoader.js +3 -2
  413. package/browser/query-builder/RelationIdLoader.js.map +1 -1
  414. package/browser/query-builder/RelationLoader.js.map +1 -1
  415. package/browser/query-builder/RelationQueryBuilder.js.map +1 -1
  416. package/browser/query-builder/RelationRemover.js.map +1 -1
  417. package/browser/query-builder/RelationUpdater.js.map +1 -1
  418. package/browser/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
  419. package/browser/query-builder/SelectQuery.js.map +1 -1
  420. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  421. package/browser/query-builder/SelectQueryBuilderOption.js.map +1 -1
  422. package/browser/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  423. package/browser/query-builder/UpdateQueryBuilder.js.map +1 -1
  424. package/browser/query-builder/WhereClause.js.map +1 -1
  425. package/browser/query-builder/WhereExpressionBuilder.js.map +1 -1
  426. package/browser/query-builder/index.js.map +1 -1
  427. package/browser/query-builder/relation-count/RelationCountAttribute.js.map +1 -1
  428. package/browser/query-builder/relation-count/RelationCountLoadResult.js.map +1 -1
  429. package/browser/query-builder/relation-count/RelationCountLoader.js.map +1 -1
  430. package/browser/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.js.map +1 -1
  431. package/browser/query-builder/relation-id/RelationIdAttribute.js.map +1 -1
  432. package/browser/query-builder/relation-id/RelationIdLoadResult.js.map +1 -1
  433. package/browser/query-builder/relation-id/RelationIdLoader.js.map +1 -1
  434. package/browser/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.js.map +1 -1
  435. package/browser/query-builder/result/DeleteResult.js.map +1 -1
  436. package/browser/query-builder/result/InsertResult.js.map +1 -1
  437. package/browser/query-builder/result/UpdateResult.js.map +1 -1
  438. package/browser/query-builder/transformer/DocumentToEntityTransformer.js.map +1 -1
  439. package/browser/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.js.map +1 -1
  440. package/browser/query-builder/transformer/PlainObjectToNewEntityTransformer.js.map +1 -1
  441. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  442. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  443. package/browser/query-runner/QueryLock.js.map +1 -1
  444. package/browser/query-runner/QueryResult.js.map +1 -1
  445. package/browser/query-runner/QueryRunner.js.map +1 -1
  446. package/browser/repository/AbstractRepository.js.map +1 -1
  447. package/browser/repository/BaseEntity.js.map +1 -1
  448. package/browser/repository/EntityId.js.map +1 -1
  449. package/browser/repository/FindTreesOptions.js.map +1 -1
  450. package/browser/repository/MongoRepository.js.map +1 -1
  451. package/browser/repository/RemoveOptions.js.map +1 -1
  452. package/browser/repository/Repository.js.map +1 -1
  453. package/browser/repository/SaveOptions.js.map +1 -1
  454. package/browser/repository/TreeRepository.js.map +1 -1
  455. package/browser/repository/UpsertOptions.js.map +1 -1
  456. package/browser/schema-builder/MongoSchemaBuilder.js.map +1 -1
  457. package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  458. package/browser/schema-builder/SchemaBuilder.js.map +1 -1
  459. package/browser/schema-builder/options/TableCheckOptions.js.map +1 -1
  460. package/browser/schema-builder/options/TableColumnOptions.js.map +1 -1
  461. package/browser/schema-builder/options/TableExclusionOptions.js.map +1 -1
  462. package/browser/schema-builder/options/TableForeignKeyOptions.js.map +1 -1
  463. package/browser/schema-builder/options/TableIndexOptions.js.map +1 -1
  464. package/browser/schema-builder/options/TableOptions.js.map +1 -1
  465. package/browser/schema-builder/options/TableUniqueOptions.js.map +1 -1
  466. package/browser/schema-builder/options/ViewOptions.js.map +1 -1
  467. package/browser/schema-builder/table/Table.js.map +1 -1
  468. package/browser/schema-builder/table/TableCheck.js.map +1 -1
  469. package/browser/schema-builder/table/TableColumn.js.map +1 -1
  470. package/browser/schema-builder/table/TableExclusion.js.map +1 -1
  471. package/browser/schema-builder/table/TableForeignKey.js.map +1 -1
  472. package/browser/schema-builder/table/TableIndex.js.map +1 -1
  473. package/browser/schema-builder/table/TableUnique.js.map +1 -1
  474. package/browser/schema-builder/util/TableUtils.js.map +1 -1
  475. package/browser/schema-builder/util/ViewUtils.js.map +1 -1
  476. package/browser/schema-builder/view/View.js.map +1 -1
  477. package/browser/subscriber/Broadcaster.js.map +1 -1
  478. package/browser/subscriber/BroadcasterResult.js.map +1 -1
  479. package/browser/subscriber/EntitySubscriberInterface.js.map +1 -1
  480. package/browser/subscriber/event/InsertEvent.js.map +1 -1
  481. package/browser/subscriber/event/LoadEvent.js.map +1 -1
  482. package/browser/subscriber/event/QueryEvent.js.map +1 -1
  483. package/browser/subscriber/event/RecoverEvent.js.map +1 -1
  484. package/browser/subscriber/event/RemoveEvent.js.map +1 -1
  485. package/browser/subscriber/event/SoftRemoveEvent.js.map +1 -1
  486. package/browser/subscriber/event/TransactionCommitEvent.js.map +1 -1
  487. package/browser/subscriber/event/TransactionRollbackEvent.js.map +1 -1
  488. package/browser/subscriber/event/TransactionStartEvent.js.map +1 -1
  489. package/browser/subscriber/event/UpdateEvent.js.map +1 -1
  490. package/browser/util/ApplyValueTransformers.js.map +1 -1
  491. package/browser/util/DateUtils.js.map +1 -1
  492. package/browser/util/DepGraph.js.map +1 -1
  493. package/browser/util/DirectoryExportedClassesLoader.js.map +1 -1
  494. package/browser/util/ImportUtils.js.map +1 -1
  495. package/browser/util/InstanceChecker.js.map +1 -1
  496. package/browser/util/ObjectUtils.js.map +1 -1
  497. package/browser/util/OrmUtils.js.map +1 -1
  498. package/browser/util/PathUtils.js.map +1 -1
  499. package/browser/util/RandomGenerator.js.map +1 -1
  500. package/browser/util/StringUtils.js.map +1 -1
  501. package/browser/util/TreeRepositoryUtils.js.map +1 -1
  502. package/browser/util/VersionUtils.js.map +1 -1
  503. package/browser/util/escapeRegExp.js.map +1 -1
  504. package/cache/DbQueryResultCache.js.map +1 -1
  505. package/cache/QueryResultCache.js.map +1 -1
  506. package/cache/QueryResultCacheFactory.js.map +1 -1
  507. package/cache/QueryResultCacheOptions.js.map +1 -1
  508. package/cache/RedisQueryResultCache.js.map +1 -1
  509. package/cli-ts-node-commonjs.js.map +1 -1
  510. package/cli-ts-node-esm.js.map +1 -1
  511. package/cli.js.map +1 -1
  512. package/commands/CacheClearCommand.js.map +1 -1
  513. package/commands/CommandUtils.js.map +1 -1
  514. package/commands/EntityCreateCommand.js +6 -6
  515. package/commands/EntityCreateCommand.js.map +1 -1
  516. package/commands/InitCommand.js +302 -302
  517. package/commands/InitCommand.js.map +1 -1
  518. package/commands/MigrationCreateCommand.js +22 -22
  519. package/commands/MigrationCreateCommand.js.map +1 -1
  520. package/commands/MigrationGenerateCommand.js +31 -31
  521. package/commands/MigrationGenerateCommand.js.map +1 -1
  522. package/commands/MigrationRevertCommand.js.map +1 -1
  523. package/commands/MigrationRunCommand.js.map +1 -1
  524. package/commands/MigrationShowCommand.js.map +1 -1
  525. package/commands/QueryCommand.js.map +1 -1
  526. package/commands/SchemaDropCommand.js.map +1 -1
  527. package/commands/SchemaLogCommand.js.map +1 -1
  528. package/commands/SchemaSyncCommand.js.map +1 -1
  529. package/commands/SubscriberCreateCommand.js +6 -6
  530. package/commands/SubscriberCreateCommand.js.map +1 -1
  531. package/commands/VersionCommand.js.map +1 -1
  532. package/common/DeepPartial.js.map +1 -1
  533. package/common/EntityTarget.js.map +1 -1
  534. package/common/MixedList.js.map +1 -1
  535. package/common/NonNever.js.map +1 -1
  536. package/common/ObjectLiteral.js.map +1 -1
  537. package/common/ObjectType.js.map +1 -1
  538. package/common/PickKeysByType.js.map +1 -1
  539. package/common/RelationType.js.map +1 -1
  540. package/connection/BaseConnectionOptions.js.map +1 -1
  541. package/connection/Connection.js.map +1 -1
  542. package/connection/ConnectionManager.js.map +1 -1
  543. package/connection/ConnectionMetadataBuilder.js.map +1 -1
  544. package/connection/ConnectionOptions.js.map +1 -1
  545. package/connection/ConnectionOptionsReader.js.map +1 -1
  546. package/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  547. package/container.js.map +1 -1
  548. package/data-source/BaseDataSourceOptions.js.map +1 -1
  549. package/data-source/DataSource.js.map +1 -1
  550. package/data-source/DataSourceOptions.js.map +1 -1
  551. package/data-source/index.js.map +1 -1
  552. package/decorator/Check.js.map +1 -1
  553. package/decorator/EntityRepository.js.map +1 -1
  554. package/decorator/Exclusion.js.map +1 -1
  555. package/decorator/Generated.js.map +1 -1
  556. package/decorator/Index.js.map +1 -1
  557. package/decorator/Unique.js.map +1 -1
  558. package/decorator/columns/Column.js.map +1 -1
  559. package/decorator/columns/CreateDateColumn.js.map +1 -1
  560. package/decorator/columns/DeleteDateColumn.js.map +1 -1
  561. package/decorator/columns/ObjectIdColumn.js.map +1 -1
  562. package/decorator/columns/PrimaryColumn.js.map +1 -1
  563. package/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  564. package/decorator/columns/UpdateDateColumn.js.map +1 -1
  565. package/decorator/columns/VersionColumn.js.map +1 -1
  566. package/decorator/columns/ViewColumn.js.map +1 -1
  567. package/decorator/columns/VirtualColumn.js.map +1 -1
  568. package/decorator/entity/ChildEntity.js.map +1 -1
  569. package/decorator/entity/Entity.js.map +1 -1
  570. package/decorator/entity/TableInheritance.js.map +1 -1
  571. package/decorator/entity-view/ViewEntity.js.map +1 -1
  572. package/decorator/listeners/AfterInsert.js.map +1 -1
  573. package/decorator/listeners/AfterLoad.js.map +1 -1
  574. package/decorator/listeners/AfterRecover.js.map +1 -1
  575. package/decorator/listeners/AfterRemove.js.map +1 -1
  576. package/decorator/listeners/AfterSoftRemove.js.map +1 -1
  577. package/decorator/listeners/AfterUpdate.js.map +1 -1
  578. package/decorator/listeners/BeforeInsert.js.map +1 -1
  579. package/decorator/listeners/BeforeRecover.js.map +1 -1
  580. package/decorator/listeners/BeforeRemove.js.map +1 -1
  581. package/decorator/listeners/BeforeSoftRemove.js.map +1 -1
  582. package/decorator/listeners/BeforeUpdate.js.map +1 -1
  583. package/decorator/listeners/EventSubscriber.js.map +1 -1
  584. package/decorator/options/ColumnCommonOptions.js.map +1 -1
  585. package/decorator/options/ColumnEmbeddedOptions.js.map +1 -1
  586. package/decorator/options/ColumnEnumOptions.js.map +1 -1
  587. package/decorator/options/ColumnHstoreOptions.js.map +1 -1
  588. package/decorator/options/ColumnNumericOptions.js.map +1 -1
  589. package/decorator/options/ColumnOptions.js.map +1 -1
  590. package/decorator/options/ColumnWithLengthOptions.js.map +1 -1
  591. package/decorator/options/ColumnWithWidthOptions.js.map +1 -1
  592. package/decorator/options/EntityOptions.js.map +1 -1
  593. package/decorator/options/IndexOptions.js.map +1 -1
  594. package/decorator/options/JoinColumnOptions.js.map +1 -1
  595. package/decorator/options/JoinTableMultipleColumnsOptions.js.map +1 -1
  596. package/decorator/options/JoinTableOptions.js.map +1 -1
  597. package/decorator/options/PrimaryGeneratedColumnIdentityOptions.js.map +1 -1
  598. package/decorator/options/PrimaryGeneratedColumnNumericOptions.js.map +1 -1
  599. package/decorator/options/PrimaryGeneratedColumnUUIDOptions.js.map +1 -1
  600. package/decorator/options/RelationOptions.js.map +1 -1
  601. package/decorator/options/SpatialColumnOptions.js.map +1 -1
  602. package/decorator/options/TransactionOptions.js.map +1 -1
  603. package/decorator/options/UniqueOptions.js.map +1 -1
  604. package/decorator/options/ValueTransformer.js.map +1 -1
  605. package/decorator/options/ViewColumnOptions.js.map +1 -1
  606. package/decorator/options/ViewEntityOptions.js.map +1 -1
  607. package/decorator/options/VirtualColumnOptions.js.map +1 -1
  608. package/decorator/relations/JoinColumn.js.map +1 -1
  609. package/decorator/relations/JoinTable.js.map +1 -1
  610. package/decorator/relations/ManyToMany.js.map +1 -1
  611. package/decorator/relations/ManyToOne.js.map +1 -1
  612. package/decorator/relations/OneToMany.js.map +1 -1
  613. package/decorator/relations/OneToOne.js.map +1 -1
  614. package/decorator/relations/RelationCount.js.map +1 -1
  615. package/decorator/relations/RelationId.js.map +1 -1
  616. package/decorator/tree/Tree.js.map +1 -1
  617. package/decorator/tree/TreeChildren.js.map +1 -1
  618. package/decorator/tree/TreeLevelColumn.js.map +1 -1
  619. package/decorator/tree/TreeParent.js.map +1 -1
  620. package/driver/Driver.js.map +1 -1
  621. package/driver/DriverFactory.js.map +1 -1
  622. package/driver/DriverUtils.js.map +1 -1
  623. package/driver/Query.js.map +1 -1
  624. package/driver/SqlInMemory.js.map +1 -1
  625. package/driver/aurora-mysql/AuroraMysqlConnection.js.map +1 -1
  626. package/driver/aurora-mysql/AuroraMysqlConnectionCredentialsOptions.js.map +1 -1
  627. package/driver/aurora-mysql/AuroraMysqlConnectionOptions.js.map +1 -1
  628. package/driver/aurora-mysql/AuroraMysqlDriver.js.map +1 -1
  629. package/driver/aurora-mysql/AuroraMysqlQueryRunner.js +6 -9
  630. package/driver/aurora-mysql/AuroraMysqlQueryRunner.js.map +1 -1
  631. package/driver/aurora-postgres/AuroraPostgresConnectionOptions.js.map +1 -1
  632. package/driver/aurora-postgres/AuroraPostgresDriver.js.map +1 -1
  633. package/driver/aurora-postgres/AuroraPostgresQueryRunner.js +6 -9
  634. package/driver/aurora-postgres/AuroraPostgresQueryRunner.js.map +1 -1
  635. package/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js.map +1 -1
  636. package/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  637. package/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -1
  638. package/driver/capacitor/CapacitorConnectionOptions.js.map +1 -1
  639. package/driver/capacitor/CapacitorDriver.js.map +1 -1
  640. package/driver/capacitor/CapacitorQueryRunner.js.map +1 -1
  641. package/driver/cockroachdb/CockroachConnectionCredentialsOptions.js.map +1 -1
  642. package/driver/cockroachdb/CockroachConnectionOptions.js.map +1 -1
  643. package/driver/cockroachdb/CockroachDriver.js.map +1 -1
  644. package/driver/cockroachdb/CockroachQueryRunner.js +7 -11
  645. package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  646. package/driver/cordova/CordovaConnectionOptions.js.map +1 -1
  647. package/driver/cordova/CordovaDriver.js.map +1 -1
  648. package/driver/cordova/CordovaQueryRunner.js.map +1 -1
  649. package/driver/expo/ExpoConnectionOptions.js.map +1 -1
  650. package/driver/expo/ExpoDriver.js.map +1 -1
  651. package/driver/expo/ExpoQueryRunner.js.map +1 -1
  652. package/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  653. package/driver/mongodb/MongoDriver.js.map +1 -1
  654. package/driver/mongodb/MongoQueryRunner.js.map +1 -1
  655. package/driver/mongodb/bson.typings.js.map +1 -1
  656. package/driver/mongodb/typings.js.map +1 -1
  657. package/driver/mysql/MysqlConnectionCredentialsOptions.js.map +1 -1
  658. package/driver/mysql/MysqlConnectionOptions.js.map +1 -1
  659. package/driver/mysql/MysqlDriver.js.map +1 -1
  660. package/driver/mysql/MysqlQueryRunner.js +77 -80
  661. package/driver/mysql/MysqlQueryRunner.js.map +1 -1
  662. package/driver/nativescript/NativescriptConnectionOptions.js.map +1 -1
  663. package/driver/nativescript/NativescriptDriver.js.map +1 -1
  664. package/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  665. package/driver/oracle/OracleConnectionCredentialsOptions.js.map +1 -1
  666. package/driver/oracle/OracleConnectionOptions.js.map +1 -1
  667. package/driver/oracle/OracleDriver.js.map +1 -1
  668. package/driver/oracle/OracleQueryRunner.js +4 -6
  669. package/driver/oracle/OracleQueryRunner.js.map +1 -1
  670. package/driver/postgres/PostgresConnectionCredentialsOptions.js.map +1 -1
  671. package/driver/postgres/PostgresConnectionOptions.js.map +1 -1
  672. package/driver/postgres/PostgresDriver.js.map +1 -1
  673. package/driver/postgres/PostgresQueryRunner.js +6 -9
  674. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  675. package/driver/react-native/ReactNativeConnectionOptions.js.map +1 -1
  676. package/driver/react-native/ReactNativeDriver.js.map +1 -1
  677. package/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  678. package/driver/sap/SapConnectionCredentialsOptions.js.map +1 -1
  679. package/driver/sap/SapConnectionOptions.js.map +1 -1
  680. package/driver/sap/SapDriver.js.map +1 -1
  681. package/driver/sap/SapQueryRunner.js.map +1 -1
  682. package/driver/spanner/SpannerConnectionCredentialsOptions.js.map +1 -1
  683. package/driver/spanner/SpannerConnectionOptions.js.map +1 -1
  684. package/driver/spanner/SpannerDriver.js.map +1 -1
  685. package/driver/spanner/SpannerQueryRunner.js.map +1 -1
  686. package/driver/sqlite/SqliteConnectionOptions.js.map +1 -1
  687. package/driver/sqlite/SqliteDriver.js.map +1 -1
  688. package/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  689. package/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  690. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +6 -9
  691. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  692. package/driver/sqljs/SqljsConnectionOptions.js.map +1 -1
  693. package/driver/sqljs/SqljsDriver.js.map +1 -1
  694. package/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  695. package/driver/sqlserver/MssqlParameter.js.map +1 -1
  696. package/driver/sqlserver/SqlServerConnectionCredentialsOptions.js.map +1 -1
  697. package/driver/sqlserver/SqlServerConnectionOptions.js.map +1 -1
  698. package/driver/sqlserver/SqlServerDriver.js.map +1 -1
  699. package/driver/sqlserver/SqlServerQueryRunner.js +31 -32
  700. package/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  701. package/driver/sqlserver/authentication/AzureActiveDirectoryAccessTokenAuthentication.js.map +1 -1
  702. package/driver/sqlserver/authentication/AzureActiveDirectoryDefaultAuthentication.js.map +1 -1
  703. package/driver/sqlserver/authentication/AzureActiveDirectoryMsiAppServiceAuthentication.js.map +1 -1
  704. package/driver/sqlserver/authentication/AzureActiveDirectoryMsiVmAuthentication.js.map +1 -1
  705. package/driver/sqlserver/authentication/AzureActiveDirectoryPasswordAuthentication.js.map +1 -1
  706. package/driver/sqlserver/authentication/AzureActiveDirectoryServicePrincipalSecret.js.map +1 -1
  707. package/driver/sqlserver/authentication/DefaultAuthentication.js.map +1 -1
  708. package/driver/sqlserver/authentication/NtlmAuthentication.js.map +1 -1
  709. package/driver/types/ColumnTypes.js.map +1 -1
  710. package/driver/types/CteCapabilities.js.map +1 -1
  711. package/driver/types/DataTypeDefaults.js.map +1 -1
  712. package/driver/types/DatabaseType.js.map +1 -1
  713. package/driver/types/GeoJsonTypes.js.map +1 -1
  714. package/driver/types/IsolationLevel.js.map +1 -1
  715. package/driver/types/MappedColumnTypes.js.map +1 -1
  716. package/driver/types/MetadataTableType.js.map +1 -1
  717. package/driver/types/ReplicationMode.js.map +1 -1
  718. package/driver/types/UpsertType.js.map +1 -1
  719. package/entity-manager/EntityManager.js.map +1 -1
  720. package/entity-manager/EntityManagerFactory.js.map +1 -1
  721. package/entity-manager/MongoEntityManager.js.map +1 -1
  722. package/entity-manager/SqljsEntityManager.js.map +1 -1
  723. package/entity-schema/EntitySchema.js.map +1 -1
  724. package/entity-schema/EntitySchemaCheckOptions.js.map +1 -1
  725. package/entity-schema/EntitySchemaColumnOptions.js.map +1 -1
  726. package/entity-schema/EntitySchemaEmbeddedColumnOptions.js.map +1 -1
  727. package/entity-schema/EntitySchemaEmbeddedError.js.map +1 -1
  728. package/entity-schema/EntitySchemaExclusionOptions.js.map +1 -1
  729. package/entity-schema/EntitySchemaIndexOptions.js.map +1 -1
  730. package/entity-schema/EntitySchemaInheritanceOptions.js.map +1 -1
  731. package/entity-schema/EntitySchemaOptions.js.map +1 -1
  732. package/entity-schema/EntitySchemaRelationIdOptions.js.map +1 -1
  733. package/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
  734. package/entity-schema/EntitySchemaTransformer.js.map +1 -1
  735. package/entity-schema/EntitySchemaUniqueOptions.js.map +1 -1
  736. package/error/AlreadyHasActiveConnectionError.js.map +1 -1
  737. package/error/CannotAttachTreeChildrenEntityError.js.map +1 -1
  738. package/error/CannotConnectAlreadyConnectedError.js.map +1 -1
  739. package/error/CannotCreateEntityIdMapError.js.map +1 -1
  740. package/error/CannotDetermineEntityError.js.map +1 -1
  741. package/error/CannotExecuteNotConnectedError.js.map +1 -1
  742. package/error/CannotGetEntityManagerNotConnectedError.js.map +1 -1
  743. package/error/CannotReflectMethodParameterTypeError.js.map +1 -1
  744. package/error/CircularRelationsError.js.map +1 -1
  745. package/error/ColumnTypeUndefinedError.js.map +1 -1
  746. package/error/ConnectionIsNotSetError.js.map +1 -1
  747. package/error/ConnectionNotFoundError.js.map +1 -1
  748. package/error/CustomRepositoryCannotInheritRepositoryError.js.map +1 -1
  749. package/error/CustomRepositoryDoesNotHaveEntityError.js.map +1 -1
  750. package/error/CustomRepositoryNotFoundError.js.map +1 -1
  751. package/error/DataTypeNotSupportedError.js.map +1 -1
  752. package/error/DriverOptionNotSetError.js.map +1 -1
  753. package/error/DriverPackageNotInstalledError.js.map +1 -1
  754. package/error/EntityMetadataNotFoundError.js.map +1 -1
  755. package/error/EntityNotFoundError.js.map +1 -1
  756. package/error/EntityPropertyNotFoundError.js.map +1 -1
  757. package/error/FindRelationsNotFoundError.js.map +1 -1
  758. package/error/ForbiddenTransactionModeOverrideError.js.map +1 -1
  759. package/error/InitializedRelationError.js.map +1 -1
  760. package/error/InsertValuesMissingError.js.map +1 -1
  761. package/error/LimitOnUpdateNotSupportedError.js.map +1 -1
  762. package/error/LockNotSupportedOnGivenDriverError.js.map +1 -1
  763. package/error/MetadataAlreadyExistsError.js.map +1 -1
  764. package/error/MetadataWithSuchNameAlreadyExistsError.js.map +1 -1
  765. package/error/MissingDeleteDateColumnError.js.map +1 -1
  766. package/error/MissingDriverError.js.map +1 -1
  767. package/error/MissingJoinColumnError.js.map +1 -1
  768. package/error/MissingJoinTableError.js.map +1 -1
  769. package/error/MissingPrimaryColumnError.js.map +1 -1
  770. package/error/MustBeEntityError.js.map +1 -1
  771. package/error/NamingStrategyNotFoundError.js.map +1 -1
  772. package/error/NestedSetMultipleRootError.js.map +1 -1
  773. package/error/NoConnectionForRepositoryError.js.map +1 -1
  774. package/error/NoConnectionOptionError.js.map +1 -1
  775. package/error/NoNeedToReleaseEntityManagerError.js.map +1 -1
  776. package/error/NoVersionOrUpdateDateColumnError.js.map +1 -1
  777. package/error/OffsetWithoutLimitNotSupportedError.js.map +1 -1
  778. package/error/OptimisticLockCanNotBeUsedError.js.map +1 -1
  779. package/error/OptimisticLockVersionMismatchError.js.map +1 -1
  780. package/error/PersistedEntityNotFoundError.js.map +1 -1
  781. package/error/PessimisticLockTransactionRequiredError.js.map +1 -1
  782. package/error/PrimaryColumnCannotBeNullableError.js.map +1 -1
  783. package/error/QueryFailedError.js.map +1 -1
  784. package/error/QueryRunnerAlreadyReleasedError.js.map +1 -1
  785. package/error/QueryRunnerProviderAlreadyReleasedError.js.map +1 -1
  786. package/error/RepositoryNotTreeError.js.map +1 -1
  787. package/error/ReturningStatementNotSupportedError.js.map +1 -1
  788. package/error/SubjectRemovedAndUpdatedError.js.map +1 -1
  789. package/error/SubjectWithoutIdentifierError.js.map +1 -1
  790. package/error/TransactionAlreadyStartedError.js.map +1 -1
  791. package/error/TransactionNotStartedError.js.map +1 -1
  792. package/error/TreeRepositoryNotSupportedError.js.map +1 -1
  793. package/error/TypeORMError.js.map +1 -1
  794. package/error/UpdateValuesMissingError.js.map +1 -1
  795. package/error/UsingJoinColumnIsNotAllowedError.js.map +1 -1
  796. package/error/UsingJoinColumnOnlyOnOneSideAllowedError.js.map +1 -1
  797. package/error/UsingJoinTableIsNotAllowedError.js.map +1 -1
  798. package/error/UsingJoinTableOnlyOnOneSideAllowedError.js.map +1 -1
  799. package/error/index.js.map +1 -1
  800. package/find-options/EqualOperator.js.map +1 -1
  801. package/find-options/FindManyOptions.js.map +1 -1
  802. package/find-options/FindOneOptions.js.map +1 -1
  803. package/find-options/FindOperator.js.map +1 -1
  804. package/find-options/FindOperatorType.js.map +1 -1
  805. package/find-options/FindOptionsOrder.js.map +1 -1
  806. package/find-options/FindOptionsRelations.js.map +1 -1
  807. package/find-options/FindOptionsSelect.js.map +1 -1
  808. package/find-options/FindOptionsUtils.js.map +1 -1
  809. package/find-options/FindOptionsWhere.js.map +1 -1
  810. package/find-options/FindTreeOptions.js.map +1 -1
  811. package/find-options/JoinOptions.js.map +1 -1
  812. package/find-options/OrderByCondition.js.map +1 -1
  813. package/find-options/mongodb/MongoFindManyOptions.js.map +1 -1
  814. package/find-options/mongodb/MongoFindOneOptions.js.map +1 -1
  815. package/find-options/operator/And.js.map +1 -1
  816. package/find-options/operator/Any.js.map +1 -1
  817. package/find-options/operator/ArrayContainedBy.js.map +1 -1
  818. package/find-options/operator/ArrayContains.js.map +1 -1
  819. package/find-options/operator/ArrayOverlap.js.map +1 -1
  820. package/find-options/operator/Between.js.map +1 -1
  821. package/find-options/operator/Equal.js.map +1 -1
  822. package/find-options/operator/ILike.js.map +1 -1
  823. package/find-options/operator/In.js.map +1 -1
  824. package/find-options/operator/IsNull.js.map +1 -1
  825. package/find-options/operator/JsonContains.js.map +1 -1
  826. package/find-options/operator/LessThan.js.map +1 -1
  827. package/find-options/operator/LessThanOrEqual.js.map +1 -1
  828. package/find-options/operator/Like.js.map +1 -1
  829. package/find-options/operator/MoreThan.js.map +1 -1
  830. package/find-options/operator/MoreThanOrEqual.js.map +1 -1
  831. package/find-options/operator/Not.js.map +1 -1
  832. package/find-options/operator/Or.js.map +1 -1
  833. package/find-options/operator/Raw.js.map +1 -1
  834. package/globals.js.map +1 -1
  835. package/index.js.map +1 -1
  836. package/logger/AbstractLogger.js.map +1 -1
  837. package/logger/AdvancedConsoleLogger.js.map +1 -1
  838. package/logger/DebugLogger.js.map +1 -1
  839. package/logger/FileLogger.js.map +1 -1
  840. package/logger/Logger.js.map +1 -1
  841. package/logger/LoggerFactory.js.map +1 -1
  842. package/logger/LoggerOptions.js.map +1 -1
  843. package/logger/SimpleConsoleLogger.js.map +1 -1
  844. package/metadata/CheckMetadata.js.map +1 -1
  845. package/metadata/ColumnMetadata.js.map +1 -1
  846. package/metadata/EmbeddedMetadata.js.map +1 -1
  847. package/metadata/EntityListenerMetadata.js.map +1 -1
  848. package/metadata/EntityMetadata.js.map +1 -1
  849. package/metadata/ExclusionMetadata.js.map +1 -1
  850. package/metadata/ForeignKeyMetadata.js.map +1 -1
  851. package/metadata/IndexMetadata.js.map +1 -1
  852. package/metadata/RelationCountMetadata.js.map +1 -1
  853. package/metadata/RelationIdMetadata.js.map +1 -1
  854. package/metadata/RelationMetadata.js.map +1 -1
  855. package/metadata/UniqueMetadata.js.map +1 -1
  856. package/metadata/types/ClosureTreeOptions.js.map +1 -1
  857. package/metadata/types/DeferrableType.js.map +1 -1
  858. package/metadata/types/EventListenerTypes.js.map +1 -1
  859. package/metadata/types/OnDeleteType.js.map +1 -1
  860. package/metadata/types/OnUpdateType.js.map +1 -1
  861. package/metadata/types/PropertyTypeInFunction.js.map +1 -1
  862. package/metadata/types/RelationTypeInFunction.js.map +1 -1
  863. package/metadata/types/RelationTypes.js.map +1 -1
  864. package/metadata/types/TableTypes.js.map +1 -1
  865. package/metadata/types/TreeTypes.js.map +1 -1
  866. package/metadata-args/CheckMetadataArgs.js.map +1 -1
  867. package/metadata-args/ColumnMetadataArgs.js.map +1 -1
  868. package/metadata-args/DiscriminatorValueMetadataArgs.js.map +1 -1
  869. package/metadata-args/EmbeddedMetadataArgs.js.map +1 -1
  870. package/metadata-args/EntityListenerMetadataArgs.js.map +1 -1
  871. package/metadata-args/EntityRepositoryMetadataArgs.js.map +1 -1
  872. package/metadata-args/EntitySubscriberMetadataArgs.js.map +1 -1
  873. package/metadata-args/ExclusionMetadataArgs.js.map +1 -1
  874. package/metadata-args/GeneratedMetadataArgs.js.map +1 -1
  875. package/metadata-args/IndexMetadataArgs.js.map +1 -1
  876. package/metadata-args/InheritanceMetadataArgs.js.map +1 -1
  877. package/metadata-args/JoinColumnMetadataArgs.js.map +1 -1
  878. package/metadata-args/JoinTableMetadataArgs.js.map +1 -1
  879. package/metadata-args/MetadataArgsStorage.js.map +1 -1
  880. package/metadata-args/NamingStrategyMetadataArgs.js.map +1 -1
  881. package/metadata-args/RelationCountMetadataArgs.js.map +1 -1
  882. package/metadata-args/RelationIdMetadataArgs.js.map +1 -1
  883. package/metadata-args/RelationMetadataArgs.js.map +1 -1
  884. package/metadata-args/TableMetadataArgs.js.map +1 -1
  885. package/metadata-args/TransactionEntityMetadataArgs.js.map +1 -1
  886. package/metadata-args/TransactionRepositoryMetadataArgs.js.map +1 -1
  887. package/metadata-args/TreeMetadataArgs.js.map +1 -1
  888. package/metadata-args/UniqueMetadataArgs.js.map +1 -1
  889. package/metadata-args/types/ColumnMode.js.map +1 -1
  890. package/metadata-builder/ClosureJunctionEntityMetadataBuilder.js.map +1 -1
  891. package/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  892. package/metadata-builder/EntityMetadataValidator.js.map +1 -1
  893. package/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
  894. package/metadata-builder/MetadataUtils.js.map +1 -1
  895. package/metadata-builder/RelationJoinColumnBuilder.js.map +1 -1
  896. package/migration/Migration.js.map +1 -1
  897. package/migration/MigrationExecutor.js.map +1 -1
  898. package/migration/MigrationInterface.js.map +1 -1
  899. package/naming-strategy/DefaultNamingStrategy.js.map +1 -1
  900. package/naming-strategy/LegacyOracleNamingStrategy.js.map +1 -1
  901. package/naming-strategy/NamingStrategyInterface.js.map +1 -1
  902. package/package.json +1 -260
  903. package/persistence/EntityPersistExecutor.js.map +1 -1
  904. package/persistence/Subject.js.map +1 -1
  905. package/persistence/SubjectChangeMap.js.map +1 -1
  906. package/persistence/SubjectChangedColumnsComputer.js.map +1 -1
  907. package/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  908. package/persistence/SubjectExecutor.js.map +1 -1
  909. package/persistence/SubjectTopologicalSorter.js.map +1 -1
  910. package/persistence/subject-builder/CascadesSubjectBuilder.js.map +1 -1
  911. package/persistence/subject-builder/ManyToManySubjectBuilder.js.map +1 -1
  912. package/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  913. package/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js.map +1 -1
  914. package/persistence/tree/ClosureSubjectExecutor.js.map +1 -1
  915. package/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  916. package/persistence/tree/NestedSetSubjectExecutor.js.map +1 -1
  917. package/platform/PlatformTools.js.map +1 -1
  918. package/query-builder/Alias.js.map +1 -1
  919. package/query-builder/Brackets.js.map +1 -1
  920. package/query-builder/DeleteQueryBuilder.js.map +1 -1
  921. package/query-builder/InsertOrUpdateOptions.js.map +1 -1
  922. package/query-builder/InsertQueryBuilder.js.map +1 -1
  923. package/query-builder/JoinAttribute.js.map +1 -1
  924. package/query-builder/JoinOptions.js.map +1 -1
  925. package/query-builder/NotBrackets.js.map +1 -1
  926. package/query-builder/QueryBuilder.js.map +1 -1
  927. package/query-builder/QueryBuilderCte.js.map +1 -1
  928. package/query-builder/QueryBuilderUtils.js.map +1 -1
  929. package/query-builder/QueryExpressionMap.js.map +1 -1
  930. package/query-builder/QueryPartialEntity.js.map +1 -1
  931. package/query-builder/RelationIdLoader.js +3 -2
  932. package/query-builder/RelationIdLoader.js.map +1 -1
  933. package/query-builder/RelationLoader.js.map +1 -1
  934. package/query-builder/RelationQueryBuilder.js.map +1 -1
  935. package/query-builder/RelationRemover.js.map +1 -1
  936. package/query-builder/RelationUpdater.js.map +1 -1
  937. package/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
  938. package/query-builder/SelectQuery.js.map +1 -1
  939. package/query-builder/SelectQueryBuilder.js.map +1 -1
  940. package/query-builder/SelectQueryBuilderOption.js.map +1 -1
  941. package/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  942. package/query-builder/UpdateQueryBuilder.js.map +1 -1
  943. package/query-builder/WhereClause.js.map +1 -1
  944. package/query-builder/WhereExpressionBuilder.js.map +1 -1
  945. package/query-builder/index.js.map +1 -1
  946. package/query-builder/relation-count/RelationCountAttribute.js.map +1 -1
  947. package/query-builder/relation-count/RelationCountLoadResult.js.map +1 -1
  948. package/query-builder/relation-count/RelationCountLoader.js.map +1 -1
  949. package/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.js.map +1 -1
  950. package/query-builder/relation-id/RelationIdAttribute.js.map +1 -1
  951. package/query-builder/relation-id/RelationIdLoadResult.js.map +1 -1
  952. package/query-builder/relation-id/RelationIdLoader.js.map +1 -1
  953. package/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.js.map +1 -1
  954. package/query-builder/result/DeleteResult.js.map +1 -1
  955. package/query-builder/result/InsertResult.js.map +1 -1
  956. package/query-builder/result/UpdateResult.js.map +1 -1
  957. package/query-builder/transformer/DocumentToEntityTransformer.js.map +1 -1
  958. package/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.js.map +1 -1
  959. package/query-builder/transformer/PlainObjectToNewEntityTransformer.js.map +1 -1
  960. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  961. package/query-runner/BaseQueryRunner.js.map +1 -1
  962. package/query-runner/QueryLock.js.map +1 -1
  963. package/query-runner/QueryResult.js.map +1 -1
  964. package/query-runner/QueryRunner.js.map +1 -1
  965. package/repository/AbstractRepository.js.map +1 -1
  966. package/repository/BaseEntity.js.map +1 -1
  967. package/repository/EntityId.js.map +1 -1
  968. package/repository/FindTreesOptions.js.map +1 -1
  969. package/repository/MongoRepository.js.map +1 -1
  970. package/repository/RemoveOptions.js.map +1 -1
  971. package/repository/Repository.js.map +1 -1
  972. package/repository/SaveOptions.js.map +1 -1
  973. package/repository/TreeRepository.js.map +1 -1
  974. package/repository/UpsertOptions.js.map +1 -1
  975. package/schema-builder/MongoSchemaBuilder.js.map +1 -1
  976. package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  977. package/schema-builder/SchemaBuilder.js.map +1 -1
  978. package/schema-builder/options/TableCheckOptions.js.map +1 -1
  979. package/schema-builder/options/TableColumnOptions.js.map +1 -1
  980. package/schema-builder/options/TableExclusionOptions.js.map +1 -1
  981. package/schema-builder/options/TableForeignKeyOptions.js.map +1 -1
  982. package/schema-builder/options/TableIndexOptions.js.map +1 -1
  983. package/schema-builder/options/TableOptions.js.map +1 -1
  984. package/schema-builder/options/TableUniqueOptions.js.map +1 -1
  985. package/schema-builder/options/ViewOptions.js.map +1 -1
  986. package/schema-builder/table/Table.js.map +1 -1
  987. package/schema-builder/table/TableCheck.js.map +1 -1
  988. package/schema-builder/table/TableColumn.js.map +1 -1
  989. package/schema-builder/table/TableExclusion.js.map +1 -1
  990. package/schema-builder/table/TableForeignKey.js.map +1 -1
  991. package/schema-builder/table/TableIndex.js.map +1 -1
  992. package/schema-builder/table/TableUnique.js.map +1 -1
  993. package/schema-builder/util/TableUtils.js.map +1 -1
  994. package/schema-builder/util/ViewUtils.js.map +1 -1
  995. package/schema-builder/view/View.js.map +1 -1
  996. package/subscriber/Broadcaster.js.map +1 -1
  997. package/subscriber/BroadcasterResult.js.map +1 -1
  998. package/subscriber/EntitySubscriberInterface.js.map +1 -1
  999. package/subscriber/event/InsertEvent.js.map +1 -1
  1000. package/subscriber/event/LoadEvent.js.map +1 -1
  1001. package/subscriber/event/QueryEvent.js.map +1 -1
  1002. package/subscriber/event/RecoverEvent.js.map +1 -1
  1003. package/subscriber/event/RemoveEvent.js.map +1 -1
  1004. package/subscriber/event/SoftRemoveEvent.js.map +1 -1
  1005. package/subscriber/event/TransactionCommitEvent.js.map +1 -1
  1006. package/subscriber/event/TransactionRollbackEvent.js.map +1 -1
  1007. package/subscriber/event/TransactionStartEvent.js.map +1 -1
  1008. package/subscriber/event/UpdateEvent.js.map +1 -1
  1009. package/typeorm-class-transformer-shim.js +271 -271
  1010. package/typeorm-model-shim.js +295 -295
  1011. package/util/ApplyValueTransformers.js.map +1 -1
  1012. package/util/DateUtils.js.map +1 -1
  1013. package/util/DepGraph.js.map +1 -1
  1014. package/util/DirectoryExportedClassesLoader.js.map +1 -1
  1015. package/util/ImportUtils.js.map +1 -1
  1016. package/util/InstanceChecker.js.map +1 -1
  1017. package/util/ObjectUtils.js.map +1 -1
  1018. package/util/OrmUtils.js.map +1 -1
  1019. package/util/PathUtils.js.map +1 -1
  1020. package/util/RandomGenerator.js.map +1 -1
  1021. package/util/StringUtils.js.map +1 -1
  1022. package/util/TreeRepositoryUtils.js.map +1 -1
  1023. package/util/VersionUtils.js.map +1 -1
  1024. package/util/escapeRegExp.js.map +1 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/nativescript/NativescriptConnectionOptions.ts"],"names":[],"mappings":"","file":"NativescriptConnectionOptions.js","sourcesContent":["import { BaseDataSourceOptions } from \"../../data-source/BaseDataSourceOptions\"\r\n\r\n/**\r\n * NativeScript-specific connection options.\r\n */\r\nexport interface NativescriptConnectionOptions extends BaseDataSourceOptions {\r\n /**\r\n * Database type.\r\n */\r\n readonly type: \"nativescript\"\r\n\r\n /**\r\n * Database name.\r\n */\r\n readonly database: string\r\n\r\n /**\r\n * The driver object\r\n * you should pass `require('nativescript-sqlite') here\r\n */\r\n readonly driver: any\r\n\r\n /**\r\n * Whether to mark the mark the database as read only on open (iOS only).\r\n */\r\n readonly readOnly?: boolean\r\n\r\n /**\r\n * The key to use for for using/opening encrypted databases. (requires the \"Encrypted Plugin\")\r\n */\r\n readonly key?: string\r\n\r\n /**\r\n * Whether to enable background multitasking. All SQL is ran on a background worker thread. (requires the \"Commercial Plugin\")\r\n */\r\n readonly multithreading?: boolean\r\n\r\n /**\r\n * Migrates a Encrypted Sql database from v3 to the new v4. If you are a new user you do not need to set this flag as new created databases will already be in v4.\r\n * If you are upgrading a app that used v1.3.0 or earlier of NS-Sqlite-Encrypted; then you will probably want to set this flag to true. (requires the \"Encrypted Plugin\")\r\n */\r\n readonly migrate?: boolean\r\n\r\n /**\r\n * Flags to pass to SQLite when opening the database on iOS. (see https://www.sqlite.org/c3ref/open.html)\r\n */\r\n readonly iosFlags?: number\r\n\r\n /**\r\n * Flags to pass to SQLite when opening the database on Android. (see https://developer.android.com/reference/android/database/sqlite/SQLiteDatabase.html)\r\n */\r\n readonly androidFlags?: number\r\n\r\n readonly poolSize?: never\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/nativescript/NativescriptConnectionOptions.ts"],"names":[],"mappings":"","file":"NativescriptConnectionOptions.js","sourcesContent":["import { BaseDataSourceOptions } from \"../../data-source/BaseDataSourceOptions\"\n\n/**\n * NativeScript-specific connection options.\n */\nexport interface NativescriptConnectionOptions extends BaseDataSourceOptions {\n /**\n * Database type.\n */\n readonly type: \"nativescript\"\n\n /**\n * Database name.\n */\n readonly database: string\n\n /**\n * The driver object\n * you should pass `require('nativescript-sqlite') here\n */\n readonly driver: any\n\n /**\n * Whether to mark the mark the database as read only on open (iOS only).\n */\n readonly readOnly?: boolean\n\n /**\n * The key to use for for using/opening encrypted databases. (requires the \"Encrypted Plugin\")\n */\n readonly key?: string\n\n /**\n * Whether to enable background multitasking. All SQL is ran on a background worker thread. (requires the \"Commercial Plugin\")\n */\n readonly multithreading?: boolean\n\n /**\n * Migrates a Encrypted Sql database from v3 to the new v4. If you are a new user you do not need to set this flag as new created databases will already be in v4.\n * If you are upgrading a app that used v1.3.0 or earlier of NS-Sqlite-Encrypted; then you will probably want to set this flag to true. (requires the \"Encrypted Plugin\")\n */\n readonly migrate?: boolean\n\n /**\n * Flags to pass to SQLite when opening the database on iOS. (see https://www.sqlite.org/c3ref/open.html)\n */\n readonly iosFlags?: number\n\n /**\n * Flags to pass to SQLite when opening the database on Android. (see https://developer.android.com/reference/android/database/sqlite/SQLiteDatabase.html)\n */\n readonly androidFlags?: number\n\n readonly poolSize?: never\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/nativescript/NativescriptDriver.ts"],"names":[],"mappings":"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","file":"NativescriptDriver.js","sourcesContent":["import { AbstractSqliteDriver } from \"../sqlite-abstract/AbstractSqliteDriver\"\r\nimport { NativescriptConnectionOptions } from \"./NativescriptConnectionOptions\"\r\nimport { NativescriptQueryRunner } from \"./NativescriptQueryRunner\"\r\nimport { QueryRunner } from \"../../query-runner/QueryRunner\"\r\nimport { DataSource } from \"../../data-source/DataSource\"\r\nimport { DriverPackageNotInstalledError } from \"../../error/DriverPackageNotInstalledError\"\r\nimport { ColumnType } from \"../types/ColumnTypes\"\r\nimport { ReplicationMode } from \"../types/ReplicationMode\"\r\n\r\n/**\r\n * Organizes communication with sqlite DBMS within Nativescript.\r\n */\r\nexport class NativescriptDriver extends AbstractSqliteDriver {\r\n // -------------------------------------------------------------------------\r\n // Public Properties\r\n // -------------------------------------------------------------------------\r\n\r\n /**\r\n * Connection options.\r\n */\r\n options: NativescriptConnectionOptions\r\n\r\n /**\r\n * Nativescript driver module\r\n * this is most likely `nativescript-sqlite`\r\n * but user can pass his own\r\n */\r\n driver: any\r\n\r\n // -------------------------------------------------------------------------\r\n // Constructor\r\n // -------------------------------------------------------------------------\r\n\r\n constructor(connection: DataSource) {\r\n super(connection)\r\n\r\n this.connection = connection\r\n this.options = connection.options as NativescriptConnectionOptions\r\n this.database = this.options.database\r\n this.driver = this.options.driver\r\n\r\n // load sqlite package\r\n this.loadDependencies()\r\n }\r\n\r\n // -------------------------------------------------------------------------\r\n // Public Methods\r\n // -------------------------------------------------------------------------\r\n\r\n /**\r\n * Closes connection with database.\r\n */\r\n async disconnect(): Promise<void> {\r\n return new Promise<void>((ok, fail) => {\r\n this.queryRunner = undefined\r\n this.databaseConnection.close().then(ok).catch(fail)\r\n })\r\n }\r\n\r\n /**\r\n * Creates a query runner used to execute database queries.\r\n */\r\n createQueryRunner(mode: ReplicationMode): QueryRunner {\r\n if (!this.queryRunner) {\r\n this.queryRunner = new NativescriptQueryRunner(this)\r\n }\r\n\r\n return this.queryRunner\r\n }\r\n\r\n normalizeType(column: {\r\n type?: ColumnType\r\n length?: number | string\r\n precision?: number | null\r\n scale?: number\r\n }): string {\r\n if ((column.type as any) === Buffer) {\r\n return \"blob\"\r\n }\r\n\r\n return super.normalizeType(column)\r\n }\r\n // -------------------------------------------------------------------------\r\n // Protected Methods\r\n // -------------------------------------------------------------------------\r\n\r\n /**\r\n * Creates connection with the database.\r\n */\r\n protected createDatabaseConnection() {\r\n return new Promise<void>((ok, fail) => {\r\n const options = Object.assign(\r\n {},\r\n {\r\n readOnly: this.options.readOnly,\r\n key: this.options.key,\r\n multithreading: this.options.multithreading,\r\n migrate: this.options.migrate,\r\n iosFlags: this.options.iosFlags,\r\n androidFlags: this.options.androidFlags,\r\n },\r\n this.options.extra || {},\r\n )\r\n\r\n new this.sqlite(\r\n this.options.database,\r\n options,\r\n (err: Error, db: any): any => {\r\n if (err) return fail(err)\r\n\r\n // use object mode to work with TypeORM\r\n db.resultType(this.sqlite.RESULTSASOBJECT)\r\n\r\n // we need to enable foreign keys in sqlite to make sure all foreign key related features\r\n // working properly. this also makes onDelete work with sqlite.\r\n db.execSQL(\r\n `PRAGMA foreign_keys = ON`,\r\n [],\r\n (err: Error, result: any): any => {\r\n if (err) return fail(err)\r\n // We are all set\r\n ok(db)\r\n },\r\n )\r\n },\r\n )\r\n })\r\n }\r\n\r\n /**\r\n * If driver dependency is not given explicitly, then try to load it via \"require\".\r\n */\r\n protected loadDependencies(): void {\r\n this.sqlite = this.driver\r\n if (!this.driver) {\r\n throw new DriverPackageNotInstalledError(\r\n \"Nativescript\",\r\n \"nativescript-sqlite\",\r\n )\r\n }\r\n }\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/nativescript/NativescriptDriver.ts"],"names":[],"mappings":"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","file":"NativescriptDriver.js","sourcesContent":["import { AbstractSqliteDriver } from \"../sqlite-abstract/AbstractSqliteDriver\"\nimport { NativescriptConnectionOptions } from \"./NativescriptConnectionOptions\"\nimport { NativescriptQueryRunner } from \"./NativescriptQueryRunner\"\nimport { QueryRunner } from \"../../query-runner/QueryRunner\"\nimport { DataSource } from \"../../data-source/DataSource\"\nimport { DriverPackageNotInstalledError } from \"../../error/DriverPackageNotInstalledError\"\nimport { ColumnType } from \"../types/ColumnTypes\"\nimport { ReplicationMode } from \"../types/ReplicationMode\"\n\n/**\n * Organizes communication with sqlite DBMS within Nativescript.\n */\nexport class NativescriptDriver extends AbstractSqliteDriver {\n // -------------------------------------------------------------------------\n // Public Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection options.\n */\n options: NativescriptConnectionOptions\n\n /**\n * Nativescript driver module\n * this is most likely `nativescript-sqlite`\n * but user can pass his own\n */\n driver: any\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(connection: DataSource) {\n super(connection)\n\n this.connection = connection\n this.options = connection.options as NativescriptConnectionOptions\n this.database = this.options.database\n this.driver = this.options.driver\n\n // load sqlite package\n this.loadDependencies()\n }\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n /**\n * Closes connection with database.\n */\n async disconnect(): Promise<void> {\n return new Promise<void>((ok, fail) => {\n this.queryRunner = undefined\n this.databaseConnection.close().then(ok).catch(fail)\n })\n }\n\n /**\n * Creates a query runner used to execute database queries.\n */\n createQueryRunner(mode: ReplicationMode): QueryRunner {\n if (!this.queryRunner) {\n this.queryRunner = new NativescriptQueryRunner(this)\n }\n\n return this.queryRunner\n }\n\n normalizeType(column: {\n type?: ColumnType\n length?: number | string\n precision?: number | null\n scale?: number\n }): string {\n if ((column.type as any) === Buffer) {\n return \"blob\"\n }\n\n return super.normalizeType(column)\n }\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Creates connection with the database.\n */\n protected createDatabaseConnection() {\n return new Promise<void>((ok, fail) => {\n const options = Object.assign(\n {},\n {\n readOnly: this.options.readOnly,\n key: this.options.key,\n multithreading: this.options.multithreading,\n migrate: this.options.migrate,\n iosFlags: this.options.iosFlags,\n androidFlags: this.options.androidFlags,\n },\n this.options.extra || {},\n )\n\n new this.sqlite(\n this.options.database,\n options,\n (err: Error, db: any): any => {\n if (err) return fail(err)\n\n // use object mode to work with TypeORM\n db.resultType(this.sqlite.RESULTSASOBJECT)\n\n // we need to enable foreign keys in sqlite to make sure all foreign key related features\n // working properly. this also makes onDelete work with sqlite.\n db.execSQL(\n `PRAGMA foreign_keys = ON`,\n [],\n (err: Error, result: any): any => {\n if (err) return fail(err)\n // We are all set\n ok(db)\n },\n )\n },\n )\n })\n }\n\n /**\n * If driver dependency is not given explicitly, then try to load it via \"require\".\n */\n protected loadDependencies(): void {\n this.sqlite = this.driver\n if (!this.driver) {\n throw new DriverPackageNotInstalledError(\n \"Nativescript\",\n \"nativescript-sqlite\",\n )\n }\n }\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/nativescript/NativescriptQueryRunner.ts"],"names":[],"mappings":"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","file":"NativescriptQueryRunner.js","sourcesContent":["import { ObjectLiteral } from \"../../common/ObjectLiteral\"\r\nimport { QueryRunnerAlreadyReleasedError } from \"../../error/QueryRunnerAlreadyReleasedError\"\r\nimport { QueryFailedError } from \"../../error/QueryFailedError\"\r\nimport { AbstractSqliteQueryRunner } from \"../sqlite-abstract/AbstractSqliteQueryRunner\"\r\nimport { NativescriptDriver } from \"./NativescriptDriver\"\r\nimport { Broadcaster } from \"../../subscriber/Broadcaster\"\r\nimport { QueryResult } from \"../../query-runner/QueryResult\"\r\n\r\n/**\r\n * Runs queries on a single sqlite database connection.\r\n */\r\nexport class NativescriptQueryRunner extends AbstractSqliteQueryRunner {\r\n /**\r\n * Database driver used by connection.\r\n */\r\n driver: NativescriptDriver\r\n\r\n // -------------------------------------------------------------------------\r\n // Constructor\r\n // -------------------------------------------------------------------------\r\n\r\n constructor(driver: NativescriptDriver) {\r\n super()\r\n this.driver = driver\r\n this.connection = driver.connection\r\n this.broadcaster = new Broadcaster(this)\r\n }\r\n\r\n /**\r\n * Called before migrations are run.\r\n */\r\n async beforeMigration(): Promise<void> {\r\n await this.query(`PRAGMA foreign_keys = OFF`)\r\n }\r\n\r\n /**\r\n * Called after migrations are run.\r\n */\r\n async afterMigration(): Promise<void> {\r\n await this.query(`PRAGMA foreign_keys = ON`)\r\n }\r\n\r\n /**\r\n * Executes a given SQL query.\r\n */\r\n async query(\r\n query: string,\r\n parameters?: any[],\r\n useStructuredResult = false,\r\n ): Promise<any> {\r\n if (this.isReleased) {\r\n throw new QueryRunnerAlreadyReleasedError()\r\n }\r\n\r\n const connection = this.driver.connection\r\n\r\n return new Promise(async (ok, fail) => {\r\n const databaseConnection = await this.connect()\r\n const isInsertQuery = query.substr(0, 11) === \"INSERT INTO\"\r\n connection.logger.logQuery(query, parameters, this)\r\n\r\n const handler = (err: any, raw: any) => {\r\n // log slow queries if maxQueryExecution time is set\r\n const maxQueryExecutionTime =\r\n this.driver.options.maxQueryExecutionTime\r\n const queryEndTime = +new Date()\r\n const queryExecutionTime = queryEndTime - queryStartTime\r\n\r\n if (\r\n maxQueryExecutionTime &&\r\n queryExecutionTime > maxQueryExecutionTime\r\n ) {\r\n connection.logger.logQuerySlow(\r\n queryExecutionTime,\r\n query,\r\n parameters,\r\n this,\r\n )\r\n }\r\n\r\n if (err) {\r\n connection.logger.logQueryError(\r\n err,\r\n query,\r\n parameters,\r\n this,\r\n )\r\n fail(new QueryFailedError(query, parameters, err))\r\n }\r\n\r\n const result = new QueryResult()\r\n result.raw = raw\r\n\r\n if (!isInsertQuery && Array.isArray(raw)) {\r\n result.records = raw\r\n }\r\n\r\n if (useStructuredResult) {\r\n ok(result)\r\n } else {\r\n ok(result.raw)\r\n }\r\n }\r\n const queryStartTime = +new Date()\r\n\r\n if (isInsertQuery) {\r\n databaseConnection.execSQL(query, parameters, handler)\r\n } else {\r\n databaseConnection.all(query, parameters, handler)\r\n }\r\n })\r\n }\r\n\r\n // -------------------------------------------------------------------------\r\n // Protected Methods\r\n // -------------------------------------------------------------------------\r\n\r\n /**\r\n * Parametrizes given object of values. Used to create column=value queries.\r\n */\r\n protected parametrize(\r\n objectLiteral: ObjectLiteral,\r\n startIndex: number = 0,\r\n ): string[] {\r\n return Object.keys(objectLiteral).map((key, index) => `\"${key}\"` + \"=?\")\r\n }\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/nativescript/NativescriptQueryRunner.ts"],"names":[],"mappings":"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","file":"NativescriptQueryRunner.js","sourcesContent":["import { ObjectLiteral } from \"../../common/ObjectLiteral\"\nimport { QueryRunnerAlreadyReleasedError } from \"../../error/QueryRunnerAlreadyReleasedError\"\nimport { QueryFailedError } from \"../../error/QueryFailedError\"\nimport { AbstractSqliteQueryRunner } from \"../sqlite-abstract/AbstractSqliteQueryRunner\"\nimport { NativescriptDriver } from \"./NativescriptDriver\"\nimport { Broadcaster } from \"../../subscriber/Broadcaster\"\nimport { QueryResult } from \"../../query-runner/QueryResult\"\n\n/**\n * Runs queries on a single sqlite database connection.\n */\nexport class NativescriptQueryRunner extends AbstractSqliteQueryRunner {\n /**\n * Database driver used by connection.\n */\n driver: NativescriptDriver\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: NativescriptDriver) {\n super()\n this.driver = driver\n this.connection = driver.connection\n this.broadcaster = new Broadcaster(this)\n }\n\n /**\n * Called before migrations are run.\n */\n async beforeMigration(): Promise<void> {\n await this.query(`PRAGMA foreign_keys = OFF`)\n }\n\n /**\n * Called after migrations are run.\n */\n async afterMigration(): Promise<void> {\n await this.query(`PRAGMA foreign_keys = ON`)\n }\n\n /**\n * Executes a given SQL query.\n */\n async query(\n query: string,\n parameters?: any[],\n useStructuredResult = false,\n ): Promise<any> {\n if (this.isReleased) {\n throw new QueryRunnerAlreadyReleasedError()\n }\n\n const connection = this.driver.connection\n\n return new Promise(async (ok, fail) => {\n const databaseConnection = await this.connect()\n const isInsertQuery = query.substr(0, 11) === \"INSERT INTO\"\n connection.logger.logQuery(query, parameters, this)\n\n const handler = (err: any, raw: any) => {\n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime =\n this.driver.options.maxQueryExecutionTime\n const queryEndTime = +new Date()\n const queryExecutionTime = queryEndTime - queryStartTime\n\n if (\n maxQueryExecutionTime &&\n queryExecutionTime > maxQueryExecutionTime\n ) {\n connection.logger.logQuerySlow(\n queryExecutionTime,\n query,\n parameters,\n this,\n )\n }\n\n if (err) {\n connection.logger.logQueryError(\n err,\n query,\n parameters,\n this,\n )\n fail(new QueryFailedError(query, parameters, err))\n }\n\n const result = new QueryResult()\n result.raw = raw\n\n if (!isInsertQuery && Array.isArray(raw)) {\n result.records = raw\n }\n\n if (useStructuredResult) {\n ok(result)\n } else {\n ok(result.raw)\n }\n }\n const queryStartTime = +new Date()\n\n if (isInsertQuery) {\n databaseConnection.execSQL(query, parameters, handler)\n } else {\n databaseConnection.all(query, parameters, handler)\n }\n })\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Parametrizes given object of values. Used to create column=value queries.\n */\n protected parametrize(\n objectLiteral: ObjectLiteral,\n startIndex: number = 0,\n ): string[] {\n return Object.keys(objectLiteral).map((key, index) => `\"${key}\"` + \"=?\")\n }\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/oracle/OracleConnectionCredentialsOptions.ts"],"names":[],"mappings":"","file":"OracleConnectionCredentialsOptions.js","sourcesContent":["/**\r\n * Oracle specific connection credential options.\r\n */\r\nexport interface OracleConnectionCredentialsOptions {\r\n /**\r\n * Connection url where the connection is performed.\r\n */\r\n readonly url?: string\r\n\r\n /**\r\n * Database host.\r\n */\r\n readonly host?: string\r\n\r\n /**\r\n * Database host port.\r\n */\r\n readonly port?: number\r\n\r\n /**\r\n * Database username.\r\n */\r\n readonly username?: string\r\n\r\n /**\r\n * Database password.\r\n */\r\n readonly password?: string\r\n\r\n /**\r\n * Database name to connect to.\r\n */\r\n readonly database?: string\r\n\r\n /**\r\n * Connection SID.\r\n */\r\n readonly sid?: string\r\n\r\n /**\r\n * Connection Service Name.\r\n */\r\n readonly serviceName?: string\r\n\r\n /**\r\n * Embedded TNS Connection String\r\n */\r\n readonly connectString?: string\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/oracle/OracleConnectionCredentialsOptions.ts"],"names":[],"mappings":"","file":"OracleConnectionCredentialsOptions.js","sourcesContent":["/**\n * Oracle specific connection credential options.\n */\nexport interface OracleConnectionCredentialsOptions {\n /**\n * Connection url where the connection is performed.\n */\n readonly url?: string\n\n /**\n * Database host.\n */\n readonly host?: string\n\n /**\n * Database host port.\n */\n readonly port?: number\n\n /**\n * Database username.\n */\n readonly username?: string\n\n /**\n * Database password.\n */\n readonly password?: string\n\n /**\n * Database name to connect to.\n */\n readonly database?: string\n\n /**\n * Connection SID.\n */\n readonly sid?: string\n\n /**\n * Connection Service Name.\n */\n readonly serviceName?: string\n\n /**\n * Embedded TNS Connection String\n */\n readonly connectString?: string\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/oracle/OracleConnectionOptions.ts"],"names":[],"mappings":"","file":"OracleConnectionOptions.js","sourcesContent":["import { BaseDataSourceOptions } from \"../../data-source/BaseDataSourceOptions\"\r\nimport { OracleConnectionCredentialsOptions } from \"./OracleConnectionCredentialsOptions\"\r\n\r\nexport interface OracleThickModeOptions {\r\n binaryDir?: string\r\n configDir?: string\r\n driverName?: string\r\n errorUrl?: string\r\n libDir?: string\r\n}\r\n\r\n/**\r\n * Oracle-specific connection options.\r\n */\r\nexport interface OracleConnectionOptions\r\n extends BaseDataSourceOptions,\r\n OracleConnectionCredentialsOptions {\r\n /**\r\n * Database type.\r\n */\r\n readonly type: \"oracle\"\r\n\r\n /**\r\n * Schema name. By default is \"public\".\r\n */\r\n readonly schema?: string\r\n\r\n /**\r\n * The driver object\r\n * This defaults to require(\"oracledb\")\r\n */\r\n readonly driver?: any\r\n\r\n /**\r\n * Utilize the thick driver. Starting from oracledb version 6, it's necessary to set this to true when opting for the thick client usage.\r\n * Alternatively, an 'OracleThickModeOptions' object can be configured, which is used for the thick mode configuration by passing it to the 'node-oracledb' driver.\r\n * For additional information, refer to the details provided in the following link:\r\n * (https://node-oracledb.readthedocs.io/en/latest/api_manual/oracledb.html#oracledb.initOracleClient)\r\n */\r\n readonly thickMode?: boolean | OracleThickModeOptions\r\n\r\n /**\r\n * A boolean determining whether to pass time values in UTC or local time. (default: false).\r\n */\r\n readonly useUTC?: boolean\r\n\r\n /**\r\n * Replication setup.\r\n */\r\n readonly replication?: {\r\n /**\r\n * Master server used by orm to perform writes.\r\n */\r\n readonly master: OracleConnectionCredentialsOptions\r\n\r\n /**\r\n * List of read-from servers (slaves).\r\n */\r\n readonly slaves: OracleConnectionCredentialsOptions[]\r\n }\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/oracle/OracleConnectionOptions.ts"],"names":[],"mappings":"","file":"OracleConnectionOptions.js","sourcesContent":["import { BaseDataSourceOptions } from \"../../data-source/BaseDataSourceOptions\"\nimport { OracleConnectionCredentialsOptions } from \"./OracleConnectionCredentialsOptions\"\n\nexport interface OracleThickModeOptions {\n binaryDir?: string\n configDir?: string\n driverName?: string\n errorUrl?: string\n libDir?: string\n}\n\n/**\n * Oracle-specific connection options.\n */\nexport interface OracleConnectionOptions\n extends BaseDataSourceOptions,\n OracleConnectionCredentialsOptions {\n /**\n * Database type.\n */\n readonly type: \"oracle\"\n\n /**\n * Schema name. By default is \"public\".\n */\n readonly schema?: string\n\n /**\n * The driver object\n * This defaults to require(\"oracledb\")\n */\n readonly driver?: any\n\n /**\n * Utilize the thick driver. Starting from oracledb version 6, it's necessary to set this to true when opting for the thick client usage.\n * Alternatively, an 'OracleThickModeOptions' object can be configured, which is used for the thick mode configuration by passing it to the 'node-oracledb' driver.\n * For additional information, refer to the details provided in the following link:\n * (https://node-oracledb.readthedocs.io/en/latest/api_manual/oracledb.html#oracledb.initOracleClient)\n */\n readonly thickMode?: boolean | OracleThickModeOptions\n\n /**\n * A boolean determining whether to pass time values in UTC or local time. (default: false).\n */\n readonly useUTC?: boolean\n\n /**\n * Replication setup.\n */\n readonly replication?: {\n /**\n * Master server used by orm to perform writes.\n */\n readonly master: OracleConnectionCredentialsOptions\n\n /**\n * List of read-from servers (slaves).\n */\n readonly slaves: OracleConnectionCredentialsOptions[]\n }\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/oracle/OracleDriver.ts"],"names":[],"mappings":"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","file":"OracleDriver.js","sourcesContent":["import { Driver } from \"../Driver\"\r\nimport { ConnectionIsNotSetError } from \"../../error/ConnectionIsNotSetError\"\r\nimport { DriverPackageNotInstalledError } from \"../../error/DriverPackageNotInstalledError\"\r\nimport { CteCapabilities } from \"../types/CteCapabilities\"\r\nimport { OracleQueryRunner } from \"./OracleQueryRunner\"\r\nimport { ObjectLiteral } from \"../../common/ObjectLiteral\"\r\nimport { ColumnMetadata } from \"../../metadata/ColumnMetadata\"\r\nimport { DateUtils } from \"../../util/DateUtils\"\r\nimport { PlatformTools } from \"../../platform/PlatformTools\"\r\nimport { DataSource } from \"../../data-source/DataSource\"\r\nimport { RdbmsSchemaBuilder } from \"../../schema-builder/RdbmsSchemaBuilder\"\r\nimport { OracleConnectionOptions } from \"./OracleConnectionOptions\"\r\nimport { MappedColumnTypes } from \"../types/MappedColumnTypes\"\r\nimport { ColumnType } from \"../types/ColumnTypes\"\r\nimport { DataTypeDefaults } from \"../types/DataTypeDefaults\"\r\nimport { TableColumn } from \"../../schema-builder/table/TableColumn\"\r\nimport { OracleConnectionCredentialsOptions } from \"./OracleConnectionCredentialsOptions\"\r\nimport { DriverUtils } from \"../DriverUtils\"\r\nimport { EntityMetadata } from \"../../metadata/EntityMetadata\"\r\nimport { OrmUtils } from \"../../util/OrmUtils\"\r\nimport { ApplyValueTransformers } from \"../../util/ApplyValueTransformers\"\r\nimport { ReplicationMode } from \"../types/ReplicationMode\"\r\nimport { Table } from \"../../schema-builder/table/Table\"\r\nimport { View } from \"../../schema-builder/view/View\"\r\nimport { TableForeignKey } from \"../../schema-builder/table/TableForeignKey\"\r\nimport { TypeORMError } from \"../../error\"\r\nimport { InstanceChecker } from \"../../util/InstanceChecker\"\r\nimport { UpsertType } from \"../types/UpsertType\"\r\nimport { OnDeleteType } from \"../../metadata/types/OnDeleteType\"\r\nimport { OnUpdateType } from \"../../metadata/types/OnUpdateType\"\r\n\r\n/**\r\n * Organizes communication with Oracle RDBMS.\r\n */\r\nexport class OracleDriver implements Driver {\r\n // -------------------------------------------------------------------------\r\n // Public Properties\r\n // -------------------------------------------------------------------------\r\n\r\n /**\r\n * Connection used by driver.\r\n */\r\n connection: DataSource\r\n\r\n /**\r\n * Underlying oracle library.\r\n */\r\n oracle: any\r\n\r\n /**\r\n * Pool for master database.\r\n */\r\n master: any\r\n\r\n /**\r\n * Pool for slave databases.\r\n * Used in replication.\r\n */\r\n slaves: any[] = []\r\n\r\n // -------------------------------------------------------------------------\r\n // Public Implemented Properties\r\n // -------------------------------------------------------------------------\r\n\r\n /**\r\n * Connection options.\r\n */\r\n options: OracleConnectionOptions\r\n\r\n /**\r\n * Database name used to perform all write queries.\r\n */\r\n database?: string\r\n\r\n /**\r\n * Schema name used to perform all write queries.\r\n */\r\n schema?: string\r\n\r\n /**\r\n * Indicates if replication is enabled.\r\n */\r\n isReplicated: boolean = false\r\n\r\n /**\r\n * Indicates if tree tables are supported by this driver.\r\n */\r\n treeSupport = true\r\n\r\n /**\r\n * Represent transaction support by this driver\r\n */\r\n transactionSupport = \"nested\" as const\r\n\r\n /**\r\n * Gets list of supported column data types by a driver.\r\n *\r\n * @see https://www.techonthenet.com/oracle/datatypes.php\r\n * @see https://docs.oracle.com/cd/B28359_01/server.111/b28318/datatype.htm#CNCPT012\r\n */\r\n supportedDataTypes: ColumnType[] = [\r\n \"char\",\r\n \"nchar\",\r\n \"nvarchar2\",\r\n \"varchar2\",\r\n \"long\",\r\n \"raw\",\r\n \"long raw\",\r\n \"number\",\r\n \"numeric\",\r\n \"float\",\r\n \"dec\",\r\n \"decimal\",\r\n \"integer\",\r\n \"int\",\r\n \"smallint\",\r\n \"real\",\r\n \"double precision\",\r\n \"date\",\r\n \"timestamp\",\r\n \"timestamp with time zone\",\r\n \"timestamp with local time zone\",\r\n \"interval year to month\",\r\n \"interval day to second\",\r\n \"bfile\",\r\n \"blob\",\r\n \"clob\",\r\n \"nclob\",\r\n \"rowid\",\r\n \"urowid\",\r\n \"simple-json\",\r\n \"json\",\r\n ]\r\n\r\n /**\r\n * Returns type of upsert supported by driver if any\r\n */\r\n supportedUpsertTypes: UpsertType[] = []\r\n\r\n /**\r\n * Returns list of supported onDelete types by driver.\r\n * https://docs.oracle.com/en/database/oracle/oracle-database/21/sqlrf/sql-language-reference.pdf\r\n * Oracle does not support NO ACTION, but NO ACTION is set by default in EntityMetadata\r\n */\r\n supportedOnDeleteTypes: OnDeleteType[] = [\r\n \"CASCADE\",\r\n \"SET NULL\",\r\n \"NO ACTION\",\r\n ]\r\n\r\n /**\r\n * Returns list of supported onUpdate types by driver.\r\n * Oracle does not have onUpdate option, but we allow NO ACTION since it is set by default in EntityMetadata\r\n */\r\n supportedOnUpdateTypes: OnUpdateType[] = [\"NO ACTION\"]\r\n\r\n /**\r\n * Gets list of spatial column data types.\r\n */\r\n spatialTypes: ColumnType[] = []\r\n\r\n /**\r\n * Gets list of column data types that support length by a driver.\r\n */\r\n withLengthColumnTypes: ColumnType[] = [\r\n \"char\",\r\n \"nchar\",\r\n \"nvarchar2\",\r\n \"varchar2\",\r\n \"varchar\",\r\n \"raw\",\r\n ]\r\n\r\n /**\r\n * Gets list of column data types that support precision by a driver.\r\n */\r\n withPrecisionColumnTypes: ColumnType[] = [\r\n \"number\",\r\n \"float\",\r\n \"timestamp\",\r\n \"timestamp with time zone\",\r\n \"timestamp with local time zone\",\r\n ]\r\n\r\n /**\r\n * Gets list of column data types that support scale by a driver.\r\n */\r\n withScaleColumnTypes: ColumnType[] = [\"number\"]\r\n\r\n /**\r\n * Orm has special columns and we need to know what database column types should be for those types.\r\n * Column types are driver dependant.\r\n */\r\n mappedDataTypes: MappedColumnTypes = {\r\n createDate: \"timestamp\",\r\n createDateDefault: \"CURRENT_TIMESTAMP\",\r\n updateDate: \"timestamp\",\r\n updateDateDefault: \"CURRENT_TIMESTAMP\",\r\n deleteDate: \"timestamp\",\r\n deleteDateNullable: true,\r\n version: \"number\",\r\n treeLevel: \"number\",\r\n migrationId: \"number\",\r\n migrationName: \"varchar2\",\r\n migrationTimestamp: \"number\",\r\n cacheId: \"number\",\r\n cacheIdentifier: \"varchar2\",\r\n cacheTime: \"number\",\r\n cacheDuration: \"number\",\r\n cacheQuery: \"clob\",\r\n cacheResult: \"clob\",\r\n metadataType: \"varchar2\",\r\n metadataDatabase: \"varchar2\",\r\n metadataSchema: \"varchar2\",\r\n metadataTable: \"varchar2\",\r\n metadataName: \"varchar2\",\r\n metadataValue: \"clob\",\r\n }\r\n\r\n /**\r\n * The prefix used for the parameters\r\n */\r\n parametersPrefix: string = \":\"\r\n\r\n /**\r\n * Default values of length, precision and scale depends on column data type.\r\n * Used in the cases when length/precision/scale is not specified by user.\r\n */\r\n dataTypeDefaults: DataTypeDefaults = {\r\n char: { length: 1 },\r\n nchar: { length: 1 },\r\n varchar: { length: 255 },\r\n varchar2: { length: 255 },\r\n nvarchar2: { length: 255 },\r\n raw: { length: 2000 },\r\n float: { precision: 126 },\r\n timestamp: { precision: 6 },\r\n \"timestamp with time zone\": { precision: 6 },\r\n \"timestamp with local time zone\": { precision: 6 },\r\n }\r\n\r\n /**\r\n * Max length allowed by Oracle for aliases.\r\n * @see https://docs.oracle.com/database/121/SQLRF/sql_elements008.htm#SQLRF51129\r\n * > The following list of rules applies to both quoted and nonquoted identifiers unless otherwise indicated\r\n * > Names must be from 1 to 30 bytes long with these exceptions:\r\n * > [...]\r\n *\r\n * Since Oracle 12.2 (with a compatible driver/client), the limit has been set to 128.\r\n * @see https://docs.oracle.com/en/database/oracle/oracle-database/12.2/sqlrf/Database-Object-Names-and-Qualifiers.html\r\n *\r\n * > If COMPATIBLE is set to a value of 12.2 or higher, then names must be from 1 to 128 bytes long with these exceptions\r\n */\r\n maxAliasLength = 29\r\n\r\n cteCapabilities: CteCapabilities = {\r\n enabled: true,\r\n }\r\n\r\n dummyTableName = \"DUAL\"\r\n\r\n // -------------------------------------------------------------------------\r\n // Constructor\r\n // -------------------------------------------------------------------------\r\n\r\n constructor(connection: DataSource) {\r\n this.connection = connection\r\n this.options = connection.options as OracleConnectionOptions\r\n\r\n if (this.options.useUTC === true) {\r\n process.env.ORA_SDTZ = \"UTC\"\r\n }\r\n // load oracle package\r\n this.loadDependencies()\r\n\r\n this.database = DriverUtils.buildDriverOptions(\r\n this.options.replication\r\n ? this.options.replication.master\r\n : this.options,\r\n ).database\r\n this.schema = DriverUtils.buildDriverOptions(this.options).schema\r\n\r\n // Object.assign(connection.options, DriverUtils.buildDriverOptions(connection.options)); // todo: do it better way\r\n // validate options to make sure everything is set\r\n // if (!this.options.host)\r\n // throw new DriverOptionNotSetError(\"host\");\r\n // if (!this.options.username)\r\n // throw new DriverOptionNotSetError(\"username\");\r\n // if (!this.options.sid)\r\n // throw new DriverOptionNotSetError(\"sid\");\r\n //\r\n }\r\n\r\n // -------------------------------------------------------------------------\r\n // Public Methods\r\n // -------------------------------------------------------------------------\r\n\r\n /**\r\n * Performs connection to the database.\r\n * Based on pooling options, it can either create connection immediately,\r\n * either create a pool and create connection when needed.\r\n */\r\n async connect(): Promise<void> {\r\n this.oracle.fetchAsString = [this.oracle.DB_TYPE_CLOB]\r\n this.oracle.fetchAsBuffer = [this.oracle.DB_TYPE_BLOB]\r\n if (this.options.replication) {\r\n this.slaves = await Promise.all(\r\n this.options.replication.slaves.map((slave) => {\r\n return this.createPool(this.options, slave)\r\n }),\r\n )\r\n this.master = await this.createPool(\r\n this.options,\r\n this.options.replication.master,\r\n )\r\n } else {\r\n this.master = await this.createPool(this.options, this.options)\r\n }\r\n\r\n if (!this.database || !this.schema) {\r\n const queryRunner = await this.createQueryRunner(\"master\")\r\n\r\n if (!this.database) {\r\n this.database = await queryRunner.getCurrentDatabase()\r\n }\r\n\r\n if (!this.schema) {\r\n this.schema = await queryRunner.getCurrentSchema()\r\n }\r\n\r\n await queryRunner.release()\r\n }\r\n }\r\n\r\n /**\r\n * Makes any action after connection (e.g. create extensions in Postgres driver).\r\n */\r\n afterConnect(): Promise<void> {\r\n return Promise.resolve()\r\n }\r\n\r\n /**\r\n * Closes connection with the database.\r\n */\r\n async disconnect(): Promise<void> {\r\n if (!this.master)\r\n return Promise.reject(new ConnectionIsNotSetError(\"oracle\"))\r\n\r\n await this.closePool(this.master)\r\n await Promise.all(this.slaves.map((slave) => this.closePool(slave)))\r\n this.master = undefined\r\n this.slaves = []\r\n }\r\n\r\n /**\r\n * Creates a schema builder used to build and sync a schema.\r\n */\r\n createSchemaBuilder() {\r\n return new RdbmsSchemaBuilder(this.connection)\r\n }\r\n\r\n /**\r\n * Creates a query runner used to execute database queries.\r\n */\r\n createQueryRunner(mode: ReplicationMode) {\r\n return new OracleQueryRunner(this, mode)\r\n }\r\n\r\n /**\r\n * Replaces parameters in the given sql with special escaping character\r\n * and an array of parameter names to be passed to a query.\r\n */\r\n escapeQueryWithParameters(\r\n sql: string,\r\n parameters: ObjectLiteral,\r\n nativeParameters: ObjectLiteral,\r\n ): [string, any[]] {\r\n const escapedParameters: any[] = Object.keys(nativeParameters).map(\r\n (key) => {\r\n if (typeof nativeParameters[key] === \"boolean\")\r\n return nativeParameters[key] ? 1 : 0\r\n return nativeParameters[key]\r\n },\r\n )\r\n if (!parameters || !Object.keys(parameters).length)\r\n return [sql, escapedParameters]\r\n\r\n const parameterIndexMap = new Map<string, number>()\r\n sql = sql.replace(\r\n /:(\\.\\.\\.)?([A-Za-z0-9_.]+)/g,\r\n (full, isArray: string, key: string): string => {\r\n if (!parameters.hasOwnProperty(key)) {\r\n return full\r\n }\r\n\r\n if (parameterIndexMap.has(key)) {\r\n return this.parametersPrefix + parameterIndexMap.get(key)\r\n }\r\n\r\n let value: any = parameters[key]\r\n\r\n if (isArray) {\r\n return value\r\n .map((v: any) => {\r\n escapedParameters.push(v)\r\n return this.createParameter(\r\n key,\r\n escapedParameters.length - 1,\r\n )\r\n })\r\n .join(\", \")\r\n }\r\n\r\n if (typeof value === \"function\") {\r\n return value()\r\n }\r\n\r\n if (typeof value === \"boolean\") {\r\n return value ? \"1\" : \"0\"\r\n }\r\n\r\n escapedParameters.push(value)\r\n parameterIndexMap.set(key, escapedParameters.length)\r\n return this.createParameter(key, escapedParameters.length - 1)\r\n },\r\n ) // todo: make replace only in value statements, otherwise problems\r\n return [sql, escapedParameters]\r\n }\r\n\r\n /**\r\n * Escapes a column name.\r\n */\r\n escape(columnName: string): string {\r\n return `\"${columnName}\"`\r\n }\r\n\r\n /**\r\n * Build full table name with database name, schema name and table name.\r\n * Oracle does not support table schemas. One user can have only one schema.\r\n */\r\n buildTableName(\r\n tableName: string,\r\n schema?: string,\r\n database?: string,\r\n ): string {\r\n let tablePath = [tableName]\r\n\r\n if (schema) {\r\n tablePath.unshift(schema)\r\n }\r\n\r\n return tablePath.join(\".\")\r\n }\r\n\r\n /**\r\n * Parse a target table name or other types and return a normalized table definition.\r\n */\r\n parseTableName(\r\n target: EntityMetadata | Table | View | TableForeignKey | string,\r\n ): { database?: string; schema?: string; tableName: string } {\r\n const driverDatabase = this.database\r\n const driverSchema = this.schema\r\n\r\n if (InstanceChecker.isTable(target) || InstanceChecker.isView(target)) {\r\n const parsed = this.parseTableName(target.name)\r\n\r\n return {\r\n database: target.database || parsed.database || driverDatabase,\r\n schema: target.schema || parsed.schema || driverSchema,\r\n tableName: parsed.tableName,\r\n }\r\n }\r\n\r\n if (InstanceChecker.isTableForeignKey(target)) {\r\n const parsed = this.parseTableName(target.referencedTableName)\r\n\r\n return {\r\n database:\r\n target.referencedDatabase ||\r\n parsed.database ||\r\n driverDatabase,\r\n schema:\r\n target.referencedSchema || parsed.schema || driverSchema,\r\n tableName: parsed.tableName,\r\n }\r\n }\r\n\r\n if (InstanceChecker.isEntityMetadata(target)) {\r\n // EntityMetadata tableName is never a path\r\n\r\n return {\r\n database: target.database || driverDatabase,\r\n schema: target.schema || driverSchema,\r\n tableName: target.tableName,\r\n }\r\n }\r\n\r\n const parts = target.split(\".\")\r\n\r\n if (parts.length === 3) {\r\n return {\r\n database: parts[0] || driverDatabase,\r\n schema: parts[1] || driverSchema,\r\n tableName: parts[2],\r\n }\r\n } else if (parts.length === 2) {\r\n return {\r\n database: driverDatabase,\r\n schema: parts[0] || driverSchema,\r\n tableName: parts[1],\r\n }\r\n } else {\r\n return {\r\n database: driverDatabase,\r\n schema: driverSchema,\r\n tableName: target,\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Prepares given value to a value to be persisted, based on its column type and metadata.\r\n */\r\n preparePersistentValue(value: any, columnMetadata: ColumnMetadata): any {\r\n if (columnMetadata.transformer)\r\n value = ApplyValueTransformers.transformTo(\r\n columnMetadata.transformer,\r\n value,\r\n )\r\n\r\n if (value === null || value === undefined) return value\r\n\r\n if (columnMetadata.type === Boolean) {\r\n return value ? 1 : 0\r\n } else if (columnMetadata.type === \"date\") {\r\n if (typeof value === \"string\") value = value.replace(/[^0-9-]/g, \"\")\r\n return () =>\r\n `TO_DATE('${DateUtils.mixedDateToDateString(\r\n value,\r\n )}', 'YYYY-MM-DD')`\r\n } else if (\r\n columnMetadata.type === Date ||\r\n columnMetadata.type === \"timestamp\" ||\r\n columnMetadata.type === \"timestamp with time zone\" ||\r\n columnMetadata.type === \"timestamp with local time zone\"\r\n ) {\r\n return DateUtils.mixedDateToDate(value)\r\n } else if (columnMetadata.type === \"simple-array\") {\r\n return DateUtils.simpleArrayToString(value)\r\n } else if (columnMetadata.type === \"simple-json\") {\r\n return DateUtils.simpleJsonToString(value)\r\n } else if (columnMetadata.type === \"json\") {\r\n return DateUtils.simpleJsonToString(value)\r\n }\r\n\r\n return value\r\n }\r\n\r\n /**\r\n * Prepares given value to a value to be persisted, based on its column type or metadata.\r\n */\r\n prepareHydratedValue(value: any, columnMetadata: ColumnMetadata): any {\r\n if (value === null || value === undefined)\r\n return columnMetadata.transformer\r\n ? ApplyValueTransformers.transformFrom(\r\n columnMetadata.transformer,\r\n value,\r\n )\r\n : value\r\n\r\n if (columnMetadata.type === Boolean) {\r\n value = !!value\r\n } else if (columnMetadata.type === \"date\") {\r\n value = DateUtils.mixedDateToDateString(value)\r\n } else if (columnMetadata.type === \"time\") {\r\n value = DateUtils.mixedTimeToString(value)\r\n } else if (\r\n columnMetadata.type === Date ||\r\n columnMetadata.type === \"timestamp\" ||\r\n columnMetadata.type === \"timestamp with time zone\" ||\r\n columnMetadata.type === \"timestamp with local time zone\"\r\n ) {\r\n value = DateUtils.normalizeHydratedDate(value)\r\n } else if (columnMetadata.type === \"simple-array\") {\r\n value = DateUtils.stringToSimpleArray(value)\r\n } else if (columnMetadata.type === \"simple-json\") {\r\n value = DateUtils.stringToSimpleJson(value)\r\n } else if (columnMetadata.type === Number) {\r\n // convert to number if number\r\n value = !isNaN(+value) ? parseInt(value) : value\r\n }\r\n\r\n if (columnMetadata.transformer)\r\n value = ApplyValueTransformers.transformFrom(\r\n columnMetadata.transformer,\r\n value,\r\n )\r\n\r\n return value\r\n }\r\n\r\n /**\r\n * Creates a database type from a given column metadata.\r\n */\r\n normalizeType(column: {\r\n type?: ColumnType\r\n length?: number | string\r\n precision?: number | null\r\n scale?: number\r\n isArray?: boolean\r\n }): string {\r\n if (\r\n column.type === Number ||\r\n column.type === Boolean ||\r\n column.type === \"numeric\" ||\r\n column.type === \"dec\" ||\r\n column.type === \"decimal\" ||\r\n column.type === \"int\" ||\r\n column.type === \"integer\" ||\r\n column.type === \"smallint\"\r\n ) {\r\n return \"number\"\r\n } else if (\r\n column.type === \"real\" ||\r\n column.type === \"double precision\"\r\n ) {\r\n return \"float\"\r\n } else if (column.type === String || column.type === \"varchar\") {\r\n return \"varchar2\"\r\n } else if (column.type === Date) {\r\n return \"timestamp\"\r\n } else if ((column.type as any) === Buffer) {\r\n return \"blob\"\r\n } else if (column.type === \"uuid\") {\r\n return \"varchar2\"\r\n } else if (column.type === \"simple-array\") {\r\n return \"clob\"\r\n } else if (column.type === \"simple-json\") {\r\n return \"clob\"\r\n } else if (column.type === \"json\") {\r\n return \"json\"\r\n } else {\r\n return (column.type as string) || \"\"\r\n }\r\n }\r\n\r\n /**\r\n * Normalizes \"default\" value of the column.\r\n */\r\n normalizeDefault(columnMetadata: ColumnMetadata): string | undefined {\r\n const defaultValue = columnMetadata.default\r\n\r\n if (typeof defaultValue === \"number\") {\r\n return \"\" + defaultValue\r\n }\r\n\r\n if (typeof defaultValue === \"boolean\") {\r\n return defaultValue ? \"1\" : \"0\"\r\n }\r\n\r\n if (typeof defaultValue === \"function\") {\r\n return defaultValue()\r\n }\r\n\r\n if (typeof defaultValue === \"string\") {\r\n return `'${defaultValue}'`\r\n }\r\n\r\n if (defaultValue === null || defaultValue === undefined) {\r\n return undefined\r\n }\r\n\r\n return `${defaultValue}`\r\n }\r\n\r\n /**\r\n * Normalizes \"isUnique\" value of the column.\r\n */\r\n normalizeIsUnique(column: ColumnMetadata): boolean {\r\n return column.entityMetadata.uniques.some(\r\n (uq) => uq.columns.length === 1 && uq.columns[0] === column,\r\n )\r\n }\r\n\r\n /**\r\n * Calculates column length taking into account the default length values.\r\n */\r\n getColumnLength(column: ColumnMetadata | TableColumn): string {\r\n if (column.length) return column.length.toString()\r\n\r\n switch (column.type) {\r\n case String:\r\n case \"varchar\":\r\n case \"varchar2\":\r\n case \"nvarchar2\":\r\n return \"255\"\r\n case \"raw\":\r\n return \"2000\"\r\n case \"uuid\":\r\n return \"36\"\r\n default:\r\n return \"\"\r\n }\r\n }\r\n\r\n createFullType(column: TableColumn): string {\r\n let type = column.type\r\n\r\n // used 'getColumnLength()' method, because in Oracle column length is required for some data types.\r\n if (this.getColumnLength(column)) {\r\n type += `(${this.getColumnLength(column)})`\r\n } else if (\r\n column.precision !== null &&\r\n column.precision !== undefined &&\r\n column.scale !== null &&\r\n column.scale !== undefined\r\n ) {\r\n type += \"(\" + column.precision + \",\" + column.scale + \")\"\r\n } else if (\r\n column.precision !== null &&\r\n column.precision !== undefined\r\n ) {\r\n type += \"(\" + column.precision + \")\"\r\n }\r\n\r\n if (column.type === \"timestamp with time zone\") {\r\n type =\r\n \"TIMESTAMP\" +\r\n (column.precision !== null && column.precision !== undefined\r\n ? \"(\" + column.precision + \")\"\r\n : \"\") +\r\n \" WITH TIME ZONE\"\r\n } else if (column.type === \"timestamp with local time zone\") {\r\n type =\r\n \"TIMESTAMP\" +\r\n (column.precision !== null && column.precision !== undefined\r\n ? \"(\" + column.precision + \")\"\r\n : \"\") +\r\n \" WITH LOCAL TIME ZONE\"\r\n }\r\n\r\n if (column.isArray) type += \" array\"\r\n\r\n return type\r\n }\r\n\r\n /**\r\n * Obtains a new database connection to a master server.\r\n * Used for replication.\r\n * If replication is not setup then returns default connection's database connection.\r\n */\r\n obtainMasterConnection(): Promise<any> {\r\n return new Promise<any>((ok, fail) => {\r\n if (!this.master) {\r\n return fail(new TypeORMError(\"Driver not Connected\"))\r\n }\r\n\r\n this.master.getConnection(\r\n (err: any, connection: any, release: Function) => {\r\n if (err) return fail(err)\r\n ok(connection)\r\n },\r\n )\r\n })\r\n }\r\n\r\n /**\r\n * Obtains a new database connection to a slave server.\r\n * Used for replication.\r\n * If replication is not setup then returns master (default) connection's database connection.\r\n */\r\n obtainSlaveConnection(): Promise<any> {\r\n if (!this.slaves.length) return this.obtainMasterConnection()\r\n\r\n return new Promise<any>((ok, fail) => {\r\n const random = Math.floor(Math.random() * this.slaves.length)\r\n\r\n this.slaves[random].getConnection((err: any, connection: any) => {\r\n if (err) return fail(err)\r\n ok(connection)\r\n })\r\n })\r\n }\r\n\r\n /**\r\n * Creates generated map of values generated or returned by database after INSERT query.\r\n */\r\n createGeneratedMap(metadata: EntityMetadata, insertResult: ObjectLiteral) {\r\n if (!insertResult) return undefined\r\n\r\n return Object.keys(insertResult).reduce((map, key) => {\r\n const column = metadata.findColumnWithDatabaseName(key)\r\n if (column) {\r\n OrmUtils.mergeDeep(\r\n map,\r\n column.createValueMap(\r\n this.prepareHydratedValue(insertResult[key], column),\r\n ),\r\n )\r\n }\r\n return map\r\n }, {} as ObjectLiteral)\r\n }\r\n\r\n /**\r\n * Differentiate columns of this table and columns from the given column metadatas columns\r\n * and returns only changed.\r\n */\r\n findChangedColumns(\r\n tableColumns: TableColumn[],\r\n columnMetadatas: ColumnMetadata[],\r\n ): ColumnMetadata[] {\r\n return columnMetadatas.filter((columnMetadata) => {\r\n const tableColumn = tableColumns.find(\r\n (c) => c.name === columnMetadata.databaseName,\r\n )\r\n if (!tableColumn) return false // we don't need new columns, we only need exist and changed\r\n\r\n const isColumnChanged =\r\n tableColumn.name !== columnMetadata.databaseName ||\r\n tableColumn.type !== this.normalizeType(columnMetadata) ||\r\n tableColumn.length !== this.getColumnLength(columnMetadata) ||\r\n tableColumn.precision !== columnMetadata.precision ||\r\n tableColumn.scale !== columnMetadata.scale ||\r\n // || tableColumn.comment !== columnMetadata.comment\r\n tableColumn.default !== this.normalizeDefault(columnMetadata) ||\r\n tableColumn.isPrimary !== columnMetadata.isPrimary ||\r\n tableColumn.isNullable !== columnMetadata.isNullable ||\r\n tableColumn.asExpression !== columnMetadata.asExpression ||\r\n tableColumn.generatedType !== columnMetadata.generatedType ||\r\n tableColumn.isUnique !==\r\n this.normalizeIsUnique(columnMetadata) ||\r\n (columnMetadata.generationStrategy !== \"uuid\" &&\r\n tableColumn.isGenerated !== columnMetadata.isGenerated)\r\n\r\n // DEBUG SECTION\r\n // if (isColumnChanged) {\r\n // console.log(\"table:\", columnMetadata.entityMetadata.tableName)\r\n // console.log(\r\n // \"name:\",\r\n // tableColumn.name,\r\n // columnMetadata.databaseName,\r\n // )\r\n // console.log(\r\n // \"type:\",\r\n // tableColumn.type,\r\n // this.normalizeType(columnMetadata),\r\n // )\r\n // console.log(\r\n // \"length:\",\r\n // tableColumn.length,\r\n // columnMetadata.length,\r\n // )\r\n // console.log(\r\n // \"precision:\",\r\n // tableColumn.precision,\r\n // columnMetadata.precision,\r\n // )\r\n // console.log(\"scale:\", tableColumn.scale, columnMetadata.scale)\r\n // console.log(\r\n // \"comment:\",\r\n // tableColumn.comment,\r\n // columnMetadata.comment,\r\n // )\r\n // console.log(\r\n // \"default:\",\r\n // tableColumn.default,\r\n // this.normalizeDefault(columnMetadata),\r\n // )\r\n // console.log(\r\n // \"enum:\",\r\n // tableColumn.enum &&\r\n // columnMetadata.enum &&\r\n // !OrmUtils.isArraysEqual(\r\n // tableColumn.enum,\r\n // columnMetadata.enum.map((val) => val + \"\"),\r\n // ),\r\n // )\r\n // console.log(\r\n // \"onUpdate:\",\r\n // tableColumn.onUpdate,\r\n // columnMetadata.onUpdate,\r\n // )\r\n // console.log(\r\n // \"isPrimary:\",\r\n // tableColumn.isPrimary,\r\n // columnMetadata.isPrimary,\r\n // )\r\n // console.log(\r\n // \"isNullable:\",\r\n // tableColumn.isNullable,\r\n // columnMetadata.isNullable,\r\n // )\r\n // console.log(\r\n // \"asExpression:\",\r\n // tableColumn.asExpression,\r\n // columnMetadata.asExpression,\r\n // )\r\n // console.log(\r\n // \"generatedType:\",\r\n // tableColumn.generatedType,\r\n // columnMetadata.generatedType,\r\n // )\r\n // console.log(\r\n // \"isUnique:\",\r\n // tableColumn.isUnique,\r\n // this.normalizeIsUnique(columnMetadata),\r\n // )\r\n // console.log(\r\n // \"isGenerated:\",\r\n // tableColumn.isGenerated,\r\n // columnMetadata.isGenerated,\r\n // )\r\n // console.log(\"==========================================\")\r\n // }\r\n\r\n return isColumnChanged\r\n })\r\n }\r\n\r\n /**\r\n * Returns true if driver supports RETURNING / OUTPUT statement.\r\n */\r\n isReturningSqlSupported(): boolean {\r\n return true\r\n }\r\n\r\n /**\r\n * Returns true if driver supports uuid values generation on its own.\r\n */\r\n isUUIDGenerationSupported(): boolean {\r\n return false\r\n }\r\n\r\n /**\r\n * Returns true if driver supports fulltext indices.\r\n */\r\n isFullTextColumnTypeSupported(): boolean {\r\n return false\r\n }\r\n\r\n /**\r\n * Creates an escaped parameter.\r\n */\r\n createParameter(parameterName: string, index: number): string {\r\n return this.parametersPrefix + (index + 1)\r\n }\r\n\r\n /**\r\n * Converts column type in to native oracle type.\r\n */\r\n columnTypeToNativeParameter(type: ColumnType): any {\r\n switch (this.normalizeType({ type: type as any })) {\r\n case \"number\":\r\n case \"numeric\":\r\n case \"int\":\r\n case \"integer\":\r\n case \"smallint\":\r\n case \"dec\":\r\n case \"decimal\":\r\n return this.oracle.DB_TYPE_NUMBER\r\n case \"char\":\r\n case \"nchar\":\r\n case \"nvarchar2\":\r\n case \"varchar2\":\r\n return this.oracle.DB_TYPE_VARCHAR\r\n case \"blob\":\r\n return this.oracle.DB_TYPE_BLOB\r\n case \"simple-json\":\r\n case \"clob\":\r\n return this.oracle.DB_TYPE_CLOB\r\n case \"date\":\r\n case \"timestamp\":\r\n case \"timestamp with time zone\":\r\n case \"timestamp with local time zone\":\r\n return this.oracle.DB_TYPE_TIMESTAMP\r\n case \"json\":\r\n return this.oracle.DB_TYPE_JSON\r\n }\r\n }\r\n\r\n // -------------------------------------------------------------------------\r\n // Protected Methods\r\n // -------------------------------------------------------------------------\r\n\r\n /**\r\n * Loads all driver dependencies.\r\n */\r\n protected loadDependencies(): void {\r\n try {\r\n const oracle = this.options.driver || PlatformTools.load(\"oracledb\")\r\n this.oracle = oracle\r\n } catch (e) {\r\n throw new DriverPackageNotInstalledError(\"Oracle\", \"oracledb\")\r\n }\r\n const thickMode = this.options.thickMode\r\n if (thickMode) {\r\n typeof thickMode === \"object\"\r\n ? this.oracle.initOracleClient(thickMode)\r\n : this.oracle.initOracleClient()\r\n }\r\n }\r\n\r\n /**\r\n * Creates a new connection pool for a given database credentials.\r\n */\r\n protected async createPool(\r\n options: OracleConnectionOptions,\r\n credentials: OracleConnectionCredentialsOptions,\r\n ): Promise<any> {\r\n credentials = Object.assign(\r\n {},\r\n credentials,\r\n DriverUtils.buildDriverOptions(credentials),\r\n ) // todo: do it better way\r\n\r\n if (!credentials.connectString) {\r\n let address = `(PROTOCOL=TCP)`\r\n\r\n if (credentials.host) {\r\n address += `(HOST=${credentials.host})`\r\n }\r\n\r\n if (credentials.port) {\r\n address += `(PORT=${credentials.port})`\r\n }\r\n\r\n let connectData = `(SERVER=DEDICATED)`\r\n\r\n if (credentials.sid) {\r\n connectData += `(SID=${credentials.sid})`\r\n }\r\n\r\n if (credentials.serviceName) {\r\n connectData += `(SERVICE_NAME=${credentials.serviceName})`\r\n }\r\n\r\n const connectString = `(DESCRIPTION=(ADDRESS=${address})(CONNECT_DATA=${connectData}))`\r\n Object.assign(credentials, { connectString })\r\n }\r\n\r\n // build connection options for the driver\r\n const connectionOptions = Object.assign(\r\n {},\r\n {\r\n user: credentials.username,\r\n password: credentials.password,\r\n connectString: credentials.connectString,\r\n },\r\n {\r\n poolMax: options.poolSize,\r\n },\r\n options.extra || {},\r\n )\r\n\r\n // pooling is enabled either when its set explicitly to true,\r\n // either when its not defined at all (e.g. enabled by default)\r\n return new Promise<void>((ok, fail) => {\r\n this.oracle.createPool(connectionOptions, (err: any, pool: any) => {\r\n if (err) return fail(err)\r\n ok(pool)\r\n })\r\n })\r\n }\r\n\r\n /**\r\n * Closes connection pool.\r\n */\r\n protected async closePool(pool: any): Promise<void> {\r\n return new Promise<void>((ok, fail) => {\r\n pool.close((err: any) => (err ? fail(err) : ok()))\r\n pool = undefined\r\n })\r\n }\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/oracle/OracleDriver.ts"],"names":[],"mappings":"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","file":"OracleDriver.js","sourcesContent":["import { Driver } from \"../Driver\"\nimport { ConnectionIsNotSetError } from \"../../error/ConnectionIsNotSetError\"\nimport { DriverPackageNotInstalledError } from \"../../error/DriverPackageNotInstalledError\"\nimport { CteCapabilities } from \"../types/CteCapabilities\"\nimport { OracleQueryRunner } from \"./OracleQueryRunner\"\nimport { ObjectLiteral } from \"../../common/ObjectLiteral\"\nimport { ColumnMetadata } from \"../../metadata/ColumnMetadata\"\nimport { DateUtils } from \"../../util/DateUtils\"\nimport { PlatformTools } from \"../../platform/PlatformTools\"\nimport { DataSource } from \"../../data-source/DataSource\"\nimport { RdbmsSchemaBuilder } from \"../../schema-builder/RdbmsSchemaBuilder\"\nimport { OracleConnectionOptions } from \"./OracleConnectionOptions\"\nimport { MappedColumnTypes } from \"../types/MappedColumnTypes\"\nimport { ColumnType } from \"../types/ColumnTypes\"\nimport { DataTypeDefaults } from \"../types/DataTypeDefaults\"\nimport { TableColumn } from \"../../schema-builder/table/TableColumn\"\nimport { OracleConnectionCredentialsOptions } from \"./OracleConnectionCredentialsOptions\"\nimport { DriverUtils } from \"../DriverUtils\"\nimport { EntityMetadata } from \"../../metadata/EntityMetadata\"\nimport { OrmUtils } from \"../../util/OrmUtils\"\nimport { ApplyValueTransformers } from \"../../util/ApplyValueTransformers\"\nimport { ReplicationMode } from \"../types/ReplicationMode\"\nimport { Table } from \"../../schema-builder/table/Table\"\nimport { View } from \"../../schema-builder/view/View\"\nimport { TableForeignKey } from \"../../schema-builder/table/TableForeignKey\"\nimport { TypeORMError } from \"../../error\"\nimport { InstanceChecker } from \"../../util/InstanceChecker\"\nimport { UpsertType } from \"../types/UpsertType\"\nimport { OnDeleteType } from \"../../metadata/types/OnDeleteType\"\nimport { OnUpdateType } from \"../../metadata/types/OnUpdateType\"\n\n/**\n * Organizes communication with Oracle RDBMS.\n */\nexport class OracleDriver implements Driver {\n // -------------------------------------------------------------------------\n // Public Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection used by driver.\n */\n connection: DataSource\n\n /**\n * Underlying oracle library.\n */\n oracle: any\n\n /**\n * Pool for master database.\n */\n master: any\n\n /**\n * Pool for slave databases.\n * Used in replication.\n */\n slaves: any[] = []\n\n // -------------------------------------------------------------------------\n // Public Implemented Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection options.\n */\n options: OracleConnectionOptions\n\n /**\n * Database name used to perform all write queries.\n */\n database?: string\n\n /**\n * Schema name used to perform all write queries.\n */\n schema?: string\n\n /**\n * Indicates if replication is enabled.\n */\n isReplicated: boolean = false\n\n /**\n * Indicates if tree tables are supported by this driver.\n */\n treeSupport = true\n\n /**\n * Represent transaction support by this driver\n */\n transactionSupport = \"nested\" as const\n\n /**\n * Gets list of supported column data types by a driver.\n *\n * @see https://www.techonthenet.com/oracle/datatypes.php\n * @see https://docs.oracle.com/cd/B28359_01/server.111/b28318/datatype.htm#CNCPT012\n */\n supportedDataTypes: ColumnType[] = [\n \"char\",\n \"nchar\",\n \"nvarchar2\",\n \"varchar2\",\n \"long\",\n \"raw\",\n \"long raw\",\n \"number\",\n \"numeric\",\n \"float\",\n \"dec\",\n \"decimal\",\n \"integer\",\n \"int\",\n \"smallint\",\n \"real\",\n \"double precision\",\n \"date\",\n \"timestamp\",\n \"timestamp with time zone\",\n \"timestamp with local time zone\",\n \"interval year to month\",\n \"interval day to second\",\n \"bfile\",\n \"blob\",\n \"clob\",\n \"nclob\",\n \"rowid\",\n \"urowid\",\n \"simple-json\",\n \"json\",\n ]\n\n /**\n * Returns type of upsert supported by driver if any\n */\n supportedUpsertTypes: UpsertType[] = []\n\n /**\n * Returns list of supported onDelete types by driver.\n * https://docs.oracle.com/en/database/oracle/oracle-database/21/sqlrf/sql-language-reference.pdf\n * Oracle does not support NO ACTION, but NO ACTION is set by default in EntityMetadata\n */\n supportedOnDeleteTypes: OnDeleteType[] = [\n \"CASCADE\",\n \"SET NULL\",\n \"NO ACTION\",\n ]\n\n /**\n * Returns list of supported onUpdate types by driver.\n * Oracle does not have onUpdate option, but we allow NO ACTION since it is set by default in EntityMetadata\n */\n supportedOnUpdateTypes: OnUpdateType[] = [\"NO ACTION\"]\n\n /**\n * Gets list of spatial column data types.\n */\n spatialTypes: ColumnType[] = []\n\n /**\n * Gets list of column data types that support length by a driver.\n */\n withLengthColumnTypes: ColumnType[] = [\n \"char\",\n \"nchar\",\n \"nvarchar2\",\n \"varchar2\",\n \"varchar\",\n \"raw\",\n ]\n\n /**\n * Gets list of column data types that support precision by a driver.\n */\n withPrecisionColumnTypes: ColumnType[] = [\n \"number\",\n \"float\",\n \"timestamp\",\n \"timestamp with time zone\",\n \"timestamp with local time zone\",\n ]\n\n /**\n * Gets list of column data types that support scale by a driver.\n */\n withScaleColumnTypes: ColumnType[] = [\"number\"]\n\n /**\n * Orm has special columns and we need to know what database column types should be for those types.\n * Column types are driver dependant.\n */\n mappedDataTypes: MappedColumnTypes = {\n createDate: \"timestamp\",\n createDateDefault: \"CURRENT_TIMESTAMP\",\n updateDate: \"timestamp\",\n updateDateDefault: \"CURRENT_TIMESTAMP\",\n deleteDate: \"timestamp\",\n deleteDateNullable: true,\n version: \"number\",\n treeLevel: \"number\",\n migrationId: \"number\",\n migrationName: \"varchar2\",\n migrationTimestamp: \"number\",\n cacheId: \"number\",\n cacheIdentifier: \"varchar2\",\n cacheTime: \"number\",\n cacheDuration: \"number\",\n cacheQuery: \"clob\",\n cacheResult: \"clob\",\n metadataType: \"varchar2\",\n metadataDatabase: \"varchar2\",\n metadataSchema: \"varchar2\",\n metadataTable: \"varchar2\",\n metadataName: \"varchar2\",\n metadataValue: \"clob\",\n }\n\n /**\n * The prefix used for the parameters\n */\n parametersPrefix: string = \":\"\n\n /**\n * Default values of length, precision and scale depends on column data type.\n * Used in the cases when length/precision/scale is not specified by user.\n */\n dataTypeDefaults: DataTypeDefaults = {\n char: { length: 1 },\n nchar: { length: 1 },\n varchar: { length: 255 },\n varchar2: { length: 255 },\n nvarchar2: { length: 255 },\n raw: { length: 2000 },\n float: { precision: 126 },\n timestamp: { precision: 6 },\n \"timestamp with time zone\": { precision: 6 },\n \"timestamp with local time zone\": { precision: 6 },\n }\n\n /**\n * Max length allowed by Oracle for aliases.\n * @see https://docs.oracle.com/database/121/SQLRF/sql_elements008.htm#SQLRF51129\n * > The following list of rules applies to both quoted and nonquoted identifiers unless otherwise indicated\n * > Names must be from 1 to 30 bytes long with these exceptions:\n * > [...]\n *\n * Since Oracle 12.2 (with a compatible driver/client), the limit has been set to 128.\n * @see https://docs.oracle.com/en/database/oracle/oracle-database/12.2/sqlrf/Database-Object-Names-and-Qualifiers.html\n *\n * > If COMPATIBLE is set to a value of 12.2 or higher, then names must be from 1 to 128 bytes long with these exceptions\n */\n maxAliasLength = 29\n\n cteCapabilities: CteCapabilities = {\n enabled: true,\n }\n\n dummyTableName = \"DUAL\"\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(connection: DataSource) {\n this.connection = connection\n this.options = connection.options as OracleConnectionOptions\n\n if (this.options.useUTC === true) {\n process.env.ORA_SDTZ = \"UTC\"\n }\n // load oracle package\n this.loadDependencies()\n\n this.database = DriverUtils.buildDriverOptions(\n this.options.replication\n ? this.options.replication.master\n : this.options,\n ).database\n this.schema = DriverUtils.buildDriverOptions(this.options).schema\n\n // Object.assign(connection.options, DriverUtils.buildDriverOptions(connection.options)); // todo: do it better way\n // validate options to make sure everything is set\n // if (!this.options.host)\n // throw new DriverOptionNotSetError(\"host\");\n // if (!this.options.username)\n // throw new DriverOptionNotSetError(\"username\");\n // if (!this.options.sid)\n // throw new DriverOptionNotSetError(\"sid\");\n //\n }\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n /**\n * Performs connection to the database.\n * Based on pooling options, it can either create connection immediately,\n * either create a pool and create connection when needed.\n */\n async connect(): Promise<void> {\n this.oracle.fetchAsString = [this.oracle.DB_TYPE_CLOB]\n this.oracle.fetchAsBuffer = [this.oracle.DB_TYPE_BLOB]\n if (this.options.replication) {\n this.slaves = await Promise.all(\n this.options.replication.slaves.map((slave) => {\n return this.createPool(this.options, slave)\n }),\n )\n this.master = await this.createPool(\n this.options,\n this.options.replication.master,\n )\n } else {\n this.master = await this.createPool(this.options, this.options)\n }\n\n if (!this.database || !this.schema) {\n const queryRunner = await this.createQueryRunner(\"master\")\n\n if (!this.database) {\n this.database = await queryRunner.getCurrentDatabase()\n }\n\n if (!this.schema) {\n this.schema = await queryRunner.getCurrentSchema()\n }\n\n await queryRunner.release()\n }\n }\n\n /**\n * Makes any action after connection (e.g. create extensions in Postgres driver).\n */\n afterConnect(): Promise<void> {\n return Promise.resolve()\n }\n\n /**\n * Closes connection with the database.\n */\n async disconnect(): Promise<void> {\n if (!this.master)\n return Promise.reject(new ConnectionIsNotSetError(\"oracle\"))\n\n await this.closePool(this.master)\n await Promise.all(this.slaves.map((slave) => this.closePool(slave)))\n this.master = undefined\n this.slaves = []\n }\n\n /**\n * Creates a schema builder used to build and sync a schema.\n */\n createSchemaBuilder() {\n return new RdbmsSchemaBuilder(this.connection)\n }\n\n /**\n * Creates a query runner used to execute database queries.\n */\n createQueryRunner(mode: ReplicationMode) {\n return new OracleQueryRunner(this, mode)\n }\n\n /**\n * Replaces parameters in the given sql with special escaping character\n * and an array of parameter names to be passed to a query.\n */\n escapeQueryWithParameters(\n sql: string,\n parameters: ObjectLiteral,\n nativeParameters: ObjectLiteral,\n ): [string, any[]] {\n const escapedParameters: any[] = Object.keys(nativeParameters).map(\n (key) => {\n if (typeof nativeParameters[key] === \"boolean\")\n return nativeParameters[key] ? 1 : 0\n return nativeParameters[key]\n },\n )\n if (!parameters || !Object.keys(parameters).length)\n return [sql, escapedParameters]\n\n const parameterIndexMap = new Map<string, number>()\n sql = sql.replace(\n /:(\\.\\.\\.)?([A-Za-z0-9_.]+)/g,\n (full, isArray: string, key: string): string => {\n if (!parameters.hasOwnProperty(key)) {\n return full\n }\n\n if (parameterIndexMap.has(key)) {\n return this.parametersPrefix + parameterIndexMap.get(key)\n }\n\n let value: any = parameters[key]\n\n if (isArray) {\n return value\n .map((v: any) => {\n escapedParameters.push(v)\n return this.createParameter(\n key,\n escapedParameters.length - 1,\n )\n })\n .join(\", \")\n }\n\n if (typeof value === \"function\") {\n return value()\n }\n\n if (typeof value === \"boolean\") {\n return value ? \"1\" : \"0\"\n }\n\n escapedParameters.push(value)\n parameterIndexMap.set(key, escapedParameters.length)\n return this.createParameter(key, escapedParameters.length - 1)\n },\n ) // todo: make replace only in value statements, otherwise problems\n return [sql, escapedParameters]\n }\n\n /**\n * Escapes a column name.\n */\n escape(columnName: string): string {\n return `\"${columnName}\"`\n }\n\n /**\n * Build full table name with database name, schema name and table name.\n * Oracle does not support table schemas. One user can have only one schema.\n */\n buildTableName(\n tableName: string,\n schema?: string,\n database?: string,\n ): string {\n let tablePath = [tableName]\n\n if (schema) {\n tablePath.unshift(schema)\n }\n\n return tablePath.join(\".\")\n }\n\n /**\n * Parse a target table name or other types and return a normalized table definition.\n */\n parseTableName(\n target: EntityMetadata | Table | View | TableForeignKey | string,\n ): { database?: string; schema?: string; tableName: string } {\n const driverDatabase = this.database\n const driverSchema = this.schema\n\n if (InstanceChecker.isTable(target) || InstanceChecker.isView(target)) {\n const parsed = this.parseTableName(target.name)\n\n return {\n database: target.database || parsed.database || driverDatabase,\n schema: target.schema || parsed.schema || driverSchema,\n tableName: parsed.tableName,\n }\n }\n\n if (InstanceChecker.isTableForeignKey(target)) {\n const parsed = this.parseTableName(target.referencedTableName)\n\n return {\n database:\n target.referencedDatabase ||\n parsed.database ||\n driverDatabase,\n schema:\n target.referencedSchema || parsed.schema || driverSchema,\n tableName: parsed.tableName,\n }\n }\n\n if (InstanceChecker.isEntityMetadata(target)) {\n // EntityMetadata tableName is never a path\n\n return {\n database: target.database || driverDatabase,\n schema: target.schema || driverSchema,\n tableName: target.tableName,\n }\n }\n\n const parts = target.split(\".\")\n\n if (parts.length === 3) {\n return {\n database: parts[0] || driverDatabase,\n schema: parts[1] || driverSchema,\n tableName: parts[2],\n }\n } else if (parts.length === 2) {\n return {\n database: driverDatabase,\n schema: parts[0] || driverSchema,\n tableName: parts[1],\n }\n } else {\n return {\n database: driverDatabase,\n schema: driverSchema,\n tableName: target,\n }\n }\n }\n\n /**\n * Prepares given value to a value to be persisted, based on its column type and metadata.\n */\n preparePersistentValue(value: any, columnMetadata: ColumnMetadata): any {\n if (columnMetadata.transformer)\n value = ApplyValueTransformers.transformTo(\n columnMetadata.transformer,\n value,\n )\n\n if (value === null || value === undefined) return value\n\n if (columnMetadata.type === Boolean) {\n return value ? 1 : 0\n } else if (columnMetadata.type === \"date\") {\n if (typeof value === \"string\") value = value.replace(/[^0-9-]/g, \"\")\n return () =>\n `TO_DATE('${DateUtils.mixedDateToDateString(\n value,\n )}', 'YYYY-MM-DD')`\n } else if (\n columnMetadata.type === Date ||\n columnMetadata.type === \"timestamp\" ||\n columnMetadata.type === \"timestamp with time zone\" ||\n columnMetadata.type === \"timestamp with local time zone\"\n ) {\n return DateUtils.mixedDateToDate(value)\n } else if (columnMetadata.type === \"simple-array\") {\n return DateUtils.simpleArrayToString(value)\n } else if (columnMetadata.type === \"simple-json\") {\n return DateUtils.simpleJsonToString(value)\n } else if (columnMetadata.type === \"json\") {\n return DateUtils.simpleJsonToString(value)\n }\n\n return value\n }\n\n /**\n * Prepares given value to a value to be persisted, based on its column type or metadata.\n */\n prepareHydratedValue(value: any, columnMetadata: ColumnMetadata): any {\n if (value === null || value === undefined)\n return columnMetadata.transformer\n ? ApplyValueTransformers.transformFrom(\n columnMetadata.transformer,\n value,\n )\n : value\n\n if (columnMetadata.type === Boolean) {\n value = !!value\n } else if (columnMetadata.type === \"date\") {\n value = DateUtils.mixedDateToDateString(value)\n } else if (columnMetadata.type === \"time\") {\n value = DateUtils.mixedTimeToString(value)\n } else if (\n columnMetadata.type === Date ||\n columnMetadata.type === \"timestamp\" ||\n columnMetadata.type === \"timestamp with time zone\" ||\n columnMetadata.type === \"timestamp with local time zone\"\n ) {\n value = DateUtils.normalizeHydratedDate(value)\n } else if (columnMetadata.type === \"simple-array\") {\n value = DateUtils.stringToSimpleArray(value)\n } else if (columnMetadata.type === \"simple-json\") {\n value = DateUtils.stringToSimpleJson(value)\n } else if (columnMetadata.type === Number) {\n // convert to number if number\n value = !isNaN(+value) ? parseInt(value) : value\n }\n\n if (columnMetadata.transformer)\n value = ApplyValueTransformers.transformFrom(\n columnMetadata.transformer,\n value,\n )\n\n return value\n }\n\n /**\n * Creates a database type from a given column metadata.\n */\n normalizeType(column: {\n type?: ColumnType\n length?: number | string\n precision?: number | null\n scale?: number\n isArray?: boolean\n }): string {\n if (\n column.type === Number ||\n column.type === Boolean ||\n column.type === \"numeric\" ||\n column.type === \"dec\" ||\n column.type === \"decimal\" ||\n column.type === \"int\" ||\n column.type === \"integer\" ||\n column.type === \"smallint\"\n ) {\n return \"number\"\n } else if (\n column.type === \"real\" ||\n column.type === \"double precision\"\n ) {\n return \"float\"\n } else if (column.type === String || column.type === \"varchar\") {\n return \"varchar2\"\n } else if (column.type === Date) {\n return \"timestamp\"\n } else if ((column.type as any) === Buffer) {\n return \"blob\"\n } else if (column.type === \"uuid\") {\n return \"varchar2\"\n } else if (column.type === \"simple-array\") {\n return \"clob\"\n } else if (column.type === \"simple-json\") {\n return \"clob\"\n } else if (column.type === \"json\") {\n return \"json\"\n } else {\n return (column.type as string) || \"\"\n }\n }\n\n /**\n * Normalizes \"default\" value of the column.\n */\n normalizeDefault(columnMetadata: ColumnMetadata): string | undefined {\n const defaultValue = columnMetadata.default\n\n if (typeof defaultValue === \"number\") {\n return \"\" + defaultValue\n }\n\n if (typeof defaultValue === \"boolean\") {\n return defaultValue ? \"1\" : \"0\"\n }\n\n if (typeof defaultValue === \"function\") {\n return defaultValue()\n }\n\n if (typeof defaultValue === \"string\") {\n return `'${defaultValue}'`\n }\n\n if (defaultValue === null || defaultValue === undefined) {\n return undefined\n }\n\n return `${defaultValue}`\n }\n\n /**\n * Normalizes \"isUnique\" value of the column.\n */\n normalizeIsUnique(column: ColumnMetadata): boolean {\n return column.entityMetadata.uniques.some(\n (uq) => uq.columns.length === 1 && uq.columns[0] === column,\n )\n }\n\n /**\n * Calculates column length taking into account the default length values.\n */\n getColumnLength(column: ColumnMetadata | TableColumn): string {\n if (column.length) return column.length.toString()\n\n switch (column.type) {\n case String:\n case \"varchar\":\n case \"varchar2\":\n case \"nvarchar2\":\n return \"255\"\n case \"raw\":\n return \"2000\"\n case \"uuid\":\n return \"36\"\n default:\n return \"\"\n }\n }\n\n createFullType(column: TableColumn): string {\n let type = column.type\n\n // used 'getColumnLength()' method, because in Oracle column length is required for some data types.\n if (this.getColumnLength(column)) {\n type += `(${this.getColumnLength(column)})`\n } else if (\n column.precision !== null &&\n column.precision !== undefined &&\n column.scale !== null &&\n column.scale !== undefined\n ) {\n type += \"(\" + column.precision + \",\" + column.scale + \")\"\n } else if (\n column.precision !== null &&\n column.precision !== undefined\n ) {\n type += \"(\" + column.precision + \")\"\n }\n\n if (column.type === \"timestamp with time zone\") {\n type =\n \"TIMESTAMP\" +\n (column.precision !== null && column.precision !== undefined\n ? \"(\" + column.precision + \")\"\n : \"\") +\n \" WITH TIME ZONE\"\n } else if (column.type === \"timestamp with local time zone\") {\n type =\n \"TIMESTAMP\" +\n (column.precision !== null && column.precision !== undefined\n ? \"(\" + column.precision + \")\"\n : \"\") +\n \" WITH LOCAL TIME ZONE\"\n }\n\n if (column.isArray) type += \" array\"\n\n return type\n }\n\n /**\n * Obtains a new database connection to a master server.\n * Used for replication.\n * If replication is not setup then returns default connection's database connection.\n */\n obtainMasterConnection(): Promise<any> {\n return new Promise<any>((ok, fail) => {\n if (!this.master) {\n return fail(new TypeORMError(\"Driver not Connected\"))\n }\n\n this.master.getConnection(\n (err: any, connection: any, release: Function) => {\n if (err) return fail(err)\n ok(connection)\n },\n )\n })\n }\n\n /**\n * Obtains a new database connection to a slave server.\n * Used for replication.\n * If replication is not setup then returns master (default) connection's database connection.\n */\n obtainSlaveConnection(): Promise<any> {\n if (!this.slaves.length) return this.obtainMasterConnection()\n\n return new Promise<any>((ok, fail) => {\n const random = Math.floor(Math.random() * this.slaves.length)\n\n this.slaves[random].getConnection((err: any, connection: any) => {\n if (err) return fail(err)\n ok(connection)\n })\n })\n }\n\n /**\n * Creates generated map of values generated or returned by database after INSERT query.\n */\n createGeneratedMap(metadata: EntityMetadata, insertResult: ObjectLiteral) {\n if (!insertResult) return undefined\n\n return Object.keys(insertResult).reduce((map, key) => {\n const column = metadata.findColumnWithDatabaseName(key)\n if (column) {\n OrmUtils.mergeDeep(\n map,\n column.createValueMap(\n this.prepareHydratedValue(insertResult[key], column),\n ),\n )\n }\n return map\n }, {} as ObjectLiteral)\n }\n\n /**\n * Differentiate columns of this table and columns from the given column metadatas columns\n * and returns only changed.\n */\n findChangedColumns(\n tableColumns: TableColumn[],\n columnMetadatas: ColumnMetadata[],\n ): ColumnMetadata[] {\n return columnMetadatas.filter((columnMetadata) => {\n const tableColumn = tableColumns.find(\n (c) => c.name === columnMetadata.databaseName,\n )\n if (!tableColumn) return false // we don't need new columns, we only need exist and changed\n\n const isColumnChanged =\n tableColumn.name !== columnMetadata.databaseName ||\n tableColumn.type !== this.normalizeType(columnMetadata) ||\n tableColumn.length !== this.getColumnLength(columnMetadata) ||\n tableColumn.precision !== columnMetadata.precision ||\n tableColumn.scale !== columnMetadata.scale ||\n // || tableColumn.comment !== columnMetadata.comment\n tableColumn.default !== this.normalizeDefault(columnMetadata) ||\n tableColumn.isPrimary !== columnMetadata.isPrimary ||\n tableColumn.isNullable !== columnMetadata.isNullable ||\n tableColumn.asExpression !== columnMetadata.asExpression ||\n tableColumn.generatedType !== columnMetadata.generatedType ||\n tableColumn.isUnique !==\n this.normalizeIsUnique(columnMetadata) ||\n (columnMetadata.generationStrategy !== \"uuid\" &&\n tableColumn.isGenerated !== columnMetadata.isGenerated)\n\n // DEBUG SECTION\n // if (isColumnChanged) {\n // console.log(\"table:\", columnMetadata.entityMetadata.tableName)\n // console.log(\n // \"name:\",\n // tableColumn.name,\n // columnMetadata.databaseName,\n // )\n // console.log(\n // \"type:\",\n // tableColumn.type,\n // this.normalizeType(columnMetadata),\n // )\n // console.log(\n // \"length:\",\n // tableColumn.length,\n // columnMetadata.length,\n // )\n // console.log(\n // \"precision:\",\n // tableColumn.precision,\n // columnMetadata.precision,\n // )\n // console.log(\"scale:\", tableColumn.scale, columnMetadata.scale)\n // console.log(\n // \"comment:\",\n // tableColumn.comment,\n // columnMetadata.comment,\n // )\n // console.log(\n // \"default:\",\n // tableColumn.default,\n // this.normalizeDefault(columnMetadata),\n // )\n // console.log(\n // \"enum:\",\n // tableColumn.enum &&\n // columnMetadata.enum &&\n // !OrmUtils.isArraysEqual(\n // tableColumn.enum,\n // columnMetadata.enum.map((val) => val + \"\"),\n // ),\n // )\n // console.log(\n // \"onUpdate:\",\n // tableColumn.onUpdate,\n // columnMetadata.onUpdate,\n // )\n // console.log(\n // \"isPrimary:\",\n // tableColumn.isPrimary,\n // columnMetadata.isPrimary,\n // )\n // console.log(\n // \"isNullable:\",\n // tableColumn.isNullable,\n // columnMetadata.isNullable,\n // )\n // console.log(\n // \"asExpression:\",\n // tableColumn.asExpression,\n // columnMetadata.asExpression,\n // )\n // console.log(\n // \"generatedType:\",\n // tableColumn.generatedType,\n // columnMetadata.generatedType,\n // )\n // console.log(\n // \"isUnique:\",\n // tableColumn.isUnique,\n // this.normalizeIsUnique(columnMetadata),\n // )\n // console.log(\n // \"isGenerated:\",\n // tableColumn.isGenerated,\n // columnMetadata.isGenerated,\n // )\n // console.log(\"==========================================\")\n // }\n\n return isColumnChanged\n })\n }\n\n /**\n * Returns true if driver supports RETURNING / OUTPUT statement.\n */\n isReturningSqlSupported(): boolean {\n return true\n }\n\n /**\n * Returns true if driver supports uuid values generation on its own.\n */\n isUUIDGenerationSupported(): boolean {\n return false\n }\n\n /**\n * Returns true if driver supports fulltext indices.\n */\n isFullTextColumnTypeSupported(): boolean {\n return false\n }\n\n /**\n * Creates an escaped parameter.\n */\n createParameter(parameterName: string, index: number): string {\n return this.parametersPrefix + (index + 1)\n }\n\n /**\n * Converts column type in to native oracle type.\n */\n columnTypeToNativeParameter(type: ColumnType): any {\n switch (this.normalizeType({ type: type as any })) {\n case \"number\":\n case \"numeric\":\n case \"int\":\n case \"integer\":\n case \"smallint\":\n case \"dec\":\n case \"decimal\":\n return this.oracle.DB_TYPE_NUMBER\n case \"char\":\n case \"nchar\":\n case \"nvarchar2\":\n case \"varchar2\":\n return this.oracle.DB_TYPE_VARCHAR\n case \"blob\":\n return this.oracle.DB_TYPE_BLOB\n case \"simple-json\":\n case \"clob\":\n return this.oracle.DB_TYPE_CLOB\n case \"date\":\n case \"timestamp\":\n case \"timestamp with time zone\":\n case \"timestamp with local time zone\":\n return this.oracle.DB_TYPE_TIMESTAMP\n case \"json\":\n return this.oracle.DB_TYPE_JSON\n }\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Loads all driver dependencies.\n */\n protected loadDependencies(): void {\n try {\n const oracle = this.options.driver || PlatformTools.load(\"oracledb\")\n this.oracle = oracle\n } catch (e) {\n throw new DriverPackageNotInstalledError(\"Oracle\", \"oracledb\")\n }\n const thickMode = this.options.thickMode\n if (thickMode) {\n typeof thickMode === \"object\"\n ? this.oracle.initOracleClient(thickMode)\n : this.oracle.initOracleClient()\n }\n }\n\n /**\n * Creates a new connection pool for a given database credentials.\n */\n protected async createPool(\n options: OracleConnectionOptions,\n credentials: OracleConnectionCredentialsOptions,\n ): Promise<any> {\n credentials = Object.assign(\n {},\n credentials,\n DriverUtils.buildDriverOptions(credentials),\n ) // todo: do it better way\n\n if (!credentials.connectString) {\n let address = `(PROTOCOL=TCP)`\n\n if (credentials.host) {\n address += `(HOST=${credentials.host})`\n }\n\n if (credentials.port) {\n address += `(PORT=${credentials.port})`\n }\n\n let connectData = `(SERVER=DEDICATED)`\n\n if (credentials.sid) {\n connectData += `(SID=${credentials.sid})`\n }\n\n if (credentials.serviceName) {\n connectData += `(SERVICE_NAME=${credentials.serviceName})`\n }\n\n const connectString = `(DESCRIPTION=(ADDRESS=${address})(CONNECT_DATA=${connectData}))`\n Object.assign(credentials, { connectString })\n }\n\n // build connection options for the driver\n const connectionOptions = Object.assign(\n {},\n {\n user: credentials.username,\n password: credentials.password,\n connectString: credentials.connectString,\n },\n {\n poolMax: options.poolSize,\n },\n options.extra || {},\n )\n\n // pooling is enabled either when its set explicitly to true,\n // either when its not defined at all (e.g. enabled by default)\n return new Promise<void>((ok, fail) => {\n this.oracle.createPool(connectionOptions, (err: any, pool: any) => {\n if (err) return fail(err)\n ok(pool)\n })\n })\n }\n\n /**\n * Closes connection pool.\n */\n protected async closePool(pool: any): Promise<void> {\n return new Promise<void>((ok, fail) => {\n pool.close((err: any) => (err ? fail(err) : ok()))\n pool = undefined\n })\n }\n}\n"],"sourceRoot":"../.."}
@@ -96,13 +96,12 @@ class OracleQueryRunner extends BaseQueryRunner_1.BaseQueryRunner {
96
96
  throw err;
97
97
  }
98
98
  if (this.transactionDepth === 0) {
99
- this.transactionDepth += 1;
100
99
  await this.query("SET TRANSACTION ISOLATION LEVEL " + isolationLevel);
101
100
  }
102
101
  else {
103
- this.transactionDepth += 1;
104
- await this.query(`SAVEPOINT typeorm_${this.transactionDepth - 1}`);
102
+ await this.query(`SAVEPOINT typeorm_${this.transactionDepth}`);
105
103
  }
104
+ this.transactionDepth += 1;
106
105
  await this.broadcaster.broadcast("AfterTransactionStart");
107
106
  }
108
107
  /**
@@ -129,14 +128,13 @@ class OracleQueryRunner extends BaseQueryRunner_1.BaseQueryRunner {
129
128
  throw new TransactionNotStartedError_1.TransactionNotStartedError();
130
129
  await this.broadcaster.broadcast("BeforeTransactionRollback");
131
130
  if (this.transactionDepth > 1) {
132
- this.transactionDepth -= 1;
133
- await this.query(`ROLLBACK TO SAVEPOINT typeorm_${this.transactionDepth}`);
131
+ await this.query(`ROLLBACK TO SAVEPOINT typeorm_${this.transactionDepth - 1}`);
134
132
  }
135
133
  else {
136
- this.transactionDepth -= 1;
137
134
  await this.query("ROLLBACK");
138
135
  this.isTransactionActive = false;
139
136
  }
137
+ this.transactionDepth -= 1;
140
138
  await this.broadcaster.broadcast("AfterTransactionRollback");
141
139
  }
142
140
  /**