typeorm 0.3.12-dev.ef64bfc → 0.4.0-alpha.1

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 (1483) hide show
  1. package/browser/cache/DbQueryResultCache.d.ts +4 -4
  2. package/browser/cache/DbQueryResultCache.js +1 -1
  3. package/browser/cache/DbQueryResultCache.js.map +1 -1
  4. package/browser/cache/QueryResultCache.d.ts +2 -2
  5. package/browser/cache/QueryResultCache.js.map +1 -1
  6. package/browser/cache/QueryResultCacheFactory.d.ts +2 -2
  7. package/browser/cache/QueryResultCacheFactory.js.map +1 -1
  8. package/browser/cache/RedisQueryResultCache.d.ts +4 -4
  9. package/browser/cache/RedisQueryResultCache.js.map +1 -1
  10. package/browser/cli-ts-node-commonjs.js +0 -0
  11. package/browser/cli-ts-node-esm.js +0 -0
  12. package/browser/common/DeepPartial.d.ts +1 -1
  13. package/browser/common/EntityTarget.d.ts +3 -3
  14. package/browser/common/EntityTarget.js.map +1 -1
  15. package/browser/common/MixedList.d.ts +1 -1
  16. package/browser/common/NonNever.d.ts +1 -1
  17. package/browser/common/ObjectType.d.ts +1 -1
  18. package/browser/common/PickKeysByType.d.ts +6 -0
  19. package/browser/common/PickKeysByType.js +3 -0
  20. package/browser/common/PickKeysByType.js.map +1 -0
  21. package/browser/common/RelationType.d.ts +1 -1
  22. package/browser/connection/BaseConnectionOptions.d.ts +2 -2
  23. package/browser/connection/BaseConnectionOptions.js.map +1 -1
  24. package/browser/connection/ConnectionManager.d.ts +1 -1
  25. package/browser/connection/ConnectionManager.js.map +1 -1
  26. package/browser/connection/ConnectionMetadataBuilder.d.ts +5 -5
  27. package/browser/connection/ConnectionMetadataBuilder.js.map +1 -1
  28. package/browser/connection/ConnectionOptions.d.ts +2 -2
  29. package/browser/connection/ConnectionOptions.js.map +1 -1
  30. package/browser/connection/ConnectionOptionsReader.d.ts +1 -1
  31. package/browser/connection/ConnectionOptionsReader.js.map +1 -1
  32. package/browser/connection/options-reader/ConnectionOptionsEnvReader.d.ts +1 -1
  33. package/browser/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  34. package/browser/connection/options-reader/ConnectionOptionsXmlReader.d.ts +1 -1
  35. package/browser/connection/options-reader/ConnectionOptionsXmlReader.js.map +1 -1
  36. package/browser/connection/options-reader/ConnectionOptionsYmlReader.d.ts +1 -1
  37. package/browser/connection/options-reader/ConnectionOptionsYmlReader.js.map +1 -1
  38. package/browser/container.d.ts +1 -1
  39. package/browser/data-source/BaseDataSourceOptions.d.ts +8 -8
  40. package/browser/data-source/BaseDataSourceOptions.js.map +1 -1
  41. package/browser/data-source/DataSource.d.ts +21 -21
  42. package/browser/data-source/DataSource.js +1 -1
  43. package/browser/data-source/DataSource.js.map +1 -1
  44. package/browser/data-source/DataSourceOptions.d.ts +19 -19
  45. package/browser/data-source/DataSourceOptions.js.map +1 -1
  46. package/browser/decorator/Check.js.map +1 -1
  47. package/browser/decorator/EntityRepository.d.ts +1 -1
  48. package/browser/decorator/EntityRepository.js.map +1 -1
  49. package/browser/decorator/Exclusion.js.map +1 -1
  50. package/browser/decorator/Generated.js.map +1 -1
  51. package/browser/decorator/Index.d.ts +1 -1
  52. package/browser/decorator/Index.js.map +1 -1
  53. package/browser/decorator/Unique.d.ts +1 -1
  54. package/browser/decorator/Unique.js.map +1 -1
  55. package/browser/decorator/columns/Column.d.ts +10 -10
  56. package/browser/decorator/columns/Column.js.map +1 -1
  57. package/browser/decorator/columns/CreateDateColumn.d.ts +1 -1
  58. package/browser/decorator/columns/CreateDateColumn.js.map +1 -1
  59. package/browser/decorator/columns/DeleteDateColumn.d.ts +1 -1
  60. package/browser/decorator/columns/DeleteDateColumn.js.map +1 -1
  61. package/browser/decorator/columns/ObjectIdColumn.d.ts +1 -1
  62. package/browser/decorator/columns/ObjectIdColumn.js.map +1 -1
  63. package/browser/decorator/columns/PrimaryColumn.d.ts +3 -3
  64. package/browser/decorator/columns/PrimaryColumn.js.map +1 -1
  65. package/browser/decorator/columns/PrimaryGeneratedColumn.d.ts +3 -3
  66. package/browser/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  67. package/browser/decorator/columns/UpdateDateColumn.d.ts +1 -1
  68. package/browser/decorator/columns/UpdateDateColumn.js.map +1 -1
  69. package/browser/decorator/columns/VersionColumn.d.ts +1 -1
  70. package/browser/decorator/columns/VersionColumn.js.map +1 -1
  71. package/browser/decorator/columns/ViewColumn.d.ts +1 -1
  72. package/browser/decorator/columns/ViewColumn.js.map +1 -1
  73. package/browser/decorator/columns/VirtualColumn.d.ts +2 -2
  74. package/browser/decorator/columns/VirtualColumn.js.map +1 -1
  75. package/browser/decorator/entity/ChildEntity.js.map +1 -1
  76. package/browser/decorator/entity/Entity.d.ts +1 -1
  77. package/browser/decorator/entity/Entity.js.map +1 -1
  78. package/browser/decorator/entity/TableInheritance.d.ts +1 -1
  79. package/browser/decorator/entity/TableInheritance.js.map +1 -1
  80. package/browser/decorator/entity-view/ViewEntity.d.ts +1 -1
  81. package/browser/decorator/entity-view/ViewEntity.js.map +1 -1
  82. package/browser/decorator/listeners/AfterInsert.js.map +1 -1
  83. package/browser/decorator/listeners/AfterLoad.js.map +1 -1
  84. package/browser/decorator/listeners/AfterRecover.js.map +1 -1
  85. package/browser/decorator/listeners/AfterRemove.js.map +1 -1
  86. package/browser/decorator/listeners/AfterSoftRemove.js.map +1 -1
  87. package/browser/decorator/listeners/AfterUpdate.js.map +1 -1
  88. package/browser/decorator/listeners/BeforeInsert.js.map +1 -1
  89. package/browser/decorator/listeners/BeforeRecover.js.map +1 -1
  90. package/browser/decorator/listeners/BeforeRemove.js.map +1 -1
  91. package/browser/decorator/listeners/BeforeSoftRemove.js.map +1 -1
  92. package/browser/decorator/listeners/BeforeUpdate.js.map +1 -1
  93. package/browser/decorator/listeners/EventSubscriber.js.map +1 -1
  94. package/browser/decorator/options/ColumnCommonOptions.d.ts +1 -1
  95. package/browser/decorator/options/ColumnCommonOptions.js.map +1 -1
  96. package/browser/decorator/options/ColumnOptions.d.ts +3 -3
  97. package/browser/decorator/options/ColumnOptions.js.map +1 -1
  98. package/browser/decorator/options/EntityOptions.d.ts +1 -1
  99. package/browser/decorator/options/EntityOptions.js.map +1 -1
  100. package/browser/decorator/options/JoinTableMultipleColumnsOptions.d.ts +1 -1
  101. package/browser/decorator/options/JoinTableMultipleColumnsOptions.js.map +1 -1
  102. package/browser/decorator/options/JoinTableOptions.d.ts +1 -1
  103. package/browser/decorator/options/JoinTableOptions.js.map +1 -1
  104. package/browser/decorator/options/PrimaryGeneratedColumnIdentityOptions.d.ts +1 -1
  105. package/browser/decorator/options/PrimaryGeneratedColumnIdentityOptions.js.map +1 -1
  106. package/browser/decorator/options/PrimaryGeneratedColumnNumericOptions.d.ts +1 -1
  107. package/browser/decorator/options/PrimaryGeneratedColumnNumericOptions.js.map +1 -1
  108. package/browser/decorator/options/RelationOptions.d.ts +3 -3
  109. package/browser/decorator/options/RelationOptions.js.map +1 -1
  110. package/browser/decorator/options/SpatialColumnOptions.d.ts +1 -1
  111. package/browser/decorator/options/SpatialColumnOptions.js.map +1 -1
  112. package/browser/decorator/options/TransactionOptions.d.ts +1 -1
  113. package/browser/decorator/options/TransactionOptions.js.map +1 -1
  114. package/browser/decorator/options/UniqueOptions.d.ts +1 -1
  115. package/browser/decorator/options/UniqueOptions.js.map +1 -1
  116. package/browser/decorator/options/ViewColumnOptions.d.ts +1 -1
  117. package/browser/decorator/options/ViewColumnOptions.js.map +1 -1
  118. package/browser/decorator/options/ViewEntityOptions.d.ts +1 -1
  119. package/browser/decorator/options/ViewEntityOptions.js.map +1 -1
  120. package/browser/decorator/options/VirtualColumnOptions.d.ts +2 -2
  121. package/browser/decorator/options/VirtualColumnOptions.js.map +1 -1
  122. package/browser/decorator/relations/JoinColumn.d.ts +1 -1
  123. package/browser/decorator/relations/JoinColumn.js.map +1 -1
  124. package/browser/decorator/relations/JoinTable.d.ts +2 -2
  125. package/browser/decorator/relations/JoinTable.js.map +1 -1
  126. package/browser/decorator/relations/ManyToMany.d.ts +2 -2
  127. package/browser/decorator/relations/ManyToMany.js.map +1 -1
  128. package/browser/decorator/relations/ManyToOne.d.ts +2 -2
  129. package/browser/decorator/relations/ManyToOne.js.map +1 -1
  130. package/browser/decorator/relations/OneToMany.d.ts +2 -2
  131. package/browser/decorator/relations/OneToMany.js.map +1 -1
  132. package/browser/decorator/relations/OneToOne.d.ts +2 -2
  133. package/browser/decorator/relations/OneToOne.js.map +1 -1
  134. package/browser/decorator/relations/RelationCount.d.ts +1 -1
  135. package/browser/decorator/relations/RelationCount.js.map +1 -1
  136. package/browser/decorator/relations/RelationId.d.ts +1 -1
  137. package/browser/decorator/relations/RelationId.js.map +1 -1
  138. package/browser/decorator/tree/Tree.d.ts +2 -2
  139. package/browser/decorator/tree/Tree.js.map +1 -1
  140. package/browser/decorator/tree/TreeChildren.js.map +1 -1
  141. package/browser/decorator/tree/TreeLevelColumn.js.map +1 -1
  142. package/browser/decorator/tree/TreeParent.d.ts +1 -1
  143. package/browser/decorator/tree/TreeParent.js.map +1 -1
  144. package/browser/driver/Driver.d.ts +17 -17
  145. package/browser/driver/Driver.js.map +1 -1
  146. package/browser/driver/DriverFactory.d.ts +2 -2
  147. package/browser/driver/DriverFactory.js.map +1 -1
  148. package/browser/driver/DriverUtils.d.ts +1 -1
  149. package/browser/driver/DriverUtils.js +2 -2
  150. package/browser/driver/DriverUtils.js.map +1 -1
  151. package/browser/driver/SqlInMemory.d.ts +1 -1
  152. package/browser/driver/SqlInMemory.js.map +1 -1
  153. package/browser/driver/aurora-mysql/AuroraMysqlConnection.d.ts +4 -4
  154. package/browser/driver/aurora-mysql/AuroraMysqlConnection.js.map +1 -1
  155. package/browser/driver/aurora-mysql/AuroraMysqlConnectionOptions.d.ts +2 -2
  156. package/browser/driver/aurora-mysql/AuroraMysqlConnectionOptions.js.map +1 -1
  157. package/browser/driver/aurora-mysql/AuroraMysqlDriver.d.ts +17 -17
  158. package/browser/driver/aurora-mysql/AuroraMysqlDriver.js +2 -2
  159. package/browser/driver/aurora-mysql/AuroraMysqlDriver.js.map +1 -1
  160. package/browser/driver/aurora-mysql/AuroraMysqlQueryRunner.d.ts +6 -6
  161. package/browser/driver/aurora-mysql/AuroraMysqlQueryRunner.js +1 -1
  162. package/browser/driver/aurora-mysql/AuroraMysqlQueryRunner.js.map +1 -1
  163. package/browser/driver/aurora-postgres/AuroraPostgresConnectionOptions.d.ts +1 -1
  164. package/browser/driver/aurora-postgres/AuroraPostgresConnectionOptions.js.map +1 -1
  165. package/browser/driver/aurora-postgres/AuroraPostgresDriver.d.ts +5 -5
  166. package/browser/driver/aurora-postgres/AuroraPostgresDriver.js.map +1 -1
  167. package/browser/driver/aurora-postgres/AuroraPostgresQueryRunner.d.ts +4 -4
  168. package/browser/driver/aurora-postgres/AuroraPostgresQueryRunner.js.map +1 -1
  169. package/browser/driver/better-sqlite3/BetterSqlite3ConnectionOptions.d.ts +7 -1
  170. package/browser/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js.map +1 -1
  171. package/browser/driver/better-sqlite3/BetterSqlite3Driver.d.ts +5 -5
  172. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js +3 -1
  173. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  174. package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.d.ts +1 -1
  175. package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -1
  176. package/browser/driver/capacitor/CapacitorConnectionOptions.d.ts +1 -1
  177. package/browser/driver/capacitor/CapacitorConnectionOptions.js.map +1 -1
  178. package/browser/driver/capacitor/CapacitorDriver.d.ts +4 -4
  179. package/browser/driver/capacitor/CapacitorDriver.js.map +1 -1
  180. package/browser/driver/capacitor/CapacitorQueryRunner.d.ts +2 -2
  181. package/browser/driver/capacitor/CapacitorQueryRunner.js.map +1 -1
  182. package/browser/driver/cockroachdb/CockroachConnectionCredentialsOptions.d.ts +1 -1
  183. package/browser/driver/cockroachdb/CockroachConnectionCredentialsOptions.js.map +1 -1
  184. package/browser/driver/cockroachdb/CockroachConnectionOptions.d.ts +2 -2
  185. package/browser/driver/cockroachdb/CockroachConnectionOptions.js.map +1 -1
  186. package/browser/driver/cockroachdb/CockroachDriver.d.ts +18 -18
  187. package/browser/driver/cockroachdb/CockroachDriver.js +2 -2
  188. package/browser/driver/cockroachdb/CockroachDriver.js.map +1 -1
  189. package/browser/driver/cockroachdb/CockroachQueryRunner.d.ts +5 -5
  190. package/browser/driver/cockroachdb/CockroachQueryRunner.js +2 -2
  191. package/browser/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  192. package/browser/driver/cordova/CordovaConnectionOptions.d.ts +1 -1
  193. package/browser/driver/cordova/CordovaConnectionOptions.js.map +1 -1
  194. package/browser/driver/cordova/CordovaDriver.d.ts +4 -4
  195. package/browser/driver/cordova/CordovaDriver.js.map +1 -1
  196. package/browser/driver/cordova/CordovaQueryRunner.d.ts +2 -2
  197. package/browser/driver/cordova/CordovaQueryRunner.js +1 -1
  198. package/browser/driver/cordova/CordovaQueryRunner.js.map +1 -1
  199. package/browser/driver/expo/ExpoConnectionOptions.d.ts +1 -1
  200. package/browser/driver/expo/ExpoConnectionOptions.js.map +1 -1
  201. package/browser/driver/expo/ExpoDriver.d.ts +4 -4
  202. package/browser/driver/expo/ExpoDriver.js.map +1 -1
  203. package/browser/driver/expo/ExpoQueryRunner.d.ts +1 -1
  204. package/browser/driver/expo/ExpoQueryRunner.js +1 -1
  205. package/browser/driver/expo/ExpoQueryRunner.js.map +1 -1
  206. package/browser/driver/mongodb/MongoConnectionOptions.d.ts +2 -2
  207. package/browser/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  208. package/browser/driver/mongodb/MongoDriver.d.ts +17 -17
  209. package/browser/driver/mongodb/MongoDriver.js.map +1 -1
  210. package/browser/driver/mongodb/MongoQueryRunner.d.ts +16 -16
  211. package/browser/driver/mongodb/MongoQueryRunner.js.map +1 -1
  212. package/browser/driver/mongodb/typings.d.ts +6 -6
  213. package/browser/driver/mysql/MysqlConnectionOptions.d.ts +2 -2
  214. package/browser/driver/mysql/MysqlConnectionOptions.js.map +1 -1
  215. package/browser/driver/mysql/MysqlDriver.d.ts +17 -17
  216. package/browser/driver/mysql/MysqlDriver.js +2 -2
  217. package/browser/driver/mysql/MysqlDriver.js.map +1 -1
  218. package/browser/driver/mysql/MysqlQueryRunner.d.ts +7 -7
  219. package/browser/driver/mysql/MysqlQueryRunner.js +1 -1
  220. package/browser/driver/mysql/MysqlQueryRunner.js.map +1 -1
  221. package/browser/driver/nativescript/NativescriptConnectionOptions.d.ts +1 -1
  222. package/browser/driver/nativescript/NativescriptConnectionOptions.js.map +1 -1
  223. package/browser/driver/nativescript/NativescriptDriver.d.ts +5 -5
  224. package/browser/driver/nativescript/NativescriptDriver.js.map +1 -1
  225. package/browser/driver/nativescript/NativescriptQueryRunner.d.ts +2 -2
  226. package/browser/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  227. package/browser/driver/oracle/OracleConnectionOptions.d.ts +2 -2
  228. package/browser/driver/oracle/OracleConnectionOptions.js.map +1 -1
  229. package/browser/driver/oracle/OracleDriver.d.ts +17 -17
  230. package/browser/driver/oracle/OracleDriver.js +2 -2
  231. package/browser/driver/oracle/OracleDriver.js.map +1 -1
  232. package/browser/driver/oracle/OracleQueryRunner.d.ts +6 -6
  233. package/browser/driver/oracle/OracleQueryRunner.js +2 -2
  234. package/browser/driver/oracle/OracleQueryRunner.js.map +1 -1
  235. package/browser/driver/postgres/PostgresConnectionCredentialsOptions.d.ts +1 -1
  236. package/browser/driver/postgres/PostgresConnectionCredentialsOptions.js.map +1 -1
  237. package/browser/driver/postgres/PostgresConnectionOptions.d.ts +2 -2
  238. package/browser/driver/postgres/PostgresConnectionOptions.js.map +1 -1
  239. package/browser/driver/postgres/PostgresDriver.d.ts +18 -18
  240. package/browser/driver/postgres/PostgresDriver.js +2 -2
  241. package/browser/driver/postgres/PostgresDriver.js.map +1 -1
  242. package/browser/driver/postgres/PostgresQueryRunner.d.ts +5 -5
  243. package/browser/driver/postgres/PostgresQueryRunner.js +3 -3
  244. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  245. package/browser/driver/react-native/ReactNativeConnectionOptions.d.ts +1 -1
  246. package/browser/driver/react-native/ReactNativeConnectionOptions.js.map +1 -1
  247. package/browser/driver/react-native/ReactNativeDriver.d.ts +4 -4
  248. package/browser/driver/react-native/ReactNativeDriver.js.map +1 -1
  249. package/browser/driver/react-native/ReactNativeQueryRunner.d.ts +2 -2
  250. package/browser/driver/react-native/ReactNativeQueryRunner.js +1 -1
  251. package/browser/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  252. package/browser/driver/sap/SapConnectionOptions.d.ts +2 -2
  253. package/browser/driver/sap/SapConnectionOptions.js.map +1 -1
  254. package/browser/driver/sap/SapDriver.d.ts +10 -10
  255. package/browser/driver/sap/SapDriver.js +3 -3
  256. package/browser/driver/sap/SapDriver.js.map +1 -1
  257. package/browser/driver/sap/SapQueryRunner.d.ts +6 -6
  258. package/browser/driver/sap/SapQueryRunner.js +1 -1
  259. package/browser/driver/sap/SapQueryRunner.js.map +1 -1
  260. package/browser/driver/spanner/SpannerConnectionOptions.d.ts +2 -2
  261. package/browser/driver/spanner/SpannerConnectionOptions.js.map +1 -1
  262. package/browser/driver/spanner/SpannerDriver.d.ts +12 -12
  263. package/browser/driver/spanner/SpannerDriver.js +3 -3
  264. package/browser/driver/spanner/SpannerDriver.js.map +1 -1
  265. package/browser/driver/spanner/SpannerQueryRunner.d.ts +6 -6
  266. package/browser/driver/spanner/SpannerQueryRunner.js +7 -7
  267. package/browser/driver/spanner/SpannerQueryRunner.js.map +1 -1
  268. package/browser/driver/sqlite/SqliteConnectionOptions.d.ts +1 -1
  269. package/browser/driver/sqlite/SqliteConnectionOptions.js.map +1 -1
  270. package/browser/driver/sqlite/SqliteDriver.d.ts +5 -5
  271. package/browser/driver/sqlite/SqliteDriver.js.map +1 -1
  272. package/browser/driver/sqlite/SqliteQueryRunner.d.ts +1 -1
  273. package/browser/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  274. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.d.ts +18 -18
  275. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js +13 -1
  276. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  277. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.d.ts +5 -5
  278. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +10 -10
  279. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  280. package/browser/driver/sqljs/SqljsConnectionOptions.d.ts +1 -1
  281. package/browser/driver/sqljs/SqljsConnectionOptions.js.map +1 -1
  282. package/browser/driver/sqljs/SqljsDriver.d.ts +5 -5
  283. package/browser/driver/sqljs/SqljsDriver.js +1 -1
  284. package/browser/driver/sqljs/SqljsDriver.js.map +1 -1
  285. package/browser/driver/sqljs/SqljsQueryRunner.d.ts +1 -1
  286. package/browser/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  287. package/browser/driver/sqlserver/SqlServerConnectionCredentialsOptions.d.ts +8 -8
  288. package/browser/driver/sqlserver/SqlServerConnectionCredentialsOptions.js.map +1 -1
  289. package/browser/driver/sqlserver/SqlServerConnectionOptions.d.ts +2 -2
  290. package/browser/driver/sqlserver/SqlServerConnectionOptions.js.map +1 -1
  291. package/browser/driver/sqlserver/SqlServerDriver.d.ts +16 -16
  292. package/browser/driver/sqlserver/SqlServerDriver.js +2 -2
  293. package/browser/driver/sqlserver/SqlServerDriver.js.map +1 -1
  294. package/browser/driver/sqlserver/SqlServerQueryRunner.d.ts +7 -7
  295. package/browser/driver/sqlserver/SqlServerQueryRunner.js +4 -4
  296. package/browser/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  297. package/browser/driver/types/ColumnTypes.d.ts +7 -7
  298. package/browser/driver/types/DatabaseType.d.ts +1 -1
  299. package/browser/driver/types/GeoJsonTypes.d.ts +12 -12
  300. package/browser/driver/types/IsolationLevel.d.ts +1 -1
  301. package/browser/driver/types/MappedColumnTypes.d.ts +1 -1
  302. package/browser/driver/types/MappedColumnTypes.js.map +1 -1
  303. package/browser/driver/types/ReplicationMode.d.ts +1 -1
  304. package/browser/driver/types/UpsertType.d.ts +1 -1
  305. package/browser/entity-manager/EntityManager.d.ts +37 -19
  306. package/browser/entity-manager/EntityManager.js +32 -0
  307. package/browser/entity-manager/EntityManager.js.map +1 -1
  308. package/browser/entity-manager/EntityManagerFactory.d.ts +2 -2
  309. package/browser/entity-manager/EntityManagerFactory.js.map +1 -1
  310. package/browser/entity-manager/MongoEntityManager.d.ts +12 -12
  311. package/browser/entity-manager/MongoEntityManager.js +5 -5
  312. package/browser/entity-manager/MongoEntityManager.js.map +1 -1
  313. package/browser/entity-manager/SqljsEntityManager.d.ts +2 -2
  314. package/browser/entity-manager/SqljsEntityManager.js.map +1 -1
  315. package/browser/entity-schema/EntitySchema.d.ts +1 -1
  316. package/browser/entity-schema/EntitySchema.js.map +1 -1
  317. package/browser/entity-schema/EntitySchemaColumnOptions.d.ts +3 -3
  318. package/browser/entity-schema/EntitySchemaColumnOptions.js.map +1 -1
  319. package/browser/entity-schema/EntitySchemaEmbeddedColumnOptions.d.ts +1 -1
  320. package/browser/entity-schema/EntitySchemaEmbeddedColumnOptions.js.map +1 -1
  321. package/browser/entity-schema/EntitySchemaOptions.d.ts +10 -10
  322. package/browser/entity-schema/EntitySchemaOptions.js.map +1 -1
  323. package/browser/entity-schema/EntitySchemaRelationIdOptions.d.ts +1 -1
  324. package/browser/entity-schema/EntitySchemaRelationIdOptions.js.map +1 -1
  325. package/browser/entity-schema/EntitySchemaRelationOptions.d.ts +8 -8
  326. package/browser/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
  327. package/browser/entity-schema/EntitySchemaTransformer.d.ts +1 -1
  328. package/browser/entity-schema/EntitySchemaTransformer.js.map +1 -1
  329. package/browser/entity-schema/EntitySchemaUniqueOptions.d.ts +1 -1
  330. package/browser/entity-schema/EntitySchemaUniqueOptions.js.map +1 -1
  331. package/browser/error/CannotCreateEntityIdMapError.d.ts +1 -1
  332. package/browser/error/CannotCreateEntityIdMapError.js.map +1 -1
  333. package/browser/error/DataTypeNotSupportedError.d.ts +3 -3
  334. package/browser/error/DataTypeNotSupportedError.js.map +1 -1
  335. package/browser/error/EntityMetadataNotFoundError.d.ts +1 -1
  336. package/browser/error/EntityMetadataNotFoundError.js.map +1 -1
  337. package/browser/error/EntityNotFoundError.d.ts +1 -1
  338. package/browser/error/EntityNotFoundError.js.map +1 -1
  339. package/browser/error/EntityPropertyNotFoundError.d.ts +1 -1
  340. package/browser/error/EntityPropertyNotFoundError.js.map +1 -1
  341. package/browser/error/ForbiddenTransactionModeOverrideError.d.ts +1 -1
  342. package/browser/error/ForbiddenTransactionModeOverrideError.js.map +1 -1
  343. package/browser/error/InitializedRelationError.d.ts +1 -1
  344. package/browser/error/InitializedRelationError.js.map +1 -1
  345. package/browser/error/MissingDeleteDateColumnError.d.ts +1 -1
  346. package/browser/error/MissingDeleteDateColumnError.js.map +1 -1
  347. package/browser/error/MissingJoinColumnError.d.ts +2 -2
  348. package/browser/error/MissingJoinColumnError.js.map +1 -1
  349. package/browser/error/MissingJoinTableError.d.ts +2 -2
  350. package/browser/error/MissingJoinTableError.js.map +1 -1
  351. package/browser/error/MissingPrimaryColumnError.d.ts +1 -1
  352. package/browser/error/MissingPrimaryColumnError.js.map +1 -1
  353. package/browser/error/RepositoryNotTreeError.d.ts +1 -1
  354. package/browser/error/RepositoryNotTreeError.js.map +1 -1
  355. package/browser/error/SubjectRemovedAndUpdatedError.d.ts +1 -1
  356. package/browser/error/SubjectRemovedAndUpdatedError.js.map +1 -1
  357. package/browser/error/SubjectWithoutIdentifierError.d.ts +1 -1
  358. package/browser/error/SubjectWithoutIdentifierError.js.map +1 -1
  359. package/browser/error/TreeRepositoryNotSupportedError.d.ts +1 -1
  360. package/browser/error/TreeRepositoryNotSupportedError.js.map +1 -1
  361. package/browser/error/UsingJoinColumnIsNotAllowedError.d.ts +2 -2
  362. package/browser/error/UsingJoinColumnIsNotAllowedError.js.map +1 -1
  363. package/browser/error/UsingJoinColumnOnlyOnOneSideAllowedError.d.ts +2 -2
  364. package/browser/error/UsingJoinColumnOnlyOnOneSideAllowedError.js.map +1 -1
  365. package/browser/error/UsingJoinTableIsNotAllowedError.d.ts +2 -2
  366. package/browser/error/UsingJoinTableIsNotAllowedError.js.map +1 -1
  367. package/browser/error/UsingJoinTableOnlyOnOneSideAllowedError.d.ts +2 -2
  368. package/browser/error/UsingJoinTableOnlyOnOneSideAllowedError.js.map +1 -1
  369. package/browser/find-options/FindManyOptions.d.ts +1 -1
  370. package/browser/find-options/FindManyOptions.js.map +1 -1
  371. package/browser/find-options/FindOneOptions.d.ts +5 -5
  372. package/browser/find-options/FindOneOptions.js.map +1 -1
  373. package/browser/find-options/FindOperator.d.ts +3 -3
  374. package/browser/find-options/FindOperator.js.map +1 -1
  375. package/browser/find-options/FindOperatorType.d.ts +1 -1
  376. package/browser/find-options/FindOperatorType.js.map +1 -1
  377. package/browser/find-options/FindOptionsOrder.d.ts +4 -4
  378. package/browser/find-options/FindOptionsOrder.js.map +1 -1
  379. package/browser/find-options/FindOptionsRelations.d.ts +4 -4
  380. package/browser/find-options/FindOptionsRelations.js.map +1 -1
  381. package/browser/find-options/FindOptionsSelect.d.ts +4 -4
  382. package/browser/find-options/FindOptionsSelect.js.map +1 -1
  383. package/browser/find-options/FindOptionsUtils.d.ts +6 -6
  384. package/browser/find-options/FindOptionsUtils.js +1 -1
  385. package/browser/find-options/FindOptionsUtils.js.map +1 -1
  386. package/browser/find-options/FindOptionsWhere.d.ts +9 -5
  387. package/browser/find-options/FindOptionsWhere.js.map +1 -1
  388. package/browser/find-options/OrderByCondition.d.ts +1 -1
  389. package/browser/find-options/mongodb/MongoFindManyOptions.d.ts +1 -1
  390. package/browser/find-options/mongodb/MongoFindManyOptions.js.map +1 -1
  391. package/browser/find-options/mongodb/MongoFindOneOptions.d.ts +3 -3
  392. package/browser/find-options/mongodb/MongoFindOneOptions.js.map +1 -1
  393. package/browser/find-options/operator/Equal.d.ts +1 -1
  394. package/browser/find-options/operator/Equal.js.map +1 -1
  395. package/browser/find-options/operator/JsonContains.d.ts +6 -0
  396. package/browser/find-options/operator/JsonContains.js +10 -0
  397. package/browser/find-options/operator/JsonContains.js.map +1 -0
  398. package/browser/find-options/operator/Raw.d.ts +1 -1
  399. package/browser/find-options/operator/Raw.js.map +1 -1
  400. package/browser/globals.d.ts +12 -12
  401. package/browser/globals.js.map +1 -1
  402. package/browser/index.d.ts +3 -0
  403. package/browser/index.js +3 -0
  404. package/browser/index.js.map +1 -1
  405. package/browser/logger/AbstractLogger.d.ts +49 -0
  406. package/browser/logger/AbstractLogger.js +230 -0
  407. package/browser/logger/AbstractLogger.js.map +1 -0
  408. package/browser/logger/AdvancedConsoleLogger.d.ts +6 -34
  409. package/browser/logger/AdvancedConsoleLogger.js +41 -106
  410. package/browser/logger/AdvancedConsoleLogger.js.map +1 -1
  411. package/browser/logger/DebugLogger.d.ts +10 -30
  412. package/browser/logger/DebugLogger.js +56 -74
  413. package/browser/logger/DebugLogger.js.map +1 -1
  414. package/browser/logger/FileLogger.d.ts +8 -34
  415. package/browser/logger/FileLogger.js +50 -97
  416. package/browser/logger/FileLogger.js.map +1 -1
  417. package/browser/logger/Logger.d.ts +32 -1
  418. package/browser/logger/Logger.js.map +1 -1
  419. package/browser/logger/LoggerFactory.d.ts +2 -2
  420. package/browser/logger/LoggerFactory.js.map +1 -1
  421. package/browser/logger/LoggerOptions.d.ts +3 -2
  422. package/browser/logger/LoggerOptions.js.map +1 -1
  423. package/browser/logger/SimpleConsoleLogger.d.ts +6 -34
  424. package/browser/logger/SimpleConsoleLogger.js +43 -106
  425. package/browser/logger/SimpleConsoleLogger.js.map +1 -1
  426. package/browser/metadata/CheckMetadata.d.ts +3 -3
  427. package/browser/metadata/CheckMetadata.js.map +1 -1
  428. package/browser/metadata/ColumnMetadata.d.ts +8 -8
  429. package/browser/metadata/ColumnMetadata.js.map +1 -1
  430. package/browser/metadata/EmbeddedMetadata.d.ts +10 -10
  431. package/browser/metadata/EmbeddedMetadata.js +1 -1
  432. package/browser/metadata/EmbeddedMetadata.js.map +1 -1
  433. package/browser/metadata/EntityListenerMetadata.d.ts +5 -5
  434. package/browser/metadata/EntityListenerMetadata.js.map +1 -1
  435. package/browser/metadata/EntityMetadata.d.ts +20 -20
  436. package/browser/metadata/EntityMetadata.js.map +1 -1
  437. package/browser/metadata/ExclusionMetadata.d.ts +3 -3
  438. package/browser/metadata/ExclusionMetadata.js.map +1 -1
  439. package/browser/metadata/ForeignKeyMetadata.d.ts +6 -6
  440. package/browser/metadata/ForeignKeyMetadata.js.map +1 -1
  441. package/browser/metadata/IndexMetadata.d.ts +5 -5
  442. package/browser/metadata/IndexMetadata.js.map +1 -1
  443. package/browser/metadata/RelationCountMetadata.d.ts +4 -4
  444. package/browser/metadata/RelationCountMetadata.js.map +1 -1
  445. package/browser/metadata/RelationIdMetadata.d.ts +5 -5
  446. package/browser/metadata/RelationIdMetadata.js.map +1 -1
  447. package/browser/metadata/RelationMetadata.d.ts +10 -10
  448. package/browser/metadata/RelationMetadata.js.map +1 -1
  449. package/browser/metadata/UniqueMetadata.d.ts +6 -6
  450. package/browser/metadata/UniqueMetadata.js.map +1 -1
  451. package/browser/metadata/types/ClosureTreeOptions.d.ts +1 -1
  452. package/browser/metadata/types/ClosureTreeOptions.js.map +1 -1
  453. package/browser/metadata/types/DeferrableType.d.ts +1 -1
  454. package/browser/metadata/types/EventListenerTypes.d.ts +1 -1
  455. package/browser/metadata/types/OnDeleteType.d.ts +1 -1
  456. package/browser/metadata/types/OnUpdateType.d.ts +1 -1
  457. package/browser/metadata/types/PropertyTypeInFunction.d.ts +1 -1
  458. package/browser/metadata/types/RelationTypeInFunction.d.ts +2 -2
  459. package/browser/metadata/types/RelationTypeInFunction.js.map +1 -1
  460. package/browser/metadata/types/RelationTypes.d.ts +1 -1
  461. package/browser/metadata/types/TableTypes.d.ts +1 -1
  462. package/browser/metadata/types/TreeTypes.d.ts +1 -1
  463. package/browser/metadata-args/ColumnMetadataArgs.d.ts +2 -2
  464. package/browser/metadata-args/ColumnMetadataArgs.js.map +1 -1
  465. package/browser/metadata-args/EntityListenerMetadataArgs.d.ts +1 -1
  466. package/browser/metadata-args/EntityListenerMetadataArgs.js.map +1 -1
  467. package/browser/metadata-args/EntityRepositoryMetadataArgs.d.ts +1 -1
  468. package/browser/metadata-args/EntityRepositoryMetadataArgs.js.map +1 -1
  469. package/browser/metadata-args/InheritanceMetadataArgs.d.ts +1 -1
  470. package/browser/metadata-args/InheritanceMetadataArgs.js.map +1 -1
  471. package/browser/metadata-args/JoinTableMetadataArgs.d.ts +1 -1
  472. package/browser/metadata-args/JoinTableMetadataArgs.js.map +1 -1
  473. package/browser/metadata-args/MetadataArgsStorage.d.ts +22 -22
  474. package/browser/metadata-args/MetadataArgsStorage.js.map +1 -1
  475. package/browser/metadata-args/RelationCountMetadataArgs.d.ts +1 -1
  476. package/browser/metadata-args/RelationCountMetadataArgs.js.map +1 -1
  477. package/browser/metadata-args/RelationIdMetadataArgs.d.ts +1 -1
  478. package/browser/metadata-args/RelationIdMetadataArgs.js.map +1 -1
  479. package/browser/metadata-args/RelationMetadataArgs.d.ts +4 -4
  480. package/browser/metadata-args/RelationMetadataArgs.js.map +1 -1
  481. package/browser/metadata-args/TableMetadataArgs.d.ts +3 -3
  482. package/browser/metadata-args/TableMetadataArgs.js.map +1 -1
  483. package/browser/metadata-args/TreeMetadataArgs.d.ts +2 -2
  484. package/browser/metadata-args/TreeMetadataArgs.js.map +1 -1
  485. package/browser/metadata-args/UniqueMetadataArgs.d.ts +1 -1
  486. package/browser/metadata-args/UniqueMetadataArgs.js.map +1 -1
  487. package/browser/metadata-args/types/ColumnMode.d.ts +1 -1
  488. package/browser/metadata-builder/ClosureJunctionEntityMetadataBuilder.d.ts +1 -1
  489. package/browser/metadata-builder/ClosureJunctionEntityMetadataBuilder.js.map +1 -1
  490. package/browser/metadata-builder/EntityMetadataBuilder.d.ts +4 -4
  491. package/browser/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  492. package/browser/metadata-builder/EntityMetadataValidator.d.ts +2 -2
  493. package/browser/metadata-builder/EntityMetadataValidator.js.map +1 -1
  494. package/browser/metadata-builder/JunctionEntityMetadataBuilder.d.ts +3 -3
  495. package/browser/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
  496. package/browser/metadata-builder/RelationJoinColumnBuilder.d.ts +3 -3
  497. package/browser/metadata-builder/RelationJoinColumnBuilder.js +2 -1
  498. package/browser/metadata-builder/RelationJoinColumnBuilder.js.map +1 -1
  499. package/browser/migration/Migration.d.ts +1 -1
  500. package/browser/migration/Migration.js.map +1 -1
  501. package/browser/migration/MigrationExecutor.d.ts +2 -2
  502. package/browser/migration/MigrationExecutor.js +3 -3
  503. package/browser/migration/MigrationExecutor.js.map +1 -1
  504. package/browser/migration/MigrationInterface.d.ts +1 -1
  505. package/browser/migration/MigrationInterface.js.map +1 -1
  506. package/browser/naming-strategy/DefaultNamingStrategy.d.ts +2 -2
  507. package/browser/naming-strategy/DefaultNamingStrategy.js.map +1 -1
  508. package/browser/naming-strategy/LegacyOracleNamingStrategy.d.ts +21 -0
  509. package/browser/naming-strategy/LegacyOracleNamingStrategy.js +46 -0
  510. package/browser/naming-strategy/LegacyOracleNamingStrategy.js.map +1 -0
  511. package/browser/naming-strategy/NamingStrategyInterface.d.ts +2 -2
  512. package/browser/naming-strategy/NamingStrategyInterface.js.map +1 -1
  513. package/browser/persistence/EntityPersistExecutor.d.ts +5 -5
  514. package/browser/persistence/EntityPersistExecutor.js +1 -1
  515. package/browser/persistence/EntityPersistExecutor.js.map +1 -1
  516. package/browser/persistence/Subject.d.ts +5 -5
  517. package/browser/persistence/Subject.js.map +1 -1
  518. package/browser/persistence/SubjectChangeMap.d.ts +3 -3
  519. package/browser/persistence/SubjectChangeMap.js.map +1 -1
  520. package/browser/persistence/SubjectChangedColumnsComputer.d.ts +1 -1
  521. package/browser/persistence/SubjectChangedColumnsComputer.js.map +1 -1
  522. package/browser/persistence/SubjectDatabaseEntityLoader.d.ts +3 -3
  523. package/browser/persistence/SubjectDatabaseEntityLoader.js +1 -1
  524. package/browser/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  525. package/browser/persistence/SubjectExecutor.d.ts +4 -4
  526. package/browser/persistence/SubjectExecutor.js +1 -1
  527. package/browser/persistence/SubjectExecutor.js.map +1 -1
  528. package/browser/persistence/SubjectTopoligicalSorter.d.ts +2 -2
  529. package/browser/persistence/SubjectTopoligicalSorter.js +7 -11
  530. package/browser/persistence/SubjectTopoligicalSorter.js.map +1 -1
  531. package/browser/persistence/subject-builder/CascadesSubjectBuilder.d.ts +1 -1
  532. package/browser/persistence/subject-builder/CascadesSubjectBuilder.js.map +1 -1
  533. package/browser/persistence/subject-builder/ManyToManySubjectBuilder.d.ts +2 -2
  534. package/browser/persistence/subject-builder/ManyToManySubjectBuilder.js.map +1 -1
  535. package/browser/persistence/subject-builder/OneToManySubjectBuilder.d.ts +1 -1
  536. package/browser/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  537. package/browser/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.d.ts +1 -1
  538. package/browser/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js +1 -1
  539. package/browser/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js.map +1 -1
  540. package/browser/persistence/tree/ClosureSubjectExecutor.d.ts +2 -2
  541. package/browser/persistence/tree/ClosureSubjectExecutor.js.map +1 -1
  542. package/browser/persistence/tree/MaterializedPathSubjectExecutor.d.ts +2 -2
  543. package/browser/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  544. package/browser/persistence/tree/NestedSetSubjectExecutor.d.ts +4 -4
  545. package/browser/persistence/tree/NestedSetSubjectExecutor.js +2 -2
  546. package/browser/persistence/tree/NestedSetSubjectExecutor.js.map +1 -1
  547. package/browser/platform/BrowserPlatformTools.js +2 -2
  548. package/browser/platform/BrowserPlatformTools.js.map +1 -1
  549. package/browser/platform/PlatformTools.d.ts +2 -0
  550. package/browser/platform/PlatformTools.js +6 -0
  551. package/browser/platform/PlatformTools.js.map +1 -1
  552. package/browser/query-builder/Alias.d.ts +1 -1
  553. package/browser/query-builder/Alias.js.map +1 -1
  554. package/browser/query-builder/Brackets.d.ts +1 -1
  555. package/browser/query-builder/Brackets.js.map +1 -1
  556. package/browser/query-builder/DeleteQueryBuilder.d.ts +6 -6
  557. package/browser/query-builder/DeleteQueryBuilder.js.map +1 -1
  558. package/browser/query-builder/InsertOrUpdateOptions.d.ts +2 -2
  559. package/browser/query-builder/InsertOrUpdateOptions.js.map +1 -1
  560. package/browser/query-builder/InsertQueryBuilder.d.ts +5 -5
  561. package/browser/query-builder/InsertQueryBuilder.js.map +1 -1
  562. package/browser/query-builder/JoinAttribute.d.ts +5 -5
  563. package/browser/query-builder/JoinAttribute.js +2 -2
  564. package/browser/query-builder/JoinAttribute.js.map +1 -1
  565. package/browser/query-builder/QueryBuilder.d.ts +18 -18
  566. package/browser/query-builder/QueryBuilder.js +3 -1
  567. package/browser/query-builder/QueryBuilder.js.map +1 -1
  568. package/browser/query-builder/QueryExpressionMap.d.ts +12 -12
  569. package/browser/query-builder/QueryExpressionMap.js.map +1 -1
  570. package/browser/query-builder/QueryPartialEntity.d.ts +4 -4
  571. package/browser/query-builder/QueryPartialEntity.js.map +1 -1
  572. package/browser/query-builder/RelationIdLoader.d.ts +4 -4
  573. package/browser/query-builder/RelationIdLoader.js +2 -2
  574. package/browser/query-builder/RelationIdLoader.js.map +1 -1
  575. package/browser/query-builder/RelationLoader.d.ts +5 -5
  576. package/browser/query-builder/RelationLoader.js.map +1 -1
  577. package/browser/query-builder/RelationQueryBuilder.d.ts +1 -1
  578. package/browser/query-builder/RelationQueryBuilder.js.map +1 -1
  579. package/browser/query-builder/RelationRemover.d.ts +2 -2
  580. package/browser/query-builder/RelationRemover.js.map +1 -1
  581. package/browser/query-builder/RelationUpdater.d.ts +2 -2
  582. package/browser/query-builder/RelationUpdater.js.map +1 -1
  583. package/browser/query-builder/ReturningResultsEntityUpdator.d.ts +6 -6
  584. package/browser/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
  585. package/browser/query-builder/SelectQueryBuilder.d.ts +18 -18
  586. package/browser/query-builder/SelectQueryBuilder.js +12 -8
  587. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  588. package/browser/query-builder/SelectQueryBuilderOption.d.ts +1 -1
  589. package/browser/query-builder/SoftDeleteQueryBuilder.d.ts +7 -7
  590. package/browser/query-builder/SoftDeleteQueryBuilder.js +1 -1
  591. package/browser/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  592. package/browser/query-builder/UpdateQueryBuilder.d.ts +7 -7
  593. package/browser/query-builder/UpdateQueryBuilder.js +3 -3
  594. package/browser/query-builder/UpdateQueryBuilder.js.map +1 -1
  595. package/browser/query-builder/WhereClause.d.ts +3 -3
  596. package/browser/query-builder/WhereClause.js.map +1 -1
  597. package/browser/query-builder/WhereExpressionBuilder.d.ts +3 -4
  598. package/browser/query-builder/WhereExpressionBuilder.js.map +1 -1
  599. package/browser/query-builder/relation-count/RelationCountAttribute.d.ts +4 -4
  600. package/browser/query-builder/relation-count/RelationCountAttribute.js.map +1 -1
  601. package/browser/query-builder/relation-count/RelationCountLoadResult.d.ts +1 -1
  602. package/browser/query-builder/relation-count/RelationCountLoadResult.js.map +1 -1
  603. package/browser/query-builder/relation-count/RelationCountLoader.d.ts +4 -4
  604. package/browser/query-builder/relation-count/RelationCountLoader.js.map +1 -1
  605. package/browser/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.d.ts +1 -1
  606. package/browser/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.js.map +1 -1
  607. package/browser/query-builder/relation-id/RelationIdAttribute.d.ts +4 -4
  608. package/browser/query-builder/relation-id/RelationIdAttribute.js.map +1 -1
  609. package/browser/query-builder/relation-id/RelationIdLoadResult.d.ts +1 -1
  610. package/browser/query-builder/relation-id/RelationIdLoadResult.js.map +1 -1
  611. package/browser/query-builder/relation-id/RelationIdLoader.d.ts +4 -4
  612. package/browser/query-builder/relation-id/RelationIdLoader.js.map +1 -1
  613. package/browser/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.d.ts +1 -1
  614. package/browser/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.js.map +1 -1
  615. package/browser/query-builder/result/DeleteResult.d.ts +1 -1
  616. package/browser/query-builder/result/DeleteResult.js.map +1 -1
  617. package/browser/query-builder/result/InsertResult.d.ts +2 -2
  618. package/browser/query-builder/result/InsertResult.js.map +1 -1
  619. package/browser/query-builder/result/UpdateResult.d.ts +2 -2
  620. package/browser/query-builder/result/UpdateResult.js.map +1 -1
  621. package/browser/query-builder/transformer/DocumentToEntityTransformer.d.ts +2 -2
  622. package/browser/query-builder/transformer/DocumentToEntityTransformer.js.map +1 -1
  623. package/browser/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.d.ts +3 -3
  624. package/browser/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.js.map +1 -1
  625. package/browser/query-builder/transformer/PlainObjectToNewEntityTransformer.d.ts +2 -2
  626. package/browser/query-builder/transformer/PlainObjectToNewEntityTransformer.js.map +1 -1
  627. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.d.ts +8 -8
  628. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js +1 -1
  629. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  630. package/browser/query-runner/BaseQueryRunner.d.ts +11 -11
  631. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  632. package/browser/query-runner/QueryRunner.d.ts +17 -17
  633. package/browser/query-runner/QueryRunner.js.map +1 -1
  634. package/browser/repository/AbstractRepository.d.ts +6 -6
  635. package/browser/repository/AbstractRepository.js.map +1 -1
  636. package/browser/repository/BaseEntity.d.ts +41 -16
  637. package/browser/repository/BaseEntity.js +24 -0
  638. package/browser/repository/BaseEntity.js.map +1 -1
  639. package/browser/repository/EntityId.d.ts +2 -2
  640. package/browser/repository/EntityId.js.map +1 -1
  641. package/browser/repository/MongoRepository.d.ts +8 -8
  642. package/browser/repository/MongoRepository.js.map +1 -1
  643. package/browser/repository/Repository.d.ts +34 -17
  644. package/browser/repository/Repository.js +32 -8
  645. package/browser/repository/Repository.js.map +1 -1
  646. package/browser/repository/TreeRepository.d.ts +3 -3
  647. package/browser/repository/TreeRepository.js.map +1 -1
  648. package/browser/repository/UpsertOptions.d.ts +2 -2
  649. package/browser/repository/UpsertOptions.js.map +1 -1
  650. package/browser/schema-builder/MongoSchemaBuilder.d.ts +2 -2
  651. package/browser/schema-builder/MongoSchemaBuilder.js.map +1 -1
  652. package/browser/schema-builder/RdbmsSchemaBuilder.d.ts +7 -7
  653. package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  654. package/browser/schema-builder/SchemaBuilder.d.ts +1 -1
  655. package/browser/schema-builder/SchemaBuilder.js.map +1 -1
  656. package/browser/schema-builder/options/TableOptions.d.ts +6 -6
  657. package/browser/schema-builder/options/TableOptions.js.map +1 -1
  658. package/browser/schema-builder/options/ViewOptions.d.ts +1 -1
  659. package/browser/schema-builder/options/ViewOptions.js.map +1 -1
  660. package/browser/schema-builder/table/Table.d.ts +3 -3
  661. package/browser/schema-builder/table/Table.js.map +1 -1
  662. package/browser/schema-builder/table/TableCheck.d.ts +2 -2
  663. package/browser/schema-builder/table/TableCheck.js.map +1 -1
  664. package/browser/schema-builder/table/TableColumn.d.ts +1 -1
  665. package/browser/schema-builder/table/TableColumn.js.map +1 -1
  666. package/browser/schema-builder/table/TableExclusion.d.ts +2 -2
  667. package/browser/schema-builder/table/TableExclusion.js.map +1 -1
  668. package/browser/schema-builder/table/TableForeignKey.d.ts +3 -3
  669. package/browser/schema-builder/table/TableForeignKey.js.map +1 -1
  670. package/browser/schema-builder/table/TableIndex.d.ts +2 -2
  671. package/browser/schema-builder/table/TableIndex.js.map +1 -1
  672. package/browser/schema-builder/table/TableUnique.d.ts +2 -2
  673. package/browser/schema-builder/table/TableUnique.js.map +1 -1
  674. package/browser/schema-builder/util/TableUtils.d.ts +3 -3
  675. package/browser/schema-builder/util/TableUtils.js.map +1 -1
  676. package/browser/schema-builder/util/ViewUtils.d.ts +1 -1
  677. package/browser/schema-builder/util/ViewUtils.js.map +1 -1
  678. package/browser/schema-builder/view/View.d.ts +2 -2
  679. package/browser/schema-builder/view/View.js.map +1 -1
  680. package/browser/subscriber/Broadcaster.d.ts +6 -6
  681. package/browser/subscriber/Broadcaster.js.map +1 -1
  682. package/browser/subscriber/BroadcasterResult.js.map +1 -1
  683. package/browser/subscriber/EntitySubscriberInterface.d.ts +9 -9
  684. package/browser/subscriber/EntitySubscriberInterface.js.map +1 -1
  685. package/browser/subscriber/event/InsertEvent.d.ts +4 -4
  686. package/browser/subscriber/event/InsertEvent.js.map +1 -1
  687. package/browser/subscriber/event/LoadEvent.d.ts +4 -4
  688. package/browser/subscriber/event/LoadEvent.js.map +1 -1
  689. package/browser/subscriber/event/RecoverEvent.d.ts +2 -3
  690. package/browser/subscriber/event/RecoverEvent.js.map +1 -1
  691. package/browser/subscriber/event/RemoveEvent.d.ts +4 -4
  692. package/browser/subscriber/event/RemoveEvent.js.map +1 -1
  693. package/browser/subscriber/event/SoftRemoveEvent.d.ts +2 -3
  694. package/browser/subscriber/event/SoftRemoveEvent.js.map +1 -1
  695. package/browser/subscriber/event/TransactionCommitEvent.d.ts +3 -3
  696. package/browser/subscriber/event/TransactionCommitEvent.js.map +1 -1
  697. package/browser/subscriber/event/TransactionRollbackEvent.d.ts +3 -3
  698. package/browser/subscriber/event/TransactionRollbackEvent.js.map +1 -1
  699. package/browser/subscriber/event/TransactionStartEvent.d.ts +3 -3
  700. package/browser/subscriber/event/TransactionStartEvent.js.map +1 -1
  701. package/browser/subscriber/event/UpdateEvent.d.ts +7 -7
  702. package/browser/subscriber/event/UpdateEvent.js.map +1 -1
  703. package/browser/util/ApplyValueTransformers.d.ts +1 -1
  704. package/browser/util/ApplyValueTransformers.js.map +1 -1
  705. package/browser/util/DateUtils.d.ts +1 -1
  706. package/browser/util/DateUtils.js.map +1 -1
  707. package/browser/util/DepGraph.js +14 -14
  708. package/browser/util/DepGraph.js.map +1 -1
  709. package/browser/util/DirectoryExportedClassesLoader.d.ts +1 -1
  710. package/browser/util/DirectoryExportedClassesLoader.js.map +1 -1
  711. package/browser/util/InstanceChecker.d.ts +2 -2
  712. package/browser/util/InstanceChecker.js.map +1 -1
  713. package/browser/util/ObjectUtils.d.ts +1 -1
  714. package/browser/util/ObjectUtils.js.map +1 -1
  715. package/browser/util/OrmUtils.d.ts +1 -1
  716. package/browser/util/OrmUtils.js +4 -4
  717. package/browser/util/OrmUtils.js.map +1 -1
  718. package/browser/util/RandomGenerator.js +6 -6
  719. package/browser/util/RandomGenerator.js.map +1 -1
  720. package/browser/util/StringUtils.js.map +1 -1
  721. package/browser/util/TreeRepositoryUtils.d.ts +3 -3
  722. package/browser/util/TreeRepositoryUtils.js.map +1 -1
  723. package/browser/util/VersionUtils.d.ts +1 -1
  724. package/browser/util/VersionUtils.js.map +1 -1
  725. package/browser/util/escapeRegExp.d.ts +1 -1
  726. package/browser/util/escapeRegExp.js.map +1 -1
  727. package/cache/DbQueryResultCache.d.ts +4 -4
  728. package/cache/DbQueryResultCache.js +1 -1
  729. package/cache/DbQueryResultCache.js.map +1 -1
  730. package/cache/QueryResultCache.d.ts +2 -2
  731. package/cache/QueryResultCache.js.map +1 -1
  732. package/cache/QueryResultCacheFactory.d.ts +2 -2
  733. package/cache/QueryResultCacheFactory.js.map +1 -1
  734. package/cache/RedisQueryResultCache.d.ts +4 -4
  735. package/cache/RedisQueryResultCache.js.map +1 -1
  736. package/cli-ts-node-commonjs.js +0 -0
  737. package/cli-ts-node-esm.js +0 -0
  738. package/cli.js +0 -0
  739. package/commands/CacheClearCommand.d.ts +1 -1
  740. package/commands/CacheClearCommand.js.map +1 -1
  741. package/commands/CommandUtils.d.ts +2 -2
  742. package/commands/CommandUtils.js.map +1 -1
  743. package/commands/EntityCreateCommand.d.ts +1 -1
  744. package/commands/EntityCreateCommand.js.map +1 -1
  745. package/commands/InitCommand.d.ts +1 -1
  746. package/commands/InitCommand.js.map +1 -1
  747. package/commands/MigrationCreateCommand.d.ts +2 -2
  748. package/commands/MigrationCreateCommand.js.map +1 -1
  749. package/commands/MigrationGenerateCommand.d.ts +2 -2
  750. package/commands/MigrationGenerateCommand.js.map +1 -1
  751. package/commands/MigrationRevertCommand.d.ts +1 -1
  752. package/commands/MigrationRevertCommand.js.map +1 -1
  753. package/commands/MigrationRunCommand.d.ts +1 -1
  754. package/commands/MigrationRunCommand.js.map +1 -1
  755. package/commands/MigrationShowCommand.d.ts +1 -1
  756. package/commands/MigrationShowCommand.js.map +1 -1
  757. package/commands/QueryCommand.d.ts +1 -1
  758. package/commands/QueryCommand.js.map +1 -1
  759. package/commands/SchemaDropCommand.d.ts +1 -1
  760. package/commands/SchemaDropCommand.js.map +1 -1
  761. package/commands/SchemaLogCommand.d.ts +1 -1
  762. package/commands/SchemaLogCommand.js.map +1 -1
  763. package/commands/SchemaSyncCommand.d.ts +1 -1
  764. package/commands/SchemaSyncCommand.js.map +1 -1
  765. package/commands/SubscriberCreateCommand.d.ts +1 -1
  766. package/commands/SubscriberCreateCommand.js.map +1 -1
  767. package/commands/VersionCommand.d.ts +1 -1
  768. package/commands/VersionCommand.js.map +1 -1
  769. package/common/DeepPartial.d.ts +1 -1
  770. package/common/EntityTarget.d.ts +3 -3
  771. package/common/EntityTarget.js.map +1 -1
  772. package/common/MixedList.d.ts +1 -1
  773. package/common/NonNever.d.ts +1 -1
  774. package/common/ObjectType.d.ts +1 -1
  775. package/common/PickKeysByType.d.ts +6 -0
  776. package/common/PickKeysByType.js +4 -0
  777. package/common/PickKeysByType.js.map +1 -0
  778. package/common/RelationType.d.ts +1 -1
  779. package/connection/BaseConnectionOptions.d.ts +2 -2
  780. package/connection/BaseConnectionOptions.js.map +1 -1
  781. package/connection/ConnectionManager.d.ts +1 -1
  782. package/connection/ConnectionManager.js.map +1 -1
  783. package/connection/ConnectionMetadataBuilder.d.ts +5 -5
  784. package/connection/ConnectionMetadataBuilder.js.map +1 -1
  785. package/connection/ConnectionOptions.d.ts +2 -2
  786. package/connection/ConnectionOptions.js.map +1 -1
  787. package/connection/ConnectionOptionsReader.d.ts +1 -1
  788. package/connection/ConnectionOptionsReader.js.map +1 -1
  789. package/connection/options-reader/ConnectionOptionsEnvReader.d.ts +1 -1
  790. package/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  791. package/connection/options-reader/ConnectionOptionsXmlReader.d.ts +1 -1
  792. package/connection/options-reader/ConnectionOptionsXmlReader.js.map +1 -1
  793. package/connection/options-reader/ConnectionOptionsYmlReader.d.ts +1 -1
  794. package/connection/options-reader/ConnectionOptionsYmlReader.js.map +1 -1
  795. package/container.d.ts +1 -1
  796. package/data-source/BaseDataSourceOptions.d.ts +8 -8
  797. package/data-source/BaseDataSourceOptions.js.map +1 -1
  798. package/data-source/DataSource.d.ts +21 -21
  799. package/data-source/DataSource.js +1 -1
  800. package/data-source/DataSource.js.map +1 -1
  801. package/data-source/DataSourceOptions.d.ts +19 -19
  802. package/data-source/DataSourceOptions.js.map +1 -1
  803. package/decorator/Check.js.map +1 -1
  804. package/decorator/EntityRepository.d.ts +1 -1
  805. package/decorator/EntityRepository.js.map +1 -1
  806. package/decorator/Exclusion.js.map +1 -1
  807. package/decorator/Generated.js.map +1 -1
  808. package/decorator/Index.d.ts +1 -1
  809. package/decorator/Index.js.map +1 -1
  810. package/decorator/Unique.d.ts +1 -1
  811. package/decorator/Unique.js.map +1 -1
  812. package/decorator/columns/Column.d.ts +10 -10
  813. package/decorator/columns/Column.js.map +1 -1
  814. package/decorator/columns/CreateDateColumn.d.ts +1 -1
  815. package/decorator/columns/CreateDateColumn.js.map +1 -1
  816. package/decorator/columns/DeleteDateColumn.d.ts +1 -1
  817. package/decorator/columns/DeleteDateColumn.js.map +1 -1
  818. package/decorator/columns/ObjectIdColumn.d.ts +1 -1
  819. package/decorator/columns/ObjectIdColumn.js.map +1 -1
  820. package/decorator/columns/PrimaryColumn.d.ts +3 -3
  821. package/decorator/columns/PrimaryColumn.js.map +1 -1
  822. package/decorator/columns/PrimaryGeneratedColumn.d.ts +3 -3
  823. package/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  824. package/decorator/columns/UpdateDateColumn.d.ts +1 -1
  825. package/decorator/columns/UpdateDateColumn.js.map +1 -1
  826. package/decorator/columns/VersionColumn.d.ts +1 -1
  827. package/decorator/columns/VersionColumn.js.map +1 -1
  828. package/decorator/columns/ViewColumn.d.ts +1 -1
  829. package/decorator/columns/ViewColumn.js.map +1 -1
  830. package/decorator/columns/VirtualColumn.d.ts +2 -2
  831. package/decorator/columns/VirtualColumn.js.map +1 -1
  832. package/decorator/entity/ChildEntity.js.map +1 -1
  833. package/decorator/entity/Entity.d.ts +1 -1
  834. package/decorator/entity/Entity.js.map +1 -1
  835. package/decorator/entity/TableInheritance.d.ts +1 -1
  836. package/decorator/entity/TableInheritance.js.map +1 -1
  837. package/decorator/entity-view/ViewEntity.d.ts +1 -1
  838. package/decorator/entity-view/ViewEntity.js.map +1 -1
  839. package/decorator/listeners/AfterInsert.js.map +1 -1
  840. package/decorator/listeners/AfterLoad.js.map +1 -1
  841. package/decorator/listeners/AfterRecover.js.map +1 -1
  842. package/decorator/listeners/AfterRemove.js.map +1 -1
  843. package/decorator/listeners/AfterSoftRemove.js.map +1 -1
  844. package/decorator/listeners/AfterUpdate.js.map +1 -1
  845. package/decorator/listeners/BeforeInsert.js.map +1 -1
  846. package/decorator/listeners/BeforeRecover.js.map +1 -1
  847. package/decorator/listeners/BeforeRemove.js.map +1 -1
  848. package/decorator/listeners/BeforeSoftRemove.js.map +1 -1
  849. package/decorator/listeners/BeforeUpdate.js.map +1 -1
  850. package/decorator/listeners/EventSubscriber.js.map +1 -1
  851. package/decorator/options/ColumnCommonOptions.d.ts +1 -1
  852. package/decorator/options/ColumnCommonOptions.js.map +1 -1
  853. package/decorator/options/ColumnOptions.d.ts +3 -3
  854. package/decorator/options/ColumnOptions.js.map +1 -1
  855. package/decorator/options/EntityOptions.d.ts +1 -1
  856. package/decorator/options/EntityOptions.js.map +1 -1
  857. package/decorator/options/JoinTableMultipleColumnsOptions.d.ts +1 -1
  858. package/decorator/options/JoinTableMultipleColumnsOptions.js.map +1 -1
  859. package/decorator/options/JoinTableOptions.d.ts +1 -1
  860. package/decorator/options/JoinTableOptions.js.map +1 -1
  861. package/decorator/options/PrimaryGeneratedColumnIdentityOptions.d.ts +1 -1
  862. package/decorator/options/PrimaryGeneratedColumnIdentityOptions.js.map +1 -1
  863. package/decorator/options/PrimaryGeneratedColumnNumericOptions.d.ts +1 -1
  864. package/decorator/options/PrimaryGeneratedColumnNumericOptions.js.map +1 -1
  865. package/decorator/options/RelationOptions.d.ts +3 -3
  866. package/decorator/options/RelationOptions.js.map +1 -1
  867. package/decorator/options/SpatialColumnOptions.d.ts +1 -1
  868. package/decorator/options/SpatialColumnOptions.js.map +1 -1
  869. package/decorator/options/TransactionOptions.d.ts +1 -1
  870. package/decorator/options/TransactionOptions.js.map +1 -1
  871. package/decorator/options/UniqueOptions.d.ts +1 -1
  872. package/decorator/options/UniqueOptions.js.map +1 -1
  873. package/decorator/options/ViewColumnOptions.d.ts +1 -1
  874. package/decorator/options/ViewColumnOptions.js.map +1 -1
  875. package/decorator/options/ViewEntityOptions.d.ts +1 -1
  876. package/decorator/options/ViewEntityOptions.js.map +1 -1
  877. package/decorator/options/VirtualColumnOptions.d.ts +2 -2
  878. package/decorator/options/VirtualColumnOptions.js.map +1 -1
  879. package/decorator/relations/JoinColumn.d.ts +1 -1
  880. package/decorator/relations/JoinColumn.js.map +1 -1
  881. package/decorator/relations/JoinTable.d.ts +2 -2
  882. package/decorator/relations/JoinTable.js.map +1 -1
  883. package/decorator/relations/ManyToMany.d.ts +2 -2
  884. package/decorator/relations/ManyToMany.js.map +1 -1
  885. package/decorator/relations/ManyToOne.d.ts +2 -2
  886. package/decorator/relations/ManyToOne.js.map +1 -1
  887. package/decorator/relations/OneToMany.d.ts +2 -2
  888. package/decorator/relations/OneToMany.js.map +1 -1
  889. package/decorator/relations/OneToOne.d.ts +2 -2
  890. package/decorator/relations/OneToOne.js.map +1 -1
  891. package/decorator/relations/RelationCount.d.ts +1 -1
  892. package/decorator/relations/RelationCount.js.map +1 -1
  893. package/decorator/relations/RelationId.d.ts +1 -1
  894. package/decorator/relations/RelationId.js.map +1 -1
  895. package/decorator/tree/Tree.d.ts +2 -2
  896. package/decorator/tree/Tree.js.map +1 -1
  897. package/decorator/tree/TreeChildren.js.map +1 -1
  898. package/decorator/tree/TreeLevelColumn.js.map +1 -1
  899. package/decorator/tree/TreeParent.d.ts +1 -1
  900. package/decorator/tree/TreeParent.js.map +1 -1
  901. package/driver/Driver.d.ts +17 -17
  902. package/driver/Driver.js.map +1 -1
  903. package/driver/DriverFactory.d.ts +2 -2
  904. package/driver/DriverFactory.js.map +1 -1
  905. package/driver/DriverUtils.d.ts +1 -1
  906. package/driver/DriverUtils.js +2 -2
  907. package/driver/DriverUtils.js.map +1 -1
  908. package/driver/SqlInMemory.d.ts +1 -1
  909. package/driver/SqlInMemory.js.map +1 -1
  910. package/driver/aurora-mysql/AuroraMysqlConnection.d.ts +4 -4
  911. package/driver/aurora-mysql/AuroraMysqlConnection.js.map +1 -1
  912. package/driver/aurora-mysql/AuroraMysqlConnectionOptions.d.ts +2 -2
  913. package/driver/aurora-mysql/AuroraMysqlConnectionOptions.js.map +1 -1
  914. package/driver/aurora-mysql/AuroraMysqlDriver.d.ts +17 -17
  915. package/driver/aurora-mysql/AuroraMysqlDriver.js +2 -2
  916. package/driver/aurora-mysql/AuroraMysqlDriver.js.map +1 -1
  917. package/driver/aurora-mysql/AuroraMysqlQueryRunner.d.ts +6 -6
  918. package/driver/aurora-mysql/AuroraMysqlQueryRunner.js +1 -1
  919. package/driver/aurora-mysql/AuroraMysqlQueryRunner.js.map +1 -1
  920. package/driver/aurora-postgres/AuroraPostgresConnectionOptions.d.ts +1 -1
  921. package/driver/aurora-postgres/AuroraPostgresConnectionOptions.js.map +1 -1
  922. package/driver/aurora-postgres/AuroraPostgresDriver.d.ts +5 -5
  923. package/driver/aurora-postgres/AuroraPostgresDriver.js.map +1 -1
  924. package/driver/aurora-postgres/AuroraPostgresQueryRunner.d.ts +4 -4
  925. package/driver/aurora-postgres/AuroraPostgresQueryRunner.js.map +1 -1
  926. package/driver/better-sqlite3/BetterSqlite3ConnectionOptions.d.ts +7 -1
  927. package/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js.map +1 -1
  928. package/driver/better-sqlite3/BetterSqlite3Driver.d.ts +5 -5
  929. package/driver/better-sqlite3/BetterSqlite3Driver.js +3 -1
  930. package/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  931. package/driver/better-sqlite3/BetterSqlite3QueryRunner.d.ts +1 -1
  932. package/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -1
  933. package/driver/capacitor/CapacitorConnectionOptions.d.ts +1 -1
  934. package/driver/capacitor/CapacitorConnectionOptions.js.map +1 -1
  935. package/driver/capacitor/CapacitorDriver.d.ts +4 -4
  936. package/driver/capacitor/CapacitorDriver.js.map +1 -1
  937. package/driver/capacitor/CapacitorQueryRunner.d.ts +2 -2
  938. package/driver/capacitor/CapacitorQueryRunner.js.map +1 -1
  939. package/driver/cockroachdb/CockroachConnectionCredentialsOptions.d.ts +1 -1
  940. package/driver/cockroachdb/CockroachConnectionCredentialsOptions.js.map +1 -1
  941. package/driver/cockroachdb/CockroachConnectionOptions.d.ts +2 -2
  942. package/driver/cockroachdb/CockroachConnectionOptions.js.map +1 -1
  943. package/driver/cockroachdb/CockroachDriver.d.ts +18 -18
  944. package/driver/cockroachdb/CockroachDriver.js +2 -2
  945. package/driver/cockroachdb/CockroachDriver.js.map +1 -1
  946. package/driver/cockroachdb/CockroachQueryRunner.d.ts +5 -5
  947. package/driver/cockroachdb/CockroachQueryRunner.js +2 -2
  948. package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  949. package/driver/cordova/CordovaConnectionOptions.d.ts +1 -1
  950. package/driver/cordova/CordovaConnectionOptions.js.map +1 -1
  951. package/driver/cordova/CordovaDriver.d.ts +4 -4
  952. package/driver/cordova/CordovaDriver.js.map +1 -1
  953. package/driver/cordova/CordovaQueryRunner.d.ts +2 -2
  954. package/driver/cordova/CordovaQueryRunner.js +1 -1
  955. package/driver/cordova/CordovaQueryRunner.js.map +1 -1
  956. package/driver/expo/ExpoConnectionOptions.d.ts +1 -1
  957. package/driver/expo/ExpoConnectionOptions.js.map +1 -1
  958. package/driver/expo/ExpoDriver.d.ts +4 -4
  959. package/driver/expo/ExpoDriver.js.map +1 -1
  960. package/driver/expo/ExpoQueryRunner.d.ts +1 -1
  961. package/driver/expo/ExpoQueryRunner.js +1 -1
  962. package/driver/expo/ExpoQueryRunner.js.map +1 -1
  963. package/driver/mongodb/MongoConnectionOptions.d.ts +2 -2
  964. package/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  965. package/driver/mongodb/MongoDriver.d.ts +17 -17
  966. package/driver/mongodb/MongoDriver.js.map +1 -1
  967. package/driver/mongodb/MongoQueryRunner.d.ts +16 -16
  968. package/driver/mongodb/MongoQueryRunner.js.map +1 -1
  969. package/driver/mongodb/typings.d.ts +6 -6
  970. package/driver/mysql/MysqlConnectionOptions.d.ts +2 -2
  971. package/driver/mysql/MysqlConnectionOptions.js.map +1 -1
  972. package/driver/mysql/MysqlDriver.d.ts +17 -17
  973. package/driver/mysql/MysqlDriver.js +2 -2
  974. package/driver/mysql/MysqlDriver.js.map +1 -1
  975. package/driver/mysql/MysqlQueryRunner.d.ts +7 -7
  976. package/driver/mysql/MysqlQueryRunner.js +1 -1
  977. package/driver/mysql/MysqlQueryRunner.js.map +1 -1
  978. package/driver/nativescript/NativescriptConnectionOptions.d.ts +1 -1
  979. package/driver/nativescript/NativescriptConnectionOptions.js.map +1 -1
  980. package/driver/nativescript/NativescriptDriver.d.ts +5 -5
  981. package/driver/nativescript/NativescriptDriver.js.map +1 -1
  982. package/driver/nativescript/NativescriptQueryRunner.d.ts +2 -2
  983. package/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  984. package/driver/oracle/OracleConnectionOptions.d.ts +2 -2
  985. package/driver/oracle/OracleConnectionOptions.js.map +1 -1
  986. package/driver/oracle/OracleDriver.d.ts +17 -17
  987. package/driver/oracle/OracleDriver.js +2 -2
  988. package/driver/oracle/OracleDriver.js.map +1 -1
  989. package/driver/oracle/OracleQueryRunner.d.ts +6 -6
  990. package/driver/oracle/OracleQueryRunner.js +2 -2
  991. package/driver/oracle/OracleQueryRunner.js.map +1 -1
  992. package/driver/postgres/PostgresConnectionCredentialsOptions.d.ts +1 -1
  993. package/driver/postgres/PostgresConnectionCredentialsOptions.js.map +1 -1
  994. package/driver/postgres/PostgresConnectionOptions.d.ts +2 -2
  995. package/driver/postgres/PostgresConnectionOptions.js.map +1 -1
  996. package/driver/postgres/PostgresDriver.d.ts +18 -18
  997. package/driver/postgres/PostgresDriver.js +2 -2
  998. package/driver/postgres/PostgresDriver.js.map +1 -1
  999. package/driver/postgres/PostgresQueryRunner.d.ts +5 -5
  1000. package/driver/postgres/PostgresQueryRunner.js +3 -3
  1001. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  1002. package/driver/react-native/ReactNativeConnectionOptions.d.ts +1 -1
  1003. package/driver/react-native/ReactNativeConnectionOptions.js.map +1 -1
  1004. package/driver/react-native/ReactNativeDriver.d.ts +4 -4
  1005. package/driver/react-native/ReactNativeDriver.js.map +1 -1
  1006. package/driver/react-native/ReactNativeQueryRunner.d.ts +2 -2
  1007. package/driver/react-native/ReactNativeQueryRunner.js +1 -1
  1008. package/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  1009. package/driver/sap/SapConnectionOptions.d.ts +2 -2
  1010. package/driver/sap/SapConnectionOptions.js.map +1 -1
  1011. package/driver/sap/SapDriver.d.ts +10 -10
  1012. package/driver/sap/SapDriver.js +2 -2
  1013. package/driver/sap/SapDriver.js.map +1 -1
  1014. package/driver/sap/SapQueryRunner.d.ts +6 -6
  1015. package/driver/sap/SapQueryRunner.js +1 -1
  1016. package/driver/sap/SapQueryRunner.js.map +1 -1
  1017. package/driver/spanner/SpannerConnectionOptions.d.ts +2 -2
  1018. package/driver/spanner/SpannerConnectionOptions.js.map +1 -1
  1019. package/driver/spanner/SpannerDriver.d.ts +12 -12
  1020. package/driver/spanner/SpannerDriver.js +3 -3
  1021. package/driver/spanner/SpannerDriver.js.map +1 -1
  1022. package/driver/spanner/SpannerQueryRunner.d.ts +6 -6
  1023. package/driver/spanner/SpannerQueryRunner.js +7 -7
  1024. package/driver/spanner/SpannerQueryRunner.js.map +1 -1
  1025. package/driver/sqlite/SqliteConnectionOptions.d.ts +1 -1
  1026. package/driver/sqlite/SqliteConnectionOptions.js.map +1 -1
  1027. package/driver/sqlite/SqliteDriver.d.ts +5 -5
  1028. package/driver/sqlite/SqliteDriver.js.map +1 -1
  1029. package/driver/sqlite/SqliteQueryRunner.d.ts +1 -1
  1030. package/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  1031. package/driver/sqlite-abstract/AbstractSqliteDriver.d.ts +18 -18
  1032. package/driver/sqlite-abstract/AbstractSqliteDriver.js +13 -1
  1033. package/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  1034. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.d.ts +5 -5
  1035. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +10 -10
  1036. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  1037. package/driver/sqljs/SqljsConnectionOptions.d.ts +1 -1
  1038. package/driver/sqljs/SqljsConnectionOptions.js.map +1 -1
  1039. package/driver/sqljs/SqljsDriver.d.ts +5 -5
  1040. package/driver/sqljs/SqljsDriver.js +1 -1
  1041. package/driver/sqljs/SqljsDriver.js.map +1 -1
  1042. package/driver/sqljs/SqljsQueryRunner.d.ts +1 -1
  1043. package/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  1044. package/driver/sqlserver/SqlServerConnectionCredentialsOptions.d.ts +8 -8
  1045. package/driver/sqlserver/SqlServerConnectionCredentialsOptions.js.map +1 -1
  1046. package/driver/sqlserver/SqlServerConnectionOptions.d.ts +2 -2
  1047. package/driver/sqlserver/SqlServerConnectionOptions.js.map +1 -1
  1048. package/driver/sqlserver/SqlServerDriver.d.ts +16 -16
  1049. package/driver/sqlserver/SqlServerDriver.js +2 -2
  1050. package/driver/sqlserver/SqlServerDriver.js.map +1 -1
  1051. package/driver/sqlserver/SqlServerQueryRunner.d.ts +7 -7
  1052. package/driver/sqlserver/SqlServerQueryRunner.js +4 -4
  1053. package/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  1054. package/driver/types/ColumnTypes.d.ts +7 -7
  1055. package/driver/types/DatabaseType.d.ts +1 -1
  1056. package/driver/types/GeoJsonTypes.d.ts +12 -12
  1057. package/driver/types/IsolationLevel.d.ts +1 -1
  1058. package/driver/types/MappedColumnTypes.d.ts +1 -1
  1059. package/driver/types/MappedColumnTypes.js.map +1 -1
  1060. package/driver/types/ReplicationMode.d.ts +1 -1
  1061. package/driver/types/UpsertType.d.ts +1 -1
  1062. package/entity-manager/EntityManager.d.ts +37 -19
  1063. package/entity-manager/EntityManager.js +32 -0
  1064. package/entity-manager/EntityManager.js.map +1 -1
  1065. package/entity-manager/EntityManagerFactory.d.ts +2 -2
  1066. package/entity-manager/EntityManagerFactory.js.map +1 -1
  1067. package/entity-manager/MongoEntityManager.d.ts +12 -12
  1068. package/entity-manager/MongoEntityManager.js +5 -5
  1069. package/entity-manager/MongoEntityManager.js.map +1 -1
  1070. package/entity-manager/SqljsEntityManager.d.ts +2 -2
  1071. package/entity-manager/SqljsEntityManager.js.map +1 -1
  1072. package/entity-schema/EntitySchema.d.ts +1 -1
  1073. package/entity-schema/EntitySchema.js.map +1 -1
  1074. package/entity-schema/EntitySchemaColumnOptions.d.ts +3 -3
  1075. package/entity-schema/EntitySchemaColumnOptions.js.map +1 -1
  1076. package/entity-schema/EntitySchemaEmbeddedColumnOptions.d.ts +1 -1
  1077. package/entity-schema/EntitySchemaEmbeddedColumnOptions.js.map +1 -1
  1078. package/entity-schema/EntitySchemaOptions.d.ts +10 -10
  1079. package/entity-schema/EntitySchemaOptions.js.map +1 -1
  1080. package/entity-schema/EntitySchemaRelationIdOptions.d.ts +1 -1
  1081. package/entity-schema/EntitySchemaRelationIdOptions.js.map +1 -1
  1082. package/entity-schema/EntitySchemaRelationOptions.d.ts +8 -8
  1083. package/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
  1084. package/entity-schema/EntitySchemaTransformer.d.ts +1 -1
  1085. package/entity-schema/EntitySchemaTransformer.js.map +1 -1
  1086. package/entity-schema/EntitySchemaUniqueOptions.d.ts +1 -1
  1087. package/entity-schema/EntitySchemaUniqueOptions.js.map +1 -1
  1088. package/error/CannotCreateEntityIdMapError.d.ts +1 -1
  1089. package/error/CannotCreateEntityIdMapError.js.map +1 -1
  1090. package/error/DataTypeNotSupportedError.d.ts +3 -3
  1091. package/error/DataTypeNotSupportedError.js.map +1 -1
  1092. package/error/EntityMetadataNotFoundError.d.ts +1 -1
  1093. package/error/EntityMetadataNotFoundError.js.map +1 -1
  1094. package/error/EntityNotFoundError.d.ts +1 -1
  1095. package/error/EntityNotFoundError.js.map +1 -1
  1096. package/error/EntityPropertyNotFoundError.d.ts +1 -1
  1097. package/error/EntityPropertyNotFoundError.js.map +1 -1
  1098. package/error/ForbiddenTransactionModeOverrideError.d.ts +1 -1
  1099. package/error/ForbiddenTransactionModeOverrideError.js.map +1 -1
  1100. package/error/InitializedRelationError.d.ts +1 -1
  1101. package/error/InitializedRelationError.js.map +1 -1
  1102. package/error/MissingDeleteDateColumnError.d.ts +1 -1
  1103. package/error/MissingDeleteDateColumnError.js.map +1 -1
  1104. package/error/MissingJoinColumnError.d.ts +2 -2
  1105. package/error/MissingJoinColumnError.js.map +1 -1
  1106. package/error/MissingJoinTableError.d.ts +2 -2
  1107. package/error/MissingJoinTableError.js.map +1 -1
  1108. package/error/MissingPrimaryColumnError.d.ts +1 -1
  1109. package/error/MissingPrimaryColumnError.js.map +1 -1
  1110. package/error/RepositoryNotTreeError.d.ts +1 -1
  1111. package/error/RepositoryNotTreeError.js.map +1 -1
  1112. package/error/SubjectRemovedAndUpdatedError.d.ts +1 -1
  1113. package/error/SubjectRemovedAndUpdatedError.js.map +1 -1
  1114. package/error/SubjectWithoutIdentifierError.d.ts +1 -1
  1115. package/error/SubjectWithoutIdentifierError.js.map +1 -1
  1116. package/error/TreeRepositoryNotSupportedError.d.ts +1 -1
  1117. package/error/TreeRepositoryNotSupportedError.js.map +1 -1
  1118. package/error/UsingJoinColumnIsNotAllowedError.d.ts +2 -2
  1119. package/error/UsingJoinColumnIsNotAllowedError.js.map +1 -1
  1120. package/error/UsingJoinColumnOnlyOnOneSideAllowedError.d.ts +2 -2
  1121. package/error/UsingJoinColumnOnlyOnOneSideAllowedError.js.map +1 -1
  1122. package/error/UsingJoinTableIsNotAllowedError.d.ts +2 -2
  1123. package/error/UsingJoinTableIsNotAllowedError.js.map +1 -1
  1124. package/error/UsingJoinTableOnlyOnOneSideAllowedError.d.ts +2 -2
  1125. package/error/UsingJoinTableOnlyOnOneSideAllowedError.js.map +1 -1
  1126. package/find-options/FindManyOptions.d.ts +1 -1
  1127. package/find-options/FindManyOptions.js.map +1 -1
  1128. package/find-options/FindOneOptions.d.ts +5 -5
  1129. package/find-options/FindOneOptions.js.map +1 -1
  1130. package/find-options/FindOperator.d.ts +3 -3
  1131. package/find-options/FindOperator.js.map +1 -1
  1132. package/find-options/FindOperatorType.d.ts +1 -1
  1133. package/find-options/FindOperatorType.js.map +1 -1
  1134. package/find-options/FindOptionsOrder.d.ts +4 -4
  1135. package/find-options/FindOptionsOrder.js.map +1 -1
  1136. package/find-options/FindOptionsRelations.d.ts +4 -4
  1137. package/find-options/FindOptionsRelations.js.map +1 -1
  1138. package/find-options/FindOptionsSelect.d.ts +4 -4
  1139. package/find-options/FindOptionsSelect.js.map +1 -1
  1140. package/find-options/FindOptionsUtils.d.ts +6 -6
  1141. package/find-options/FindOptionsUtils.js +1 -1
  1142. package/find-options/FindOptionsUtils.js.map +1 -1
  1143. package/find-options/FindOptionsWhere.d.ts +9 -5
  1144. package/find-options/FindOptionsWhere.js.map +1 -1
  1145. package/find-options/OrderByCondition.d.ts +1 -1
  1146. package/find-options/mongodb/MongoFindManyOptions.d.ts +1 -1
  1147. package/find-options/mongodb/MongoFindManyOptions.js.map +1 -1
  1148. package/find-options/mongodb/MongoFindOneOptions.d.ts +3 -3
  1149. package/find-options/mongodb/MongoFindOneOptions.js.map +1 -1
  1150. package/find-options/operator/Equal.d.ts +1 -1
  1151. package/find-options/operator/Equal.js.map +1 -1
  1152. package/find-options/operator/JsonContains.d.ts +6 -0
  1153. package/find-options/operator/JsonContains.js +14 -0
  1154. package/find-options/operator/JsonContains.js.map +1 -0
  1155. package/find-options/operator/Raw.d.ts +1 -1
  1156. package/find-options/operator/Raw.js.map +1 -1
  1157. package/globals.d.ts +12 -12
  1158. package/globals.js.map +1 -1
  1159. package/index.d.ts +3 -0
  1160. package/index.js +5 -1
  1161. package/index.js.map +1 -1
  1162. package/index.mjs +6 -0
  1163. package/logger/AbstractLogger.d.ts +49 -0
  1164. package/logger/AbstractLogger.js +234 -0
  1165. package/logger/AbstractLogger.js.map +1 -0
  1166. package/logger/AdvancedConsoleLogger.d.ts +6 -34
  1167. package/logger/AdvancedConsoleLogger.js +41 -106
  1168. package/logger/AdvancedConsoleLogger.js.map +1 -1
  1169. package/logger/DebugLogger.d.ts +10 -30
  1170. package/logger/DebugLogger.js +56 -75
  1171. package/logger/DebugLogger.js.map +1 -1
  1172. package/logger/FileLogger.d.ts +8 -34
  1173. package/logger/FileLogger.js +50 -97
  1174. package/logger/FileLogger.js.map +1 -1
  1175. package/logger/Logger.d.ts +32 -1
  1176. package/logger/Logger.js.map +1 -1
  1177. package/logger/LoggerFactory.d.ts +2 -2
  1178. package/logger/LoggerFactory.js.map +1 -1
  1179. package/logger/LoggerOptions.d.ts +3 -2
  1180. package/logger/LoggerOptions.js.map +1 -1
  1181. package/logger/SimpleConsoleLogger.d.ts +6 -34
  1182. package/logger/SimpleConsoleLogger.js +43 -106
  1183. package/logger/SimpleConsoleLogger.js.map +1 -1
  1184. package/metadata/CheckMetadata.d.ts +3 -3
  1185. package/metadata/CheckMetadata.js.map +1 -1
  1186. package/metadata/ColumnMetadata.d.ts +8 -8
  1187. package/metadata/ColumnMetadata.js.map +1 -1
  1188. package/metadata/EmbeddedMetadata.d.ts +10 -10
  1189. package/metadata/EmbeddedMetadata.js +1 -1
  1190. package/metadata/EmbeddedMetadata.js.map +1 -1
  1191. package/metadata/EntityListenerMetadata.d.ts +5 -5
  1192. package/metadata/EntityListenerMetadata.js.map +1 -1
  1193. package/metadata/EntityMetadata.d.ts +20 -20
  1194. package/metadata/EntityMetadata.js.map +1 -1
  1195. package/metadata/ExclusionMetadata.d.ts +3 -3
  1196. package/metadata/ExclusionMetadata.js.map +1 -1
  1197. package/metadata/ForeignKeyMetadata.d.ts +6 -6
  1198. package/metadata/ForeignKeyMetadata.js.map +1 -1
  1199. package/metadata/IndexMetadata.d.ts +5 -5
  1200. package/metadata/IndexMetadata.js.map +1 -1
  1201. package/metadata/RelationCountMetadata.d.ts +4 -4
  1202. package/metadata/RelationCountMetadata.js.map +1 -1
  1203. package/metadata/RelationIdMetadata.d.ts +5 -5
  1204. package/metadata/RelationIdMetadata.js.map +1 -1
  1205. package/metadata/RelationMetadata.d.ts +10 -10
  1206. package/metadata/RelationMetadata.js.map +1 -1
  1207. package/metadata/UniqueMetadata.d.ts +6 -6
  1208. package/metadata/UniqueMetadata.js.map +1 -1
  1209. package/metadata/types/ClosureTreeOptions.d.ts +1 -1
  1210. package/metadata/types/ClosureTreeOptions.js.map +1 -1
  1211. package/metadata/types/DeferrableType.d.ts +1 -1
  1212. package/metadata/types/EventListenerTypes.d.ts +1 -1
  1213. package/metadata/types/OnDeleteType.d.ts +1 -1
  1214. package/metadata/types/OnUpdateType.d.ts +1 -1
  1215. package/metadata/types/PropertyTypeInFunction.d.ts +1 -1
  1216. package/metadata/types/RelationTypeInFunction.d.ts +2 -2
  1217. package/metadata/types/RelationTypeInFunction.js.map +1 -1
  1218. package/metadata/types/RelationTypes.d.ts +1 -1
  1219. package/metadata/types/TableTypes.d.ts +1 -1
  1220. package/metadata/types/TreeTypes.d.ts +1 -1
  1221. package/metadata-args/ColumnMetadataArgs.d.ts +2 -2
  1222. package/metadata-args/ColumnMetadataArgs.js.map +1 -1
  1223. package/metadata-args/EntityListenerMetadataArgs.d.ts +1 -1
  1224. package/metadata-args/EntityListenerMetadataArgs.js.map +1 -1
  1225. package/metadata-args/EntityRepositoryMetadataArgs.d.ts +1 -1
  1226. package/metadata-args/EntityRepositoryMetadataArgs.js.map +1 -1
  1227. package/metadata-args/InheritanceMetadataArgs.d.ts +1 -1
  1228. package/metadata-args/InheritanceMetadataArgs.js.map +1 -1
  1229. package/metadata-args/JoinTableMetadataArgs.d.ts +1 -1
  1230. package/metadata-args/JoinTableMetadataArgs.js.map +1 -1
  1231. package/metadata-args/MetadataArgsStorage.d.ts +22 -22
  1232. package/metadata-args/MetadataArgsStorage.js.map +1 -1
  1233. package/metadata-args/RelationCountMetadataArgs.d.ts +1 -1
  1234. package/metadata-args/RelationCountMetadataArgs.js.map +1 -1
  1235. package/metadata-args/RelationIdMetadataArgs.d.ts +1 -1
  1236. package/metadata-args/RelationIdMetadataArgs.js.map +1 -1
  1237. package/metadata-args/RelationMetadataArgs.d.ts +4 -4
  1238. package/metadata-args/RelationMetadataArgs.js.map +1 -1
  1239. package/metadata-args/TableMetadataArgs.d.ts +3 -3
  1240. package/metadata-args/TableMetadataArgs.js.map +1 -1
  1241. package/metadata-args/TreeMetadataArgs.d.ts +2 -2
  1242. package/metadata-args/TreeMetadataArgs.js.map +1 -1
  1243. package/metadata-args/UniqueMetadataArgs.d.ts +1 -1
  1244. package/metadata-args/UniqueMetadataArgs.js.map +1 -1
  1245. package/metadata-args/types/ColumnMode.d.ts +1 -1
  1246. package/metadata-builder/ClosureJunctionEntityMetadataBuilder.d.ts +1 -1
  1247. package/metadata-builder/ClosureJunctionEntityMetadataBuilder.js.map +1 -1
  1248. package/metadata-builder/EntityMetadataBuilder.d.ts +4 -4
  1249. package/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  1250. package/metadata-builder/EntityMetadataValidator.d.ts +2 -2
  1251. package/metadata-builder/EntityMetadataValidator.js.map +1 -1
  1252. package/metadata-builder/JunctionEntityMetadataBuilder.d.ts +3 -3
  1253. package/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
  1254. package/metadata-builder/RelationJoinColumnBuilder.d.ts +3 -3
  1255. package/metadata-builder/RelationJoinColumnBuilder.js +2 -1
  1256. package/metadata-builder/RelationJoinColumnBuilder.js.map +1 -1
  1257. package/migration/Migration.d.ts +1 -1
  1258. package/migration/Migration.js.map +1 -1
  1259. package/migration/MigrationExecutor.d.ts +2 -2
  1260. package/migration/MigrationExecutor.js +3 -3
  1261. package/migration/MigrationExecutor.js.map +1 -1
  1262. package/migration/MigrationInterface.d.ts +1 -1
  1263. package/migration/MigrationInterface.js.map +1 -1
  1264. package/naming-strategy/DefaultNamingStrategy.d.ts +2 -2
  1265. package/naming-strategy/DefaultNamingStrategy.js.map +1 -1
  1266. package/naming-strategy/LegacyOracleNamingStrategy.d.ts +21 -0
  1267. package/naming-strategy/LegacyOracleNamingStrategy.js +50 -0
  1268. package/naming-strategy/LegacyOracleNamingStrategy.js.map +1 -0
  1269. package/naming-strategy/NamingStrategyInterface.d.ts +2 -2
  1270. package/naming-strategy/NamingStrategyInterface.js.map +1 -1
  1271. package/package.json +273 -1
  1272. package/persistence/EntityPersistExecutor.d.ts +5 -5
  1273. package/persistence/EntityPersistExecutor.js +1 -1
  1274. package/persistence/EntityPersistExecutor.js.map +1 -1
  1275. package/persistence/Subject.d.ts +5 -5
  1276. package/persistence/Subject.js.map +1 -1
  1277. package/persistence/SubjectChangeMap.d.ts +3 -3
  1278. package/persistence/SubjectChangeMap.js.map +1 -1
  1279. package/persistence/SubjectChangedColumnsComputer.d.ts +1 -1
  1280. package/persistence/SubjectChangedColumnsComputer.js.map +1 -1
  1281. package/persistence/SubjectDatabaseEntityLoader.d.ts +3 -3
  1282. package/persistence/SubjectDatabaseEntityLoader.js +1 -1
  1283. package/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  1284. package/persistence/SubjectExecutor.d.ts +4 -4
  1285. package/persistence/SubjectExecutor.js +1 -1
  1286. package/persistence/SubjectExecutor.js.map +1 -1
  1287. package/persistence/SubjectTopoligicalSorter.d.ts +2 -2
  1288. package/persistence/SubjectTopoligicalSorter.js +7 -11
  1289. package/persistence/SubjectTopoligicalSorter.js.map +1 -1
  1290. package/persistence/subject-builder/CascadesSubjectBuilder.d.ts +1 -1
  1291. package/persistence/subject-builder/CascadesSubjectBuilder.js.map +1 -1
  1292. package/persistence/subject-builder/ManyToManySubjectBuilder.d.ts +2 -2
  1293. package/persistence/subject-builder/ManyToManySubjectBuilder.js.map +1 -1
  1294. package/persistence/subject-builder/OneToManySubjectBuilder.d.ts +1 -1
  1295. package/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  1296. package/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.d.ts +1 -1
  1297. package/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js +1 -1
  1298. package/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js.map +1 -1
  1299. package/persistence/tree/ClosureSubjectExecutor.d.ts +2 -2
  1300. package/persistence/tree/ClosureSubjectExecutor.js.map +1 -1
  1301. package/persistence/tree/MaterializedPathSubjectExecutor.d.ts +2 -2
  1302. package/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  1303. package/persistence/tree/NestedSetSubjectExecutor.d.ts +4 -4
  1304. package/persistence/tree/NestedSetSubjectExecutor.js +2 -2
  1305. package/persistence/tree/NestedSetSubjectExecutor.js.map +1 -1
  1306. package/platform/PlatformTools.d.ts +2 -0
  1307. package/platform/PlatformTools.js +6 -0
  1308. package/platform/PlatformTools.js.map +1 -1
  1309. package/query-builder/Alias.d.ts +1 -1
  1310. package/query-builder/Alias.js.map +1 -1
  1311. package/query-builder/Brackets.d.ts +1 -1
  1312. package/query-builder/Brackets.js.map +1 -1
  1313. package/query-builder/DeleteQueryBuilder.d.ts +6 -6
  1314. package/query-builder/DeleteQueryBuilder.js.map +1 -1
  1315. package/query-builder/InsertOrUpdateOptions.d.ts +2 -2
  1316. package/query-builder/InsertOrUpdateOptions.js.map +1 -1
  1317. package/query-builder/InsertQueryBuilder.d.ts +5 -5
  1318. package/query-builder/InsertQueryBuilder.js.map +1 -1
  1319. package/query-builder/JoinAttribute.d.ts +5 -5
  1320. package/query-builder/JoinAttribute.js +2 -2
  1321. package/query-builder/JoinAttribute.js.map +1 -1
  1322. package/query-builder/QueryBuilder.d.ts +18 -18
  1323. package/query-builder/QueryBuilder.js +3 -1
  1324. package/query-builder/QueryBuilder.js.map +1 -1
  1325. package/query-builder/QueryExpressionMap.d.ts +12 -12
  1326. package/query-builder/QueryExpressionMap.js.map +1 -1
  1327. package/query-builder/QueryPartialEntity.d.ts +4 -4
  1328. package/query-builder/QueryPartialEntity.js.map +1 -1
  1329. package/query-builder/RelationIdLoader.d.ts +4 -4
  1330. package/query-builder/RelationIdLoader.js +2 -2
  1331. package/query-builder/RelationIdLoader.js.map +1 -1
  1332. package/query-builder/RelationLoader.d.ts +5 -5
  1333. package/query-builder/RelationLoader.js.map +1 -1
  1334. package/query-builder/RelationQueryBuilder.d.ts +1 -1
  1335. package/query-builder/RelationQueryBuilder.js.map +1 -1
  1336. package/query-builder/RelationRemover.d.ts +2 -2
  1337. package/query-builder/RelationRemover.js.map +1 -1
  1338. package/query-builder/RelationUpdater.d.ts +2 -2
  1339. package/query-builder/RelationUpdater.js.map +1 -1
  1340. package/query-builder/ReturningResultsEntityUpdator.d.ts +6 -6
  1341. package/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
  1342. package/query-builder/SelectQueryBuilder.d.ts +18 -18
  1343. package/query-builder/SelectQueryBuilder.js +12 -8
  1344. package/query-builder/SelectQueryBuilder.js.map +1 -1
  1345. package/query-builder/SelectQueryBuilderOption.d.ts +1 -1
  1346. package/query-builder/SoftDeleteQueryBuilder.d.ts +7 -7
  1347. package/query-builder/SoftDeleteQueryBuilder.js +1 -1
  1348. package/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  1349. package/query-builder/UpdateQueryBuilder.d.ts +7 -7
  1350. package/query-builder/UpdateQueryBuilder.js +3 -3
  1351. package/query-builder/UpdateQueryBuilder.js.map +1 -1
  1352. package/query-builder/WhereClause.d.ts +3 -3
  1353. package/query-builder/WhereClause.js.map +1 -1
  1354. package/query-builder/WhereExpressionBuilder.d.ts +3 -4
  1355. package/query-builder/WhereExpressionBuilder.js.map +1 -1
  1356. package/query-builder/relation-count/RelationCountAttribute.d.ts +4 -4
  1357. package/query-builder/relation-count/RelationCountAttribute.js.map +1 -1
  1358. package/query-builder/relation-count/RelationCountLoadResult.d.ts +1 -1
  1359. package/query-builder/relation-count/RelationCountLoadResult.js.map +1 -1
  1360. package/query-builder/relation-count/RelationCountLoader.d.ts +4 -4
  1361. package/query-builder/relation-count/RelationCountLoader.js.map +1 -1
  1362. package/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.d.ts +1 -1
  1363. package/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.js.map +1 -1
  1364. package/query-builder/relation-id/RelationIdAttribute.d.ts +4 -4
  1365. package/query-builder/relation-id/RelationIdAttribute.js.map +1 -1
  1366. package/query-builder/relation-id/RelationIdLoadResult.d.ts +1 -1
  1367. package/query-builder/relation-id/RelationIdLoadResult.js.map +1 -1
  1368. package/query-builder/relation-id/RelationIdLoader.d.ts +4 -4
  1369. package/query-builder/relation-id/RelationIdLoader.js.map +1 -1
  1370. package/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.d.ts +1 -1
  1371. package/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.js.map +1 -1
  1372. package/query-builder/result/DeleteResult.d.ts +1 -1
  1373. package/query-builder/result/DeleteResult.js.map +1 -1
  1374. package/query-builder/result/InsertResult.d.ts +2 -2
  1375. package/query-builder/result/InsertResult.js.map +1 -1
  1376. package/query-builder/result/UpdateResult.d.ts +2 -2
  1377. package/query-builder/result/UpdateResult.js.map +1 -1
  1378. package/query-builder/transformer/DocumentToEntityTransformer.d.ts +2 -2
  1379. package/query-builder/transformer/DocumentToEntityTransformer.js.map +1 -1
  1380. package/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.d.ts +3 -3
  1381. package/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.js.map +1 -1
  1382. package/query-builder/transformer/PlainObjectToNewEntityTransformer.d.ts +2 -2
  1383. package/query-builder/transformer/PlainObjectToNewEntityTransformer.js.map +1 -1
  1384. package/query-builder/transformer/RawSqlResultsToEntityTransformer.d.ts +8 -8
  1385. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js +1 -1
  1386. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  1387. package/query-runner/BaseQueryRunner.d.ts +11 -11
  1388. package/query-runner/BaseQueryRunner.js.map +1 -1
  1389. package/query-runner/QueryRunner.d.ts +17 -17
  1390. package/query-runner/QueryRunner.js.map +1 -1
  1391. package/repository/AbstractRepository.d.ts +6 -6
  1392. package/repository/AbstractRepository.js.map +1 -1
  1393. package/repository/BaseEntity.d.ts +41 -16
  1394. package/repository/BaseEntity.js +24 -0
  1395. package/repository/BaseEntity.js.map +1 -1
  1396. package/repository/EntityId.d.ts +2 -2
  1397. package/repository/EntityId.js.map +1 -1
  1398. package/repository/MongoRepository.d.ts +8 -8
  1399. package/repository/MongoRepository.js.map +1 -1
  1400. package/repository/Repository.d.ts +34 -17
  1401. package/repository/Repository.js +32 -8
  1402. package/repository/Repository.js.map +1 -1
  1403. package/repository/TreeRepository.d.ts +3 -3
  1404. package/repository/TreeRepository.js.map +1 -1
  1405. package/repository/UpsertOptions.d.ts +2 -2
  1406. package/repository/UpsertOptions.js.map +1 -1
  1407. package/schema-builder/MongoSchemaBuilder.d.ts +2 -2
  1408. package/schema-builder/MongoSchemaBuilder.js.map +1 -1
  1409. package/schema-builder/RdbmsSchemaBuilder.d.ts +7 -7
  1410. package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  1411. package/schema-builder/SchemaBuilder.d.ts +1 -1
  1412. package/schema-builder/SchemaBuilder.js.map +1 -1
  1413. package/schema-builder/options/TableOptions.d.ts +6 -6
  1414. package/schema-builder/options/TableOptions.js.map +1 -1
  1415. package/schema-builder/options/ViewOptions.d.ts +1 -1
  1416. package/schema-builder/options/ViewOptions.js.map +1 -1
  1417. package/schema-builder/table/Table.d.ts +3 -3
  1418. package/schema-builder/table/Table.js.map +1 -1
  1419. package/schema-builder/table/TableCheck.d.ts +2 -2
  1420. package/schema-builder/table/TableCheck.js.map +1 -1
  1421. package/schema-builder/table/TableColumn.d.ts +1 -1
  1422. package/schema-builder/table/TableColumn.js.map +1 -1
  1423. package/schema-builder/table/TableExclusion.d.ts +2 -2
  1424. package/schema-builder/table/TableExclusion.js.map +1 -1
  1425. package/schema-builder/table/TableForeignKey.d.ts +3 -3
  1426. package/schema-builder/table/TableForeignKey.js.map +1 -1
  1427. package/schema-builder/table/TableIndex.d.ts +2 -2
  1428. package/schema-builder/table/TableIndex.js.map +1 -1
  1429. package/schema-builder/table/TableUnique.d.ts +2 -2
  1430. package/schema-builder/table/TableUnique.js.map +1 -1
  1431. package/schema-builder/util/TableUtils.d.ts +3 -3
  1432. package/schema-builder/util/TableUtils.js.map +1 -1
  1433. package/schema-builder/util/ViewUtils.d.ts +1 -1
  1434. package/schema-builder/util/ViewUtils.js.map +1 -1
  1435. package/schema-builder/view/View.d.ts +2 -2
  1436. package/schema-builder/view/View.js.map +1 -1
  1437. package/subscriber/Broadcaster.d.ts +6 -6
  1438. package/subscriber/Broadcaster.js.map +1 -1
  1439. package/subscriber/BroadcasterResult.js.map +1 -1
  1440. package/subscriber/EntitySubscriberInterface.d.ts +9 -9
  1441. package/subscriber/EntitySubscriberInterface.js.map +1 -1
  1442. package/subscriber/event/InsertEvent.d.ts +4 -4
  1443. package/subscriber/event/InsertEvent.js.map +1 -1
  1444. package/subscriber/event/LoadEvent.d.ts +4 -4
  1445. package/subscriber/event/LoadEvent.js.map +1 -1
  1446. package/subscriber/event/RecoverEvent.d.ts +2 -3
  1447. package/subscriber/event/RecoverEvent.js.map +1 -1
  1448. package/subscriber/event/RemoveEvent.d.ts +4 -4
  1449. package/subscriber/event/RemoveEvent.js.map +1 -1
  1450. package/subscriber/event/SoftRemoveEvent.d.ts +2 -3
  1451. package/subscriber/event/SoftRemoveEvent.js.map +1 -1
  1452. package/subscriber/event/TransactionCommitEvent.d.ts +3 -3
  1453. package/subscriber/event/TransactionCommitEvent.js.map +1 -1
  1454. package/subscriber/event/TransactionRollbackEvent.d.ts +3 -3
  1455. package/subscriber/event/TransactionRollbackEvent.js.map +1 -1
  1456. package/subscriber/event/TransactionStartEvent.d.ts +3 -3
  1457. package/subscriber/event/TransactionStartEvent.js.map +1 -1
  1458. package/subscriber/event/UpdateEvent.d.ts +7 -7
  1459. package/subscriber/event/UpdateEvent.js.map +1 -1
  1460. package/util/ApplyValueTransformers.d.ts +1 -1
  1461. package/util/ApplyValueTransformers.js.map +1 -1
  1462. package/util/DateUtils.d.ts +1 -1
  1463. package/util/DateUtils.js.map +1 -1
  1464. package/util/DepGraph.js +14 -14
  1465. package/util/DepGraph.js.map +1 -1
  1466. package/util/DirectoryExportedClassesLoader.d.ts +1 -1
  1467. package/util/DirectoryExportedClassesLoader.js.map +1 -1
  1468. package/util/InstanceChecker.d.ts +2 -2
  1469. package/util/InstanceChecker.js.map +1 -1
  1470. package/util/ObjectUtils.d.ts +1 -1
  1471. package/util/ObjectUtils.js.map +1 -1
  1472. package/util/OrmUtils.d.ts +1 -1
  1473. package/util/OrmUtils.js +4 -4
  1474. package/util/OrmUtils.js.map +1 -1
  1475. package/util/RandomGenerator.js +6 -6
  1476. package/util/RandomGenerator.js.map +1 -1
  1477. package/util/StringUtils.js.map +1 -1
  1478. package/util/TreeRepositoryUtils.d.ts +3 -3
  1479. package/util/TreeRepositoryUtils.js.map +1 -1
  1480. package/util/VersionUtils.d.ts +1 -1
  1481. package/util/VersionUtils.js.map +1 -1
  1482. package/util/escapeRegExp.d.ts +1 -1
  1483. package/util/escapeRegExp.js.map +1 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../browser/src/driver/sap/SapQueryRunner.ts"],"names":[],"mappings":"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","file":"SapQueryRunner.js","sourcesContent":["import { ObjectLiteral } from \"../../common/ObjectLiteral\"\nimport { QueryRunnerAlreadyReleasedError } from \"../../error/QueryRunnerAlreadyReleasedError\"\nimport { TransactionAlreadyStartedError } from \"../../error/TransactionAlreadyStartedError\"\nimport { TransactionNotStartedError } from \"../../error/TransactionNotStartedError\"\nimport { ColumnType } from \"../types/ColumnTypes\"\nimport { ReadStream } from \"../../platform/PlatformTools\"\nimport { BaseQueryRunner } from \"../../query-runner/BaseQueryRunner\"\nimport { QueryRunner } from \"../../query-runner/QueryRunner\"\nimport { TableIndexOptions } from \"../../schema-builder/options/TableIndexOptions\"\nimport { Table } from \"../../schema-builder/table/Table\"\nimport { TableCheck } from \"../../schema-builder/table/TableCheck\"\nimport { TableColumn } from \"../../schema-builder/table/TableColumn\"\nimport { TableExclusion } from \"../../schema-builder/table/TableExclusion\"\nimport { TableForeignKey } from \"../../schema-builder/table/TableForeignKey\"\nimport { TableIndex } from \"../../schema-builder/table/TableIndex\"\nimport { TableUnique } from \"../../schema-builder/table/TableUnique\"\nimport { View } from \"../../schema-builder/view/View\"\nimport { Broadcaster } from \"../../subscriber/Broadcaster\"\nimport { OrmUtils } from \"../../util/OrmUtils\"\nimport { Query } from \"../Query\"\nimport { IsolationLevel } from \"../types/IsolationLevel\"\nimport { SapDriver } from \"./SapDriver\"\nimport { ReplicationMode } from \"../types/ReplicationMode\"\nimport { QueryFailedError, TypeORMError } from \"../../error\"\nimport { QueryResult } from \"../../query-runner/QueryResult\"\nimport { QueryLock } from \"../../query-runner/QueryLock\"\nimport { MetadataTableType } from \"../types/MetadataTableType\"\nimport { InstanceChecker } from \"../../util/InstanceChecker\"\nimport { promisify } from \"util\"\n\n/**\n * Runs queries on a single SQL Server database connection.\n */\nexport class SapQueryRunner extends BaseQueryRunner implements QueryRunner {\n // -------------------------------------------------------------------------\n // Public Implemented Properties\n // -------------------------------------------------------------------------\n\n /**\n * Database driver used by connection.\n */\n driver: SapDriver\n\n // -------------------------------------------------------------------------\n // Protected Properties\n // -------------------------------------------------------------------------\n\n /**\n * Promise used to obtain a database connection from a pool for a first time.\n */\n protected databaseConnectionPromise: Promise<any>\n\n private lock: QueryLock = new QueryLock()\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: SapDriver, mode: ReplicationMode) {\n super()\n this.driver = driver\n this.connection = driver.connection\n this.broadcaster = new Broadcaster(this)\n this.mode = mode\n }\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n /**\n * Creates/uses database connection from the connection pool to perform further operations.\n * Returns obtained database connection.\n */\n async connect(): Promise<any> {\n if (this.databaseConnection) return this.databaseConnection\n\n this.databaseConnection = await this.driver.obtainMasterConnection()\n\n return this.databaseConnection\n }\n\n /**\n * Releases used database connection.\n * You cannot use query runner methods once its released.\n */\n release(): Promise<void> {\n this.isReleased = true\n\n if (this.databaseConnection) {\n return this.driver.master.release(this.databaseConnection)\n }\n\n return Promise.resolve()\n }\n\n /**\n * Starts transaction.\n */\n async startTransaction(isolationLevel?: IsolationLevel): Promise<void> {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError()\n\n if (\n this.isTransactionActive &&\n this.driver.transactionSupport === \"simple\"\n )\n throw new TransactionAlreadyStartedError()\n\n await this.broadcaster.broadcast(\"BeforeTransactionStart\")\n\n this.isTransactionActive = true\n\n /**\n * Disable AUTOCOMMIT while running transaction.\n * Otherwise, COMMIT/ROLLBACK doesn't work in autocommit mode.\n */\n await this.setAutoCommit({ status: \"off\" })\n\n if (isolationLevel) {\n await this.query(\n `SET TRANSACTION ISOLATION LEVEL ${isolationLevel || \"\"}`,\n )\n }\n\n await this.broadcaster.broadcast(\"AfterTransactionStart\")\n }\n\n /**\n * Commits transaction.\n * Error will be thrown if transaction was not started.\n */\n async commitTransaction(): Promise<void> {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError()\n\n if (!this.isTransactionActive) throw new TransactionNotStartedError()\n\n await this.broadcaster.broadcast(\"BeforeTransactionCommit\")\n\n await this.query(\"COMMIT\")\n this.isTransactionActive = false\n\n await this.setAutoCommit({ status: \"on\" })\n await this.broadcaster.broadcast(\"AfterTransactionCommit\")\n }\n\n /**\n * Rollbacks transaction.\n * Error will be thrown if transaction was not started.\n */\n async rollbackTransaction(): Promise<void> {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError()\n\n if (!this.isTransactionActive) throw new TransactionNotStartedError()\n\n await this.broadcaster.broadcast(\"BeforeTransactionRollback\")\n\n await this.query(\"ROLLBACK\")\n this.isTransactionActive = false\n\n await this.setAutoCommit({ status: \"on\" })\n await this.broadcaster.broadcast(\"AfterTransactionRollback\")\n }\n\n /**\n * @description Switches on/off AUTOCOMMIT mode\n * @link https://help.sap.com/docs/HANA_SERVICE_CF/7c78579ce9b14a669c1f3295b0d8ca16/d538d11053bd4f3f847ec5ce817a3d4c.html?locale=en-US\n */\n async setAutoCommit(options: { status: \"on\" | \"off\" }) {\n const connection = await this.connect()\n\n const execute = promisify(connection.exec.bind(connection))\n\n connection.setAutoCommit(options.status === \"on\")\n\n const query = `SET TRANSACTION AUTOCOMMIT DDL ${options.status.toUpperCase()};`\n try {\n await execute(query)\n } catch (error) {\n throw new QueryFailedError(query, [], error)\n }\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) throw new QueryRunnerAlreadyReleasedError()\n\n const release = await this.lock.acquire()\n\n let statement: any\n const result = new QueryResult()\n\n try {\n const databaseConnection = await this.connect()\n\n this.driver.connection.logger.logQuery(query, parameters, this)\n const queryStartTime = +new Date()\n const isInsertQuery = query.substr(0, 11) === \"INSERT INTO\"\n\n statement = databaseConnection.prepare(query)\n\n const raw = await new Promise<any>((ok, fail) => {\n statement.exec(parameters, (err: any, raw: any) =>\n err\n ? fail(new QueryFailedError(query, parameters, err))\n : ok(raw),\n )\n })\n\n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime =\n this.driver.connection.options.maxQueryExecutionTime\n const queryEndTime = +new Date()\n const queryExecutionTime = queryEndTime - queryStartTime\n if (\n maxQueryExecutionTime &&\n queryExecutionTime > maxQueryExecutionTime\n ) {\n this.driver.connection.logger.logQuerySlow(\n queryExecutionTime,\n query,\n parameters,\n this,\n )\n }\n\n if (typeof raw === \"number\") {\n result.affected = raw\n } else if (Array.isArray(raw)) {\n result.records = raw\n }\n\n result.raw = raw\n\n if (isInsertQuery) {\n const lastIdQuery = `SELECT CURRENT_IDENTITY_VALUE() FROM \"SYS\".\"DUMMY\"`\n this.driver.connection.logger.logQuery(lastIdQuery, [], this)\n const identityValueResult = await new Promise<any>(\n (ok, fail) => {\n databaseConnection.exec(\n lastIdQuery,\n (err: any, raw: any) =>\n err\n ? fail(\n new QueryFailedError(\n lastIdQuery,\n [],\n err,\n ),\n )\n : ok(raw),\n )\n },\n )\n\n result.raw = identityValueResult[0][\"CURRENT_IDENTITY_VALUE()\"]\n result.records = identityValueResult\n }\n } catch (e) {\n this.driver.connection.logger.logQueryError(\n e,\n query,\n parameters,\n this,\n )\n throw e\n } finally {\n // Never forget to drop the statement we reserved\n if (statement?.drop) {\n await new Promise<void>((ok) => statement.drop(() => ok()))\n }\n\n // Always release the lock.\n release()\n }\n\n if (useStructuredResult) {\n return result\n } else {\n return result.raw\n }\n }\n\n /**\n * Returns raw data stream.\n */\n async stream(\n query: string,\n parameters?: any[],\n onEnd?: Function,\n onError?: Function,\n ): Promise<ReadStream> {\n throw new TypeORMError(`Stream is not supported by SAP driver.`)\n }\n\n /**\n * Returns all available database names including system databases.\n */\n async getDatabases(): Promise<string[]> {\n const results: ObjectLiteral[] = await this.query(\n `SELECT DATABASE_NAME FROM \"SYS\".\"M_DATABASES\"`,\n )\n return results.map((result) => result[\"DATABASE_NAME\"])\n }\n\n /**\n * Returns all available schema names including system schemas.\n * If database parameter specified, returns schemas of that database.\n */\n async getSchemas(database?: string): Promise<string[]> {\n const query = database\n ? `SELECT * FROM \"${database}\".\"SYS\".\"SCHEMAS\"`\n : `SELECT * FROM \"SYS\".\"SCHEMAS\"`\n const results: ObjectLiteral[] = await this.query(query)\n return results.map((result) => result[\"SCHEMA_NAME\"])\n }\n\n /**\n * Checks if database with the given name exist.\n */\n async hasDatabase(database: string): Promise<boolean> {\n const databases = await this.getDatabases()\n return databases.indexOf(database) !== -1\n }\n\n /**\n * Returns current database.\n */\n async getCurrentDatabase(): Promise<string> {\n const currentDBQuery = await this.query(\n `SELECT \"VALUE\" AS \"db_name\" FROM \"SYS\".\"M_SYSTEM_OVERVIEW\" WHERE \"SECTION\" = 'System' and \"NAME\" = 'Instance ID'`,\n )\n return currentDBQuery[0][\"db_name\"]\n }\n\n /**\n * Checks if schema with the given name exist.\n */\n async hasSchema(schema: string): Promise<boolean> {\n const schemas = await this.getSchemas()\n return schemas.indexOf(schema) !== -1\n }\n\n /**\n * Returns current schema.\n */\n async getCurrentSchema(): Promise<string> {\n const currentSchemaQuery = await this.query(\n `SELECT CURRENT_SCHEMA AS \"schema_name\" FROM \"SYS\".\"DUMMY\"`,\n )\n return currentSchemaQuery[0][\"schema_name\"]\n }\n\n /**\n * Checks if table with the given name exist in the database.\n */\n async hasTable(tableOrName: Table | string): Promise<boolean> {\n const parsedTableName = this.driver.parseTableName(tableOrName)\n\n if (!parsedTableName.schema) {\n parsedTableName.schema = await this.getCurrentSchema()\n }\n\n const sql = `SELECT * FROM \"SYS\".\"TABLES\" WHERE \"SCHEMA_NAME\" = '${parsedTableName.schema}' AND \"TABLE_NAME\" = '${parsedTableName.tableName}'`\n const result = await this.query(sql)\n return result.length ? true : false\n }\n\n /**\n * Checks if column with the given name exist in the given table.\n */\n async hasColumn(\n tableOrName: Table | string,\n columnName: string,\n ): Promise<boolean> {\n const parsedTableName = this.driver.parseTableName(tableOrName)\n\n if (!parsedTableName.schema) {\n parsedTableName.schema = await this.getCurrentSchema()\n }\n\n const sql = `SELECT * FROM \"SYS\".\"TABLE_COLUMNS\" WHERE \"SCHEMA_NAME\" = ${parsedTableName.schema} AND \"TABLE_NAME\" = ${parsedTableName.tableName} AND \"COLUMN_NAME\" = '${columnName}'`\n const result = await this.query(sql)\n return result.length ? true : false\n }\n\n /**\n * Creates a new database.\n */\n async createDatabase(\n database: string,\n ifNotExist?: boolean,\n ): Promise<void> {\n return Promise.resolve()\n }\n\n /**\n * Drops database.\n */\n async dropDatabase(database: string, ifExist?: boolean): Promise<void> {\n return Promise.resolve()\n }\n\n /**\n * Creates a new table schema.\n */\n async createSchema(\n schemaPath: string,\n ifNotExist?: boolean,\n ): Promise<void> {\n const schema =\n schemaPath.indexOf(\".\") === -1\n ? schemaPath\n : schemaPath.split(\".\")[1]\n\n let exist = false\n if (ifNotExist) {\n const result = await this.query(\n `SELECT * FROM \"SYS\".\"SCHEMAS\" WHERE \"SCHEMA_NAME\" = '${schema}'`,\n )\n exist = !!result.length\n }\n if (!ifNotExist || (ifNotExist && !exist)) {\n const up = `CREATE SCHEMA \"${schema}\"`\n const down = `DROP SCHEMA \"${schema}\" CASCADE`\n await this.executeQueries(new Query(up), new Query(down))\n }\n }\n\n /**\n * Drops table schema\n */\n async dropSchema(\n schemaPath: string,\n ifExist?: boolean,\n isCascade?: boolean,\n ): Promise<void> {\n const schema =\n schemaPath.indexOf(\".\") === -1\n ? schemaPath\n : schemaPath.split(\".\")[0]\n let exist = false\n if (ifExist) {\n const result = await this.query(\n `SELECT * FROM \"SYS\".\"SCHEMAS\" WHERE \"SCHEMA_NAME\" = '${schema}'`,\n )\n exist = !!result.length\n }\n if (!ifExist || (ifExist && exist)) {\n const up = `DROP SCHEMA \"${schema}\" ${isCascade ? \"CASCADE\" : \"\"}`\n const down = `CREATE SCHEMA \"${schema}\"`\n await this.executeQueries(new Query(up), new Query(down))\n }\n }\n\n /**\n * Creates a new table.\n */\n async createTable(\n table: Table,\n ifNotExist: boolean = false,\n createForeignKeys: boolean = true,\n createIndices: boolean = true,\n ): Promise<void> {\n if (ifNotExist) {\n const isTableExist = await this.hasTable(table)\n if (isTableExist) return Promise.resolve()\n }\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n\n upQueries.push(this.createTableSql(table, createForeignKeys))\n downQueries.push(this.dropTableSql(table))\n\n // if createForeignKeys is true, we must drop created foreign keys in down query.\n // createTable does not need separate method to create foreign keys, because it create fk's in the same query with table creation.\n if (createForeignKeys)\n table.foreignKeys.forEach((foreignKey) =>\n downQueries.push(this.dropForeignKeySql(table, foreignKey)),\n )\n\n if (createIndices) {\n table.indices.forEach((index) => {\n // new index may be passed without name. In this case we generate index name manually.\n if (!index.name)\n index.name = this.connection.namingStrategy.indexName(\n table,\n index.columnNames,\n index.where,\n )\n upQueries.push(this.createIndexSql(table, index))\n downQueries.push(this.dropIndexSql(table, index))\n })\n }\n\n await this.executeQueries(upQueries, downQueries)\n }\n\n /**\n * Drops the table.\n */\n async dropTable(\n tableOrName: Table | string,\n ifExist?: boolean,\n dropForeignKeys: boolean = true,\n dropIndices: boolean = true,\n ): Promise<void> {\n if (ifExist) {\n const isTableExist = await this.hasTable(tableOrName)\n if (!isTableExist) return Promise.resolve()\n }\n\n // if dropTable called with dropForeignKeys = true, we must create foreign keys in down query.\n const createForeignKeys: boolean = dropForeignKeys\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n\n // It needs because if table does not exist and dropForeignKeys or dropIndices is true, we don't need\n // to perform drop queries for foreign keys and indices.\n\n if (dropIndices) {\n table.indices.forEach((index) => {\n upQueries.push(this.dropIndexSql(table, index))\n downQueries.push(this.createIndexSql(table, index))\n })\n }\n\n // if dropForeignKeys is true, we just drop the table, otherwise we also drop table foreign keys.\n // createTable does not need separate method to create foreign keys, because it create fk's in the same query with table creation.\n if (dropForeignKeys)\n table.foreignKeys.forEach((foreignKey) =>\n upQueries.push(this.dropForeignKeySql(table, foreignKey)),\n )\n\n upQueries.push(this.dropTableSql(table))\n downQueries.push(this.createTableSql(table, createForeignKeys))\n\n await this.executeQueries(upQueries, downQueries)\n }\n\n /**\n * Creates a new view.\n */\n async createView(\n view: View,\n syncWithMetadata: boolean = false,\n ): Promise<void> {\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n upQueries.push(this.createViewSql(view))\n if (syncWithMetadata)\n upQueries.push(await this.insertViewDefinitionSql(view))\n downQueries.push(this.dropViewSql(view))\n if (syncWithMetadata)\n downQueries.push(await this.deleteViewDefinitionSql(view))\n await this.executeQueries(upQueries, downQueries)\n }\n\n /**\n * Drops the view.\n */\n async dropView(target: View | string): Promise<void> {\n const viewName = InstanceChecker.isView(target) ? target.name : target\n const view = await this.getCachedView(viewName)\n\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n upQueries.push(await this.deleteViewDefinitionSql(view))\n upQueries.push(this.dropViewSql(view))\n downQueries.push(await this.insertViewDefinitionSql(view))\n downQueries.push(this.createViewSql(view))\n await this.executeQueries(upQueries, downQueries)\n }\n\n /**\n * Renames a table.\n */\n async renameTable(\n oldTableOrName: Table | string,\n newTableName: string,\n ): Promise<void> {\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n const oldTable = InstanceChecker.isTable(oldTableOrName)\n ? oldTableOrName\n : await this.getCachedTable(oldTableOrName)\n const newTable = oldTable.clone()\n\n const { schema: schemaName, tableName: oldTableName } =\n this.driver.parseTableName(oldTable)\n\n newTable.name = schemaName\n ? `${schemaName}.${newTableName}`\n : newTableName\n\n // rename table\n upQueries.push(\n new Query(\n `RENAME TABLE ${this.escapePath(oldTable)} TO ${this.escapePath(\n newTableName,\n )}`,\n ),\n )\n downQueries.push(\n new Query(\n `RENAME TABLE ${this.escapePath(newTable)} TO ${this.escapePath(\n oldTableName,\n )}`,\n ),\n )\n\n // drop old FK's. Foreign keys must be dropped before the primary keys are dropped\n newTable.foreignKeys.forEach((foreignKey) => {\n upQueries.push(this.dropForeignKeySql(newTable, foreignKey))\n downQueries.push(this.createForeignKeySql(newTable, foreignKey))\n })\n\n // SAP HANA does not allow to drop PK's which is referenced by foreign keys.\n // To avoid this, we must drop all referential foreign keys and recreate them later\n const referencedForeignKeySql = `SELECT * FROM \"SYS\".\"REFERENTIAL_CONSTRAINTS\" WHERE \"REFERENCED_SCHEMA_NAME\" = '${schemaName}' AND \"REFERENCED_TABLE_NAME\" = '${oldTableName}'`\n const dbForeignKeys: ObjectLiteral[] = await this.query(\n referencedForeignKeySql,\n )\n let referencedForeignKeys: TableForeignKey[] = []\n const referencedForeignKeyTableMapping: {\n tableName: string\n fkName: string\n }[] = []\n if (dbForeignKeys.length > 0) {\n referencedForeignKeys = dbForeignKeys.map((dbForeignKey) => {\n const foreignKeys = dbForeignKeys.filter(\n (dbFk) =>\n dbFk[\"CONSTRAINT_NAME\"] ===\n dbForeignKey[\"CONSTRAINT_NAME\"],\n )\n\n referencedForeignKeyTableMapping.push({\n tableName: `${dbForeignKey[\"SCHEMA_NAME\"]}.${dbForeignKey[\"TABLE_NAME\"]}`,\n fkName: dbForeignKey[\"CONSTRAINT_NAME\"],\n })\n return new TableForeignKey({\n name: dbForeignKey[\"CONSTRAINT_NAME\"],\n columnNames: foreignKeys.map((dbFk) => dbFk[\"COLUMN_NAME\"]),\n referencedDatabase: newTable.database,\n referencedSchema: newTable.schema,\n referencedTableName: newTable.name, // we use renamed table name\n referencedColumnNames: foreignKeys.map(\n (dbFk) => dbFk[\"REFERENCED_COLUMN_NAME\"],\n ),\n onDelete:\n dbForeignKey[\"DELETE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"DELETE_RULE\"],\n onUpdate:\n dbForeignKey[\"UPDATE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"UPDATE_RULE\"],\n deferrable: dbForeignKey[\"CHECK_TIME\"].replace(\"_\", \" \"), // \"CHECK_TIME\" is \"INITIALLY_IMMEDIATE\" or \"INITIALLY DEFERRED\"\n })\n })\n\n // drop referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.createForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n }\n\n // rename primary key constraint\n if (newTable.primaryColumns.length > 0) {\n const columnNames = newTable.primaryColumns.map(\n (column) => column.name,\n )\n const columnNamesString = columnNames\n .map((columnName) => `\"${columnName}\"`)\n .join(\", \")\n\n const oldPkName = this.connection.namingStrategy.primaryKeyName(\n oldTable,\n columnNames,\n )\n const newPkName = this.connection.namingStrategy.primaryKeyName(\n newTable,\n columnNames,\n )\n\n // drop old PK\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n newTable,\n )} DROP CONSTRAINT \"${oldPkName}\"`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n newTable,\n )} ADD CONSTRAINT \"${oldPkName}\" PRIMARY KEY (${columnNamesString})`,\n ),\n )\n\n // create new PK\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n newTable,\n )} ADD CONSTRAINT \"${newPkName}\" PRIMARY KEY (${columnNamesString})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n newTable,\n )} DROP CONSTRAINT \"${newPkName}\"`,\n ),\n )\n }\n\n // recreate foreign keys with new constraint names\n newTable.foreignKeys.forEach((foreignKey) => {\n // replace constraint name\n foreignKey.name = this.connection.namingStrategy.foreignKeyName(\n newTable,\n foreignKey.columnNames,\n this.getTablePath(foreignKey),\n foreignKey.referencedColumnNames,\n )\n\n // create new FK's\n upQueries.push(this.createForeignKeySql(newTable, foreignKey))\n downQueries.push(this.dropForeignKeySql(newTable, foreignKey))\n })\n\n // restore referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.createForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n\n // rename index constraints\n newTable.indices.forEach((index) => {\n // build new constraint name\n const newIndexName = this.connection.namingStrategy.indexName(\n newTable,\n index.columnNames,\n index.where,\n )\n\n // drop old index\n upQueries.push(this.dropIndexSql(newTable, index))\n downQueries.push(this.createIndexSql(newTable, index))\n\n // replace constraint name\n index.name = newIndexName\n\n // create new index\n upQueries.push(this.createIndexSql(newTable, index))\n downQueries.push(this.dropIndexSql(newTable, index))\n })\n\n await this.executeQueries(upQueries, downQueries)\n\n // rename old table and replace it in cached tabled;\n oldTable.name = newTable.name\n this.replaceCachedTable(oldTable, newTable)\n }\n\n /**\n * Creates a new column from the column in the table.\n */\n async addColumn(\n tableOrName: Table | string,\n column: TableColumn,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const parsedTableName = this.driver.parseTableName(table)\n\n if (!parsedTableName.schema) {\n parsedTableName.schema = await this.getCurrentSchema()\n }\n\n const clonedTable = table.clone()\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n\n upQueries.push(new Query(this.addColumnSql(table, column)))\n downQueries.push(new Query(this.dropColumnSql(table, column)))\n\n // create or update primary key constraint\n if (column.isPrimary) {\n const primaryColumns = clonedTable.primaryColumns\n // if table already have primary key, me must drop it and recreate again\n if (primaryColumns.length > 0) {\n // SAP HANA does not allow to drop PK's which is referenced by foreign keys.\n // To avoid this, we must drop all referential foreign keys and recreate them later\n const referencedForeignKeySql = `SELECT * FROM \"SYS\".\"REFERENTIAL_CONSTRAINTS\" WHERE \"REFERENCED_SCHEMA_NAME\" = '${parsedTableName.schema}' AND \"REFERENCED_TABLE_NAME\" = '${parsedTableName.tableName}'`\n const dbForeignKeys: ObjectLiteral[] = await this.query(\n referencedForeignKeySql,\n )\n let referencedForeignKeys: TableForeignKey[] = []\n const referencedForeignKeyTableMapping: {\n tableName: string\n fkName: string\n }[] = []\n if (dbForeignKeys.length > 0) {\n referencedForeignKeys = dbForeignKeys.map(\n (dbForeignKey) => {\n const foreignKeys = dbForeignKeys.filter(\n (dbFk) =>\n dbFk[\"CONSTRAINT_NAME\"] ===\n dbForeignKey[\"CONSTRAINT_NAME\"],\n )\n\n referencedForeignKeyTableMapping.push({\n tableName: `${dbForeignKey[\"SCHEMA_NAME\"]}.${dbForeignKey[\"TABLE_NAME\"]}`,\n fkName: dbForeignKey[\"CONSTRAINT_NAME\"],\n })\n return new TableForeignKey({\n name: dbForeignKey[\"CONSTRAINT_NAME\"],\n columnNames: foreignKeys.map(\n (dbFk) => dbFk[\"COLUMN_NAME\"],\n ),\n referencedDatabase: table.database,\n referencedSchema: table.schema,\n referencedTableName: table.name,\n referencedColumnNames: foreignKeys.map(\n (dbFk) => dbFk[\"REFERENCED_COLUMN_NAME\"],\n ),\n onDelete:\n dbForeignKey[\"DELETE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"DELETE_RULE\"],\n onUpdate:\n dbForeignKey[\"UPDATE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"UPDATE_RULE\"],\n deferrable: dbForeignKey[\"CHECK_TIME\"].replace(\n \"_\",\n \" \",\n ),\n })\n },\n )\n\n // drop referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.dropForeignKeySql(\n mapping!.tableName,\n foreignKey,\n ),\n )\n downQueries.push(\n this.createForeignKeySql(\n mapping!.tableName,\n foreignKey,\n ),\n )\n })\n }\n\n const pkName = this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n primaryColumns.map((column) => column.name),\n )\n const columnNames = primaryColumns\n .map((column) => `\"${column.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNames})`,\n ),\n )\n\n // restore referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.createForeignKeySql(\n mapping!.tableName,\n foreignKey,\n ),\n )\n downQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n }\n\n primaryColumns.push(column)\n const pkName = this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n primaryColumns.map((column) => column.name),\n )\n const columnNames = primaryColumns\n .map((column) => `\"${column.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNames})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n }\n\n // create column index\n const columnIndex = clonedTable.indices.find(\n (index) =>\n index.columnNames.length === 1 &&\n index.columnNames[0] === column.name,\n )\n if (columnIndex) {\n upQueries.push(this.createIndexSql(table, columnIndex))\n downQueries.push(this.dropIndexSql(table, columnIndex))\n } else if (column.isUnique) {\n const uniqueIndex = new TableIndex({\n name: this.connection.namingStrategy.indexName(table, [\n column.name,\n ]),\n columnNames: [column.name],\n isUnique: true,\n })\n clonedTable.indices.push(uniqueIndex)\n clonedTable.uniques.push(\n new TableUnique({\n name: uniqueIndex.name,\n columnNames: uniqueIndex.columnNames,\n }),\n )\n upQueries.push(this.createIndexSql(table, uniqueIndex))\n downQueries.push(this.dropIndexSql(table, uniqueIndex))\n }\n\n await this.executeQueries(upQueries, downQueries)\n\n clonedTable.addColumn(column)\n this.replaceCachedTable(table, clonedTable)\n }\n\n /**\n * Creates a new columns from the column in the table.\n */\n async addColumns(\n tableOrName: Table | string,\n columns: TableColumn[],\n ): Promise<void> {\n for (const column of columns) {\n await this.addColumn(tableOrName, column)\n }\n }\n\n /**\n * Renames column in the given table.\n */\n async renameColumn(\n tableOrName: Table | string,\n oldTableColumnOrName: TableColumn | string,\n newTableColumnOrName: TableColumn | string,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const oldColumn = InstanceChecker.isTableColumn(oldTableColumnOrName)\n ? oldTableColumnOrName\n : table.columns.find((c) => c.name === oldTableColumnOrName)\n if (!oldColumn)\n throw new TypeORMError(\n `Column \"${oldTableColumnOrName}\" was not found in the \"${table.name}\" table.`,\n )\n\n let newColumn: TableColumn | undefined = undefined\n if (InstanceChecker.isTableColumn(newTableColumnOrName)) {\n newColumn = newTableColumnOrName\n } else {\n newColumn = oldColumn.clone()\n newColumn.name = newTableColumnOrName\n }\n\n await this.changeColumn(table, oldColumn, newColumn)\n }\n\n /**\n * Changes a column in the table.\n */\n async changeColumn(\n tableOrName: Table | string,\n oldTableColumnOrName: TableColumn | string,\n newColumn: TableColumn,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n let clonedTable = table.clone()\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n\n const oldColumn = InstanceChecker.isTableColumn(oldTableColumnOrName)\n ? oldTableColumnOrName\n : table.columns.find(\n (column) => column.name === oldTableColumnOrName,\n )\n if (!oldColumn)\n throw new TypeORMError(\n `Column \"${oldTableColumnOrName}\" was not found in the \"${table.name}\" table.`,\n )\n\n if (\n (newColumn.isGenerated !== oldColumn.isGenerated &&\n newColumn.generationStrategy !== \"uuid\") ||\n newColumn.type !== oldColumn.type ||\n newColumn.length !== oldColumn.length\n ) {\n // SQL Server does not support changing of IDENTITY column, so we must drop column and recreate it again.\n // Also, we recreate column if column type changed\n await this.dropColumn(table, oldColumn)\n await this.addColumn(table, newColumn)\n\n // update cloned table\n clonedTable = table.clone()\n } else {\n if (newColumn.name !== oldColumn.name) {\n // rename column\n upQueries.push(\n new Query(\n `RENAME COLUMN ${this.escapePath(table)}.\"${\n oldColumn.name\n }\" TO \"${newColumn.name}\"`,\n ),\n )\n downQueries.push(\n new Query(\n `RENAME COLUMN ${this.escapePath(table)}.\"${\n newColumn.name\n }\" TO \"${oldColumn.name}\"`,\n ),\n )\n\n if (oldColumn.isPrimary === true) {\n const primaryColumns = clonedTable.primaryColumns\n\n // build old primary constraint name\n const columnNames = primaryColumns.map(\n (column) => column.name,\n )\n const oldPkName =\n this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n columnNames,\n )\n\n // replace old column name with new column name\n columnNames.splice(columnNames.indexOf(oldColumn.name), 1)\n columnNames.push(newColumn.name)\n const columnNamesString = columnNames\n .map((columnName) => `\"${columnName}\"`)\n .join(\", \")\n\n // drop old PK\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} DROP CONSTRAINT \"${oldPkName}\"`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} ADD CONSTRAINT \"${oldPkName}\" PRIMARY KEY (${columnNamesString})`,\n ),\n )\n\n // build new primary constraint name\n const newPkName =\n this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n columnNames,\n )\n\n // create new PK\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} ADD CONSTRAINT \"${newPkName}\" PRIMARY KEY (${columnNamesString})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} DROP CONSTRAINT \"${newPkName}\"`,\n ),\n )\n }\n\n // rename index constraints\n clonedTable.findColumnIndices(oldColumn).forEach((index) => {\n // build new constraint name\n index.columnNames.splice(\n index.columnNames.indexOf(oldColumn.name),\n 1,\n )\n index.columnNames.push(newColumn.name)\n const newIndexName =\n this.connection.namingStrategy.indexName(\n clonedTable,\n index.columnNames,\n index.where,\n )\n\n // drop old index\n upQueries.push(this.dropIndexSql(clonedTable, index))\n downQueries.push(this.createIndexSql(clonedTable, index))\n\n // replace constraint name\n index.name = newIndexName\n\n // create new index\n upQueries.push(this.createIndexSql(clonedTable, index))\n downQueries.push(this.dropIndexSql(clonedTable, index))\n })\n\n // rename foreign key constraints\n clonedTable\n .findColumnForeignKeys(oldColumn)\n .forEach((foreignKey) => {\n // build new constraint name\n foreignKey.columnNames.splice(\n foreignKey.columnNames.indexOf(oldColumn.name),\n 1,\n )\n foreignKey.columnNames.push(newColumn.name)\n const newForeignKeyName =\n this.connection.namingStrategy.foreignKeyName(\n clonedTable,\n foreignKey.columnNames,\n this.getTablePath(foreignKey),\n foreignKey.referencedColumnNames,\n )\n\n upQueries.push(\n this.dropForeignKeySql(clonedTable, foreignKey),\n )\n downQueries.push(\n this.createForeignKeySql(clonedTable, foreignKey),\n )\n\n // replace constraint name\n foreignKey.name = newForeignKeyName\n\n // create new FK's\n upQueries.push(\n this.createForeignKeySql(clonedTable, foreignKey),\n )\n downQueries.push(\n this.dropForeignKeySql(clonedTable, foreignKey),\n )\n })\n\n // rename check constraints\n clonedTable.findColumnChecks(oldColumn).forEach((check) => {\n // build new constraint name\n check.columnNames!.splice(\n check.columnNames!.indexOf(oldColumn.name),\n 1,\n )\n check.columnNames!.push(newColumn.name)\n const newCheckName =\n this.connection.namingStrategy.checkConstraintName(\n clonedTable,\n check.expression!,\n )\n\n upQueries.push(\n this.dropCheckConstraintSql(clonedTable, check),\n )\n downQueries.push(\n this.createCheckConstraintSql(clonedTable, check),\n )\n\n // replace constraint name\n check.name = newCheckName\n\n upQueries.push(\n this.createCheckConstraintSql(clonedTable, check),\n )\n downQueries.push(\n this.dropCheckConstraintSql(clonedTable, check),\n )\n })\n\n // rename old column in the Table object\n const oldTableColumn = clonedTable.columns.find(\n (column) => column.name === oldColumn.name,\n )\n clonedTable.columns[\n clonedTable.columns.indexOf(oldTableColumn!)\n ].name = newColumn.name\n oldColumn.name = newColumn.name\n }\n\n if (this.isColumnChanged(oldColumn, newColumn)) {\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ALTER (${this.buildCreateColumnSql(newColumn)})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ALTER (${this.buildCreateColumnSql(oldColumn)})`,\n ),\n )\n }\n\n if (newColumn.isPrimary !== oldColumn.isPrimary) {\n const primaryColumns = clonedTable.primaryColumns\n\n // if primary column state changed, we must always drop existed constraint.\n if (primaryColumns.length > 0) {\n const pkName =\n this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n primaryColumns.map((column) => column.name),\n )\n const columnNames = primaryColumns\n .map((column) => `\"${column.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNames})`,\n ),\n )\n }\n\n if (newColumn.isPrimary === true) {\n primaryColumns.push(newColumn)\n // update column in table\n const column = clonedTable.columns.find(\n (column) => column.name === newColumn.name,\n )\n column!.isPrimary = true\n const pkName =\n this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n primaryColumns.map((column) => column.name),\n )\n const columnNames = primaryColumns\n .map((column) => `\"${column.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNames})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n } else {\n const primaryColumn = primaryColumns.find(\n (c) => c.name === newColumn.name,\n )\n primaryColumns.splice(\n primaryColumns.indexOf(primaryColumn!),\n 1,\n )\n\n // update column in table\n const column = clonedTable.columns.find(\n (column) => column.name === newColumn.name,\n )\n column!.isPrimary = false\n\n // if we have another primary keys, we must recreate constraint.\n if (primaryColumns.length > 0) {\n const pkName =\n this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n primaryColumns.map((column) => column.name),\n )\n const columnNames = primaryColumns\n .map((column) => `\"${column.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNames})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n }\n }\n }\n\n if (newColumn.isUnique !== oldColumn.isUnique) {\n if (newColumn.isUnique === true) {\n const uniqueIndex = new TableIndex({\n name: this.connection.namingStrategy.indexName(table, [\n newColumn.name,\n ]),\n columnNames: [newColumn.name],\n isUnique: true,\n })\n clonedTable.indices.push(uniqueIndex)\n clonedTable.uniques.push(\n new TableUnique({\n name: uniqueIndex.name,\n columnNames: uniqueIndex.columnNames,\n }),\n )\n upQueries.push(this.createIndexSql(table, uniqueIndex))\n downQueries.push(this.dropIndexSql(table, uniqueIndex))\n } else {\n const uniqueIndex = clonedTable.indices.find((index) => {\n return (\n index.columnNames.length === 1 &&\n index.isUnique === true &&\n !!index.columnNames.find(\n (columnName) => columnName === newColumn.name,\n )\n )\n })\n clonedTable.indices.splice(\n clonedTable.indices.indexOf(uniqueIndex!),\n 1,\n )\n\n const tableUnique = clonedTable.uniques.find(\n (unique) => unique.name === uniqueIndex!.name,\n )\n clonedTable.uniques.splice(\n clonedTable.uniques.indexOf(tableUnique!),\n 1,\n )\n\n upQueries.push(this.dropIndexSql(table, uniqueIndex!))\n downQueries.push(this.createIndexSql(table, uniqueIndex!))\n }\n }\n\n if (newColumn.default !== oldColumn.default) {\n if (\n newColumn.default !== null &&\n newColumn.default !== undefined\n ) {\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(table)} ALTER (\"${\n newColumn.name\n }\" ${this.connection.driver.createFullType(\n newColumn,\n )} DEFAULT ${newColumn.default})`,\n ),\n )\n\n if (\n oldColumn.default !== null &&\n oldColumn.default !== undefined\n ) {\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ALTER (\"${\n oldColumn.name\n }\" ${this.connection.driver.createFullType(\n oldColumn,\n )} DEFAULT ${oldColumn.default})`,\n ),\n )\n } else {\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ALTER (\"${\n oldColumn.name\n }\" ${this.connection.driver.createFullType(\n oldColumn,\n )} DEFAULT NULL)`,\n ),\n )\n }\n } else if (\n oldColumn.default !== null &&\n oldColumn.default !== undefined\n ) {\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(table)} ALTER (\"${\n newColumn.name\n }\" ${this.connection.driver.createFullType(\n newColumn,\n )} DEFAULT NULL)`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(table)} ALTER (\"${\n oldColumn.name\n }\" ${this.connection.driver.createFullType(\n oldColumn,\n )} DEFAULT ${oldColumn.default})`,\n ),\n )\n }\n }\n\n await this.executeQueries(upQueries, downQueries)\n this.replaceCachedTable(table, clonedTable)\n }\n }\n\n /**\n * Changes a column in the table.\n */\n async changeColumns(\n tableOrName: Table | string,\n changedColumns: { newColumn: TableColumn; oldColumn: TableColumn }[],\n ): Promise<void> {\n for (const { oldColumn, newColumn } of changedColumns) {\n await this.changeColumn(tableOrName, oldColumn, newColumn)\n }\n }\n\n /**\n * Drops column in the table.\n */\n async dropColumn(\n tableOrName: Table | string,\n columnOrName: TableColumn | string,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const parsedTableName = this.driver.parseTableName(table)\n\n if (!parsedTableName.schema) {\n parsedTableName.schema = await this.getCurrentSchema()\n }\n\n const column = InstanceChecker.isTableColumn(columnOrName)\n ? columnOrName\n : table.findColumnByName(columnOrName)\n if (!column)\n throw new TypeORMError(\n `Column \"${columnOrName}\" was not found in table \"${table.name}\"`,\n )\n\n const clonedTable = table.clone()\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n\n // drop primary key constraint\n if (column.isPrimary) {\n // SAP HANA does not allow to drop PK's which is referenced by foreign keys.\n // To avoid this, we must drop all referential foreign keys and recreate them later\n const referencedForeignKeySql = `SELECT * FROM \"SYS\".\"REFERENTIAL_CONSTRAINTS\" WHERE \"REFERENCED_SCHEMA_NAME\" = '${parsedTableName.schema}' AND \"REFERENCED_TABLE_NAME\" = '${parsedTableName.tableName}'`\n const dbForeignKeys: ObjectLiteral[] = await this.query(\n referencedForeignKeySql,\n )\n let referencedForeignKeys: TableForeignKey[] = []\n const referencedForeignKeyTableMapping: {\n tableName: string\n fkName: string\n }[] = []\n if (dbForeignKeys.length > 0) {\n referencedForeignKeys = dbForeignKeys.map((dbForeignKey) => {\n const foreignKeys = dbForeignKeys.filter(\n (dbFk) =>\n dbFk[\"CONSTRAINT_NAME\"] ===\n dbForeignKey[\"CONSTRAINT_NAME\"],\n )\n\n referencedForeignKeyTableMapping.push({\n tableName: `${dbForeignKey[\"SCHEMA_NAME\"]}.${dbForeignKey[\"TABLE_NAME\"]}`,\n fkName: dbForeignKey[\"CONSTRAINT_NAME\"],\n })\n return new TableForeignKey({\n name: dbForeignKey[\"CONSTRAINT_NAME\"],\n columnNames: foreignKeys.map(\n (dbFk) => dbFk[\"COLUMN_NAME\"],\n ),\n referencedDatabase: table.database,\n referencedSchema: table.schema,\n referencedTableName: table.name,\n referencedColumnNames: foreignKeys.map(\n (dbFk) => dbFk[\"REFERENCED_COLUMN_NAME\"],\n ),\n onDelete:\n dbForeignKey[\"DELETE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"DELETE_RULE\"],\n onUpdate:\n dbForeignKey[\"UPDATE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"UPDATE_RULE\"],\n deferrable: dbForeignKey[\"CHECK_TIME\"].replace(\n \"_\",\n \" \",\n ),\n })\n })\n\n // drop referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.createForeignKeySql(\n mapping!.tableName,\n foreignKey,\n ),\n )\n })\n }\n\n const pkName = this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n clonedTable.primaryColumns.map((column) => column.name),\n )\n const columnNames = clonedTable.primaryColumns\n .map((primaryColumn) => `\"${primaryColumn.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNames})`,\n ),\n )\n\n // update column in table\n const tableColumn = clonedTable.findColumnByName(column.name)\n tableColumn!.isPrimary = false\n\n // if primary key have multiple columns, we must recreate it without dropped column\n if (clonedTable.primaryColumns.length > 0) {\n const pkName = this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n clonedTable.primaryColumns.map((column) => column.name),\n )\n const columnNames = clonedTable.primaryColumns\n .map((primaryColumn) => `\"${primaryColumn.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNames})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n }\n\n // restore referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.createForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n }\n\n // drop column index\n const columnIndex = clonedTable.indices.find(\n (index) =>\n index.columnNames.length === 1 &&\n index.columnNames[0] === column.name,\n )\n if (columnIndex) {\n clonedTable.indices.splice(\n clonedTable.indices.indexOf(columnIndex),\n 1,\n )\n upQueries.push(this.dropIndexSql(table, columnIndex))\n downQueries.push(this.createIndexSql(table, columnIndex))\n } else if (column.isUnique) {\n // we splice constraints both from table uniques and indices.\n const uniqueName =\n this.connection.namingStrategy.uniqueConstraintName(table, [\n column.name,\n ])\n const foundUnique = clonedTable.uniques.find(\n (unique) => unique.name === uniqueName,\n )\n if (foundUnique) {\n clonedTable.uniques.splice(\n clonedTable.uniques.indexOf(foundUnique),\n 1,\n )\n upQueries.push(this.dropIndexSql(table, uniqueName))\n downQueries.push(\n new Query(\n `CREATE UNIQUE INDEX \"${uniqueName}\" ON ${this.escapePath(\n table,\n )} (\"${column.name}\")`,\n ),\n )\n }\n\n const indexName = this.connection.namingStrategy.indexName(table, [\n column.name,\n ])\n const foundIndex = clonedTable.indices.find(\n (index) => index.name === indexName,\n )\n if (foundIndex) {\n clonedTable.indices.splice(\n clonedTable.indices.indexOf(foundIndex),\n 1,\n )\n upQueries.push(this.dropIndexSql(table, indexName))\n downQueries.push(\n new Query(\n `CREATE UNIQUE INDEX \"${indexName}\" ON ${this.escapePath(\n table,\n )} (\"${column.name}\")`,\n ),\n )\n }\n }\n\n // drop column check\n const columnCheck = clonedTable.checks.find(\n (check) =>\n !!check.columnNames &&\n check.columnNames.length === 1 &&\n check.columnNames[0] === column.name,\n )\n if (columnCheck) {\n clonedTable.checks.splice(\n clonedTable.checks.indexOf(columnCheck),\n 1,\n )\n upQueries.push(this.dropCheckConstraintSql(table, columnCheck))\n downQueries.push(this.createCheckConstraintSql(table, columnCheck))\n }\n\n upQueries.push(new Query(this.dropColumnSql(table, column)))\n downQueries.push(new Query(this.addColumnSql(table, column)))\n\n await this.executeQueries(upQueries, downQueries)\n\n clonedTable.removeColumn(column)\n this.replaceCachedTable(table, clonedTable)\n }\n\n /**\n * Drops the columns in the table.\n */\n async dropColumns(\n tableOrName: Table | string,\n columns: TableColumn[] | string[],\n ): Promise<void> {\n for (const column of columns) {\n await this.dropColumn(tableOrName, column)\n }\n }\n\n /**\n * Creates a new primary key.\n */\n async createPrimaryKey(\n tableOrName: Table | string,\n columnNames: string[],\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const clonedTable = table.clone()\n\n const up = this.createPrimaryKeySql(table, columnNames)\n\n // mark columns as primary, because dropPrimaryKeySql build constraint name from table primary column names.\n clonedTable.columns.forEach((column) => {\n if (columnNames.find((columnName) => columnName === column.name))\n column.isPrimary = true\n })\n const down = this.dropPrimaryKeySql(clonedTable)\n\n await this.executeQueries(up, down)\n this.replaceCachedTable(table, clonedTable)\n }\n\n /**\n * Updates composite primary keys.\n */\n async updatePrimaryKeys(\n tableOrName: Table | string,\n columns: TableColumn[],\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const parsedTableName = this.driver.parseTableName(table)\n\n if (!parsedTableName.schema) {\n parsedTableName.schema = await this.getCurrentSchema()\n }\n\n const clonedTable = table.clone()\n const columnNames = columns.map((column) => column.name)\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n\n // SAP HANA does not allow to drop PK's which is referenced by foreign keys.\n // To avoid this, we must drop all referential foreign keys and recreate them later\n const referencedForeignKeySql = `SELECT * FROM \"SYS\".\"REFERENTIAL_CONSTRAINTS\" WHERE \"REFERENCED_SCHEMA_NAME\" = '${parsedTableName.schema}' AND \"REFERENCED_TABLE_NAME\" = '${parsedTableName.tableName}'`\n const dbForeignKeys: ObjectLiteral[] = await this.query(\n referencedForeignKeySql,\n )\n let referencedForeignKeys: TableForeignKey[] = []\n const referencedForeignKeyTableMapping: {\n tableName: string\n fkName: string\n }[] = []\n if (dbForeignKeys.length > 0) {\n referencedForeignKeys = dbForeignKeys.map((dbForeignKey) => {\n const foreignKeys = dbForeignKeys.filter(\n (dbFk) =>\n dbFk[\"CONSTRAINT_NAME\"] ===\n dbForeignKey[\"CONSTRAINT_NAME\"],\n )\n\n referencedForeignKeyTableMapping.push({\n tableName: `${dbForeignKey[\"SCHEMA_NAME\"]}.${dbForeignKey[\"TABLE_NAME\"]}`,\n fkName: dbForeignKey[\"CONSTRAINT_NAME\"],\n })\n return new TableForeignKey({\n name: dbForeignKey[\"CONSTRAINT_NAME\"],\n columnNames: foreignKeys.map((dbFk) => dbFk[\"COLUMN_NAME\"]),\n referencedDatabase: table.database,\n referencedSchema: table.schema,\n referencedTableName: table.name,\n referencedColumnNames: foreignKeys.map(\n (dbFk) => dbFk[\"REFERENCED_COLUMN_NAME\"],\n ),\n onDelete:\n dbForeignKey[\"DELETE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"DELETE_RULE\"],\n onUpdate:\n dbForeignKey[\"UPDATE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"UPDATE_RULE\"],\n deferrable: dbForeignKey[\"CHECK_TIME\"].replace(\"_\", \" \"),\n })\n })\n\n // drop referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.createForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n }\n\n // if table already have primary columns, we must drop them.\n const primaryColumns = clonedTable.primaryColumns\n if (primaryColumns.length > 0) {\n const pkName = this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n primaryColumns.map((column) => column.name),\n )\n const columnNamesString = primaryColumns\n .map((column) => `\"${column.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNamesString})`,\n ),\n )\n }\n\n // update columns in table.\n clonedTable.columns\n .filter((column) => columnNames.indexOf(column.name) !== -1)\n .forEach((column) => (column.isPrimary = true))\n\n const pkName = this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n columnNames,\n )\n const columnNamesString = columnNames\n .map((columnName) => `\"${columnName}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNamesString})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n\n // restore referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.createForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n\n await this.executeQueries(upQueries, downQueries)\n this.replaceCachedTable(table, clonedTable)\n }\n\n /**\n * Drops a primary key.\n */\n async dropPrimaryKey(tableOrName: Table | string): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const parsedTableName = this.driver.parseTableName(table)\n\n if (!parsedTableName.schema) {\n parsedTableName.schema = await this.getCurrentSchema()\n }\n\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n\n // SAP HANA does not allow to drop PK's which is referenced by foreign keys.\n // To avoid this, we must drop all referential foreign keys and recreate them later\n const referencedForeignKeySql = `SELECT * FROM \"SYS\".\"REFERENTIAL_CONSTRAINTS\" WHERE \"REFERENCED_SCHEMA_NAME\" = '${parsedTableName.schema}' AND \"REFERENCED_TABLE_NAME\" = '${parsedTableName.tableName}'`\n const dbForeignKeys: ObjectLiteral[] = await this.query(\n referencedForeignKeySql,\n )\n let referencedForeignKeys: TableForeignKey[] = []\n const referencedForeignKeyTableMapping: {\n tableName: string\n fkName: string\n }[] = []\n if (dbForeignKeys.length > 0) {\n referencedForeignKeys = dbForeignKeys.map((dbForeignKey) => {\n const foreignKeys = dbForeignKeys.filter(\n (dbFk) =>\n dbFk[\"CONSTRAINT_NAME\"] ===\n dbForeignKey[\"CONSTRAINT_NAME\"],\n )\n\n referencedForeignKeyTableMapping.push({\n tableName: `${dbForeignKey[\"SCHEMA_NAME\"]}.${dbForeignKey[\"TABLE_NAME\"]}`,\n fkName: dbForeignKey[\"CONSTRAINT_NAME\"],\n })\n return new TableForeignKey({\n name: dbForeignKey[\"CONSTRAINT_NAME\"],\n columnNames: foreignKeys.map((dbFk) => dbFk[\"COLUMN_NAME\"]),\n referencedDatabase: table.database,\n referencedSchema: table.schema,\n referencedTableName: table.name,\n referencedColumnNames: foreignKeys.map(\n (dbFk) => dbFk[\"REFERENCED_COLUMN_NAME\"],\n ),\n onDelete:\n dbForeignKey[\"DELETE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"DELETE_RULE\"],\n onUpdate:\n dbForeignKey[\"UPDATE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"UPDATE_RULE\"],\n deferrable: dbForeignKey[\"CHECK_TIME\"].replace(\"_\", \" \"),\n })\n })\n\n // drop referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.createForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n }\n\n upQueries.push(this.dropPrimaryKeySql(table))\n downQueries.push(\n this.createPrimaryKeySql(\n table,\n table.primaryColumns.map((column) => column.name),\n ),\n )\n\n // restore referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.createForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n\n await this.executeQueries(upQueries, downQueries)\n table.primaryColumns.forEach((column) => {\n column.isPrimary = false\n })\n }\n\n /**\n * Creates a new unique constraint.\n */\n async createUniqueConstraint(\n tableOrName: Table | string,\n uniqueConstraint: TableUnique,\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support unique constraints. Use unique index instead.`,\n )\n }\n\n /**\n * Creates a new unique constraints.\n */\n async createUniqueConstraints(\n tableOrName: Table | string,\n uniqueConstraints: TableUnique[],\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support unique constraints. Use unique index instead.`,\n )\n }\n\n /**\n * Drops unique constraint.\n */\n async dropUniqueConstraint(\n tableOrName: Table | string,\n uniqueOrName: TableUnique | string,\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support unique constraints. Use unique index instead.`,\n )\n }\n\n /**\n * Drops an unique constraints.\n */\n async dropUniqueConstraints(\n tableOrName: Table | string,\n uniqueConstraints: TableUnique[],\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support unique constraints. Use unique index instead.`,\n )\n }\n\n /**\n * Creates a new check constraint.\n */\n async createCheckConstraint(\n tableOrName: Table | string,\n checkConstraint: TableCheck,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n\n // new unique constraint may be passed without name. In this case we generate unique name manually.\n if (!checkConstraint.name)\n checkConstraint.name =\n this.connection.namingStrategy.checkConstraintName(\n table,\n checkConstraint.expression!,\n )\n\n const up = this.createCheckConstraintSql(table, checkConstraint)\n const down = this.dropCheckConstraintSql(table, checkConstraint)\n await this.executeQueries(up, down)\n table.addCheckConstraint(checkConstraint)\n }\n\n /**\n * Creates a new check constraints.\n */\n async createCheckConstraints(\n tableOrName: Table | string,\n checkConstraints: TableCheck[],\n ): Promise<void> {\n const promises = checkConstraints.map((checkConstraint) =>\n this.createCheckConstraint(tableOrName, checkConstraint),\n )\n await Promise.all(promises)\n }\n\n /**\n * Drops check constraint.\n */\n async dropCheckConstraint(\n tableOrName: Table | string,\n checkOrName: TableCheck | string,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const checkConstraint = InstanceChecker.isTableCheck(checkOrName)\n ? checkOrName\n : table.checks.find((c) => c.name === checkOrName)\n if (!checkConstraint)\n throw new TypeORMError(\n `Supplied check constraint was not found in table ${table.name}`,\n )\n\n const up = this.dropCheckConstraintSql(table, checkConstraint)\n const down = this.createCheckConstraintSql(table, checkConstraint)\n await this.executeQueries(up, down)\n table.removeCheckConstraint(checkConstraint)\n }\n\n /**\n * Drops check constraints.\n */\n async dropCheckConstraints(\n tableOrName: Table | string,\n checkConstraints: TableCheck[],\n ): Promise<void> {\n const promises = checkConstraints.map((checkConstraint) =>\n this.dropCheckConstraint(tableOrName, checkConstraint),\n )\n await Promise.all(promises)\n }\n\n /**\n * Creates a new exclusion constraint.\n */\n async createExclusionConstraint(\n tableOrName: Table | string,\n exclusionConstraint: TableExclusion,\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support exclusion constraints.`,\n )\n }\n\n /**\n * Creates a new exclusion constraints.\n */\n async createExclusionConstraints(\n tableOrName: Table | string,\n exclusionConstraints: TableExclusion[],\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support exclusion constraints.`,\n )\n }\n\n /**\n * Drops exclusion constraint.\n */\n async dropExclusionConstraint(\n tableOrName: Table | string,\n exclusionOrName: TableExclusion | string,\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support exclusion constraints.`,\n )\n }\n\n /**\n * Drops exclusion constraints.\n */\n async dropExclusionConstraints(\n tableOrName: Table | string,\n exclusionConstraints: TableExclusion[],\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support exclusion constraints.`,\n )\n }\n\n /**\n * Creates a new foreign key.\n */\n async createForeignKey(\n tableOrName: Table | string,\n foreignKey: TableForeignKey,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n\n // new FK may be passed without name. In this case we generate FK name manually.\n if (!foreignKey.name)\n foreignKey.name = this.connection.namingStrategy.foreignKeyName(\n table,\n foreignKey.columnNames,\n this.getTablePath(foreignKey),\n foreignKey.referencedColumnNames,\n )\n\n const up = this.createForeignKeySql(table, foreignKey)\n const down = this.dropForeignKeySql(table, foreignKey)\n await this.executeQueries(up, down)\n table.addForeignKey(foreignKey)\n }\n\n /**\n * Creates a new foreign keys.\n */\n async createForeignKeys(\n tableOrName: Table | string,\n foreignKeys: TableForeignKey[],\n ): Promise<void> {\n const promises = foreignKeys.map((foreignKey) =>\n this.createForeignKey(tableOrName, foreignKey),\n )\n await Promise.all(promises)\n }\n\n /**\n * Drops a foreign key from the table.\n */\n async dropForeignKey(\n tableOrName: Table | string,\n foreignKeyOrName: TableForeignKey | string,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const foreignKey = InstanceChecker.isTableForeignKey(foreignKeyOrName)\n ? foreignKeyOrName\n : table.foreignKeys.find((fk) => fk.name === foreignKeyOrName)\n if (!foreignKey)\n throw new TypeORMError(\n `Supplied foreign key was not found in table ${table.name}`,\n )\n\n const up = this.dropForeignKeySql(table, foreignKey)\n const down = this.createForeignKeySql(table, foreignKey)\n await this.executeQueries(up, down)\n table.removeForeignKey(foreignKey)\n }\n\n /**\n * Drops a foreign keys from the table.\n */\n async dropForeignKeys(\n tableOrName: Table | string,\n foreignKeys: TableForeignKey[],\n ): Promise<void> {\n const promises = foreignKeys.map((foreignKey) =>\n this.dropForeignKey(tableOrName, foreignKey),\n )\n await Promise.all(promises)\n }\n\n /**\n * Creates a new index.\n */\n async createIndex(\n tableOrName: Table | string,\n index: TableIndex,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n\n // new index may be passed without name. In this case we generate index name manually.\n if (!index.name) index.name = this.generateIndexName(table, index)\n\n const up = this.createIndexSql(table, index)\n const down = this.dropIndexSql(table, index)\n await this.executeQueries(up, down)\n table.addIndex(index)\n }\n\n /**\n * Creates a new indices\n */\n async createIndices(\n tableOrName: Table | string,\n indices: TableIndex[],\n ): Promise<void> {\n const promises = indices.map((index) =>\n this.createIndex(tableOrName, index),\n )\n await Promise.all(promises)\n }\n\n /**\n * Drops an index.\n */\n async dropIndex(\n tableOrName: Table | string,\n indexOrName: TableIndex | string,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const index = InstanceChecker.isTableIndex(indexOrName)\n ? indexOrName\n : table.indices.find((i) => i.name === indexOrName)\n if (!index)\n throw new TypeORMError(\n `Supplied index ${indexOrName} was not found in table ${table.name}`,\n )\n\n // old index may be passed without name. In this case we generate index name manually.\n if (!index.name) index.name = this.generateIndexName(table, index)\n\n const up = this.dropIndexSql(table, index)\n const down = this.createIndexSql(table, index)\n await this.executeQueries(up, down)\n table.removeIndex(index)\n }\n\n /**\n * Drops an indices from the table.\n */\n async dropIndices(\n tableOrName: Table | string,\n indices: TableIndex[],\n ): Promise<void> {\n const promises = indices.map((index) =>\n this.dropIndex(tableOrName, index),\n )\n await Promise.all(promises)\n }\n\n /**\n * Clears all table contents.\n * Note: this operation uses SQL's TRUNCATE query which cannot be reverted in transactions.\n */\n async clearTable(tablePath: string): Promise<void> {\n await this.query(`TRUNCATE TABLE ${this.escapePath(tablePath)}`)\n }\n\n /**\n * Removes all tables from the currently connected database.\n */\n async clearDatabase(): Promise<void> {\n const schemas: string[] = []\n this.connection.entityMetadatas\n .filter((metadata) => metadata.schema)\n .forEach((metadata) => {\n const isSchemaExist = !!schemas.find(\n (schema) => schema === metadata.schema,\n )\n if (!isSchemaExist) schemas.push(metadata.schema!)\n })\n\n schemas.push(this.driver.options.schema || \"current_schema\")\n const schemaNamesString = schemas\n .map((name) => {\n return name === \"current_schema\" ? name : \"'\" + name + \"'\"\n })\n .join(\", \")\n\n const isAnotherTransactionActive = this.isTransactionActive\n if (!isAnotherTransactionActive) await this.startTransaction()\n try {\n // const selectViewDropsQuery = `SELECT 'DROP VIEW IF EXISTS \"' || schemaname || '\".\"' || viewname || '\" CASCADE;' as \"query\" ` +\n // `FROM \"pg_views\" WHERE \"schemaname\" IN (${schemaNamesString}) AND \"viewname\" NOT IN ('geography_columns', 'geometry_columns', 'raster_columns', 'raster_overviews')`;\n // const dropViewQueries: ObjectLiteral[] = await this.query(selectViewDropsQuery);\n // await Promise.all(dropViewQueries.map(q => this.query(q[\"query\"])));\n\n // ignore spatial_ref_sys; it's a special table supporting PostGIS\n const selectTableDropsQuery = `SELECT 'DROP TABLE \"' || schema_name || '\".\"' || table_name || '\" CASCADE;' as \"query\" FROM \"SYS\".\"TABLES\" WHERE \"SCHEMA_NAME\" IN (${schemaNamesString}) AND \"TABLE_NAME\" NOT IN ('SYS_AFL_GENERATOR_PARAMETERS') AND \"IS_COLUMN_TABLE\" = 'TRUE'`\n const dropTableQueries: ObjectLiteral[] = await this.query(\n selectTableDropsQuery,\n )\n await Promise.all(\n dropTableQueries.map((q) => this.query(q[\"query\"])),\n )\n\n if (!isAnotherTransactionActive) await this.commitTransaction()\n } catch (error) {\n try {\n // we throw original error even if rollback thrown an error\n if (!isAnotherTransactionActive)\n await this.rollbackTransaction()\n } catch (rollbackError) {}\n throw error\n }\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n protected async loadViews(viewNames?: string[]): Promise<View[]> {\n const hasTable = await this.hasTable(this.getTypeormMetadataTableName())\n if (!hasTable) {\n return []\n }\n\n if (!viewNames) {\n viewNames = []\n }\n\n const currentDatabase = await this.getCurrentDatabase()\n const currentSchema = await this.getCurrentSchema()\n\n const viewsCondition = viewNames\n .map((viewName) => {\n let { schema, tableName: name } =\n this.driver.parseTableName(viewName)\n\n if (!schema) {\n schema = currentSchema\n }\n\n return `(\"t\".\"schema\" = '${schema}' AND \"t\".\"name\" = '${name}')`\n })\n .join(\" OR \")\n\n const query = `SELECT \"t\".* FROM ${this.escapePath(\n this.getTypeormMetadataTableName(),\n )} \"t\" WHERE \"t\".\"type\" = '${MetadataTableType.VIEW}' ${\n viewsCondition ? `AND (${viewsCondition})` : \"\"\n }`\n const dbViews = await this.query(query)\n return dbViews.map((dbView: any) => {\n const view = new View()\n const schema =\n dbView[\"schema\"] === currentSchema &&\n !this.driver.options.schema\n ? undefined\n : dbView[\"schema\"]\n view.database = currentDatabase\n view.schema = dbView[\"schema\"]\n view.name = this.driver.buildTableName(dbView[\"name\"], schema)\n view.expression = dbView[\"value\"]\n return view\n })\n }\n\n /**\n * Loads all tables (with given names) from the database and creates a Table from them.\n */\n protected async loadTables(tableNames?: string[]): Promise<Table[]> {\n if (tableNames && tableNames.length === 0) {\n return []\n }\n\n const currentSchema = await this.getCurrentSchema()\n const currentDatabase = await this.getCurrentDatabase()\n\n const dbTables: { SCHEMA_NAME: string; TABLE_NAME: string }[] = []\n\n if (!tableNames) {\n const tablesSql = `SELECT \"SCHEMA_NAME\", \"TABLE_NAME\" FROM \"SYS\".\"TABLES\"`\n\n dbTables.push(...(await this.query(tablesSql)))\n } else {\n const tablesCondition = tableNames\n .map((tableName) => {\n let [schema, name] = tableName.split(\".\")\n if (!name) {\n name = schema\n schema = this.driver.options.schema || currentSchema\n }\n return `(\"SCHEMA_NAME\" = '${schema}' AND \"TABLE_NAME\" = '${name}')`\n })\n .join(\" OR \")\n\n const tablesSql =\n `SELECT \"SCHEMA_NAME\", \"TABLE_NAME\" FROM \"SYS\".\"TABLES\" WHERE ` +\n tablesCondition\n\n dbTables.push(...(await this.query(tablesSql)))\n }\n\n // if tables were not found in the db, no need to proceed\n if (dbTables.length === 0) return []\n\n const columnsCondition = dbTables\n .map(({ SCHEMA_NAME, TABLE_NAME }) => {\n return `(\"SCHEMA_NAME\" = '${SCHEMA_NAME}' AND \"TABLE_NAME\" = '${TABLE_NAME}')`\n })\n .join(\" OR \")\n const columnsSql =\n `SELECT * FROM \"SYS\".\"TABLE_COLUMNS\" WHERE ` +\n columnsCondition +\n ` ORDER BY \"POSITION\"`\n\n const constraintsCondition = dbTables\n .map(({ SCHEMA_NAME, TABLE_NAME }) => {\n return `(\"SCHEMA_NAME\" = '${SCHEMA_NAME}' AND \"TABLE_NAME\" = '${TABLE_NAME}')`\n })\n .join(\" OR \")\n const constraintsSql = `SELECT * FROM \"SYS\".\"CONSTRAINTS\" WHERE (${constraintsCondition}) ORDER BY \"POSITION\"`\n\n const indicesCondition = dbTables\n .map(({ SCHEMA_NAME, TABLE_NAME }) => {\n return `(\"I\".\"SCHEMA_NAME\" = '${SCHEMA_NAME}' AND \"I\".\"TABLE_NAME\" = '${TABLE_NAME}')`\n })\n .join(\" OR \")\n // excluding primary key and autogenerated fulltext indices\n const indicesSql =\n `SELECT \"I\".\"INDEX_TYPE\", \"I\".\"SCHEMA_NAME\", \"I\".\"TABLE_NAME\", \"I\".\"INDEX_NAME\", \"IC\".\"COLUMN_NAME\", \"I\".\"CONSTRAINT\" ` +\n `FROM \"SYS\".\"INDEXES\" \"I\" INNER JOIN \"SYS\".\"INDEX_COLUMNS\" \"IC\" ON \"IC\".\"INDEX_OID\" = \"I\".\"INDEX_OID\" ` +\n `WHERE (${indicesCondition}) AND (\"I\".\"CONSTRAINT\" IS NULL OR \"I\".\"CONSTRAINT\" != 'PRIMARY KEY') AND \"I\".\"INDEX_NAME\" NOT LIKE '%_SYS_FULLTEXT_%' ORDER BY \"IC\".\"POSITION\"`\n\n const foreignKeysCondition = dbTables\n .map(({ SCHEMA_NAME, TABLE_NAME }) => {\n return `(\"SCHEMA_NAME\" = '${SCHEMA_NAME}' AND \"TABLE_NAME\" = '${TABLE_NAME}')`\n })\n .join(\" OR \")\n const foreignKeysSql = `SELECT * FROM \"SYS\".\"REFERENTIAL_CONSTRAINTS\" WHERE (${foreignKeysCondition}) ORDER BY \"POSITION\"`\n const [\n dbColumns,\n dbConstraints,\n dbIndices,\n dbForeignKeys,\n ]: ObjectLiteral[][] = await Promise.all([\n this.query(columnsSql),\n this.query(constraintsSql),\n this.query(indicesSql),\n this.query(foreignKeysSql),\n ])\n\n // create tables for loaded tables\n return Promise.all(\n dbTables.map(async (dbTable) => {\n const table = new Table()\n const getSchemaFromKey = (dbObject: any, key: string) => {\n return dbObject[key] === currentSchema &&\n (!this.driver.options.schema ||\n this.driver.options.schema === currentSchema)\n ? undefined\n : dbObject[key]\n }\n\n // We do not need to join schema name, when database is by default.\n const schema = getSchemaFromKey(dbTable, \"SCHEMA_NAME\")\n table.database = currentDatabase\n table.schema = dbTable[\"SCHEMA_NAME\"]\n table.name = this.driver.buildTableName(\n dbTable[\"TABLE_NAME\"],\n schema,\n )\n\n // create columns from the loaded columns\n table.columns = await Promise.all(\n dbColumns\n .filter(\n (dbColumn) =>\n dbColumn[\"TABLE_NAME\"] ===\n dbTable[\"TABLE_NAME\"] &&\n dbColumn[\"SCHEMA_NAME\"] ===\n dbTable[\"SCHEMA_NAME\"],\n )\n .map(async (dbColumn) => {\n const columnConstraints = dbConstraints.filter(\n (dbConstraint) =>\n dbConstraint[\"TABLE_NAME\"] ===\n dbColumn[\"TABLE_NAME\"] &&\n dbConstraint[\"SCHEMA_NAME\"] ===\n dbColumn[\"SCHEMA_NAME\"] &&\n dbConstraint[\"COLUMN_NAME\"] ===\n dbColumn[\"COLUMN_NAME\"],\n )\n\n const columnUniqueIndices = dbIndices.filter(\n (dbIndex) => {\n return (\n dbIndex[\"TABLE_NAME\"] ===\n dbTable[\"TABLE_NAME\"] &&\n dbIndex[\"SCHEMA_NAME\"] ===\n dbTable[\"SCHEMA_NAME\"] &&\n dbIndex[\"COLUMN_NAME\"] ===\n dbColumn[\"COLUMN_NAME\"] &&\n dbIndex[\"CONSTRAINT\"] &&\n dbIndex[\"CONSTRAINT\"].indexOf(\n \"UNIQUE\",\n ) !== -1\n )\n },\n )\n\n const tableMetadata =\n this.connection.entityMetadatas.find(\n (metadata) =>\n this.getTablePath(table) ===\n this.getTablePath(metadata),\n )\n const hasIgnoredIndex =\n columnUniqueIndices.length > 0 &&\n tableMetadata &&\n tableMetadata.indices.some((index) => {\n return columnUniqueIndices.some(\n (uniqueIndex) => {\n return (\n index.name ===\n uniqueIndex[\"INDEX_NAME\"] &&\n index.synchronize === false\n )\n },\n )\n })\n\n const isConstraintComposite =\n columnUniqueIndices.every((uniqueIndex) => {\n return dbIndices.some(\n (dbIndex) =>\n dbIndex[\"INDEX_NAME\"] ===\n uniqueIndex[\"INDEX_NAME\"] &&\n dbIndex[\"COLUMN_NAME\"] !==\n dbColumn[\"COLUMN_NAME\"],\n )\n })\n\n const tableColumn = new TableColumn()\n tableColumn.name = dbColumn[\"COLUMN_NAME\"]\n tableColumn.type =\n dbColumn[\"DATA_TYPE_NAME\"].toLowerCase()\n\n if (\n tableColumn.type === \"dec\" ||\n tableColumn.type === \"decimal\"\n ) {\n // If one of these properties was set, and another was not, Postgres sets '0' in to unspecified property\n // we set 'undefined' in to unspecified property to avoid changing column on sync\n if (\n dbColumn[\"LENGTH\"] !== null &&\n !this.isDefaultColumnPrecision(\n table,\n tableColumn,\n dbColumn[\"LENGTH\"],\n )\n ) {\n tableColumn.precision = dbColumn[\"LENGTH\"]\n } else if (\n dbColumn[\"SCALE\"] !== null &&\n !this.isDefaultColumnScale(\n table,\n tableColumn,\n dbColumn[\"SCALE\"],\n )\n ) {\n tableColumn.precision = undefined\n }\n if (\n dbColumn[\"SCALE\"] !== null &&\n !this.isDefaultColumnScale(\n table,\n tableColumn,\n dbColumn[\"SCALE\"],\n )\n ) {\n tableColumn.scale = dbColumn[\"SCALE\"]\n } else if (\n dbColumn[\"LENGTH\"] !== null &&\n !this.isDefaultColumnPrecision(\n table,\n tableColumn,\n dbColumn[\"LENGTH\"],\n )\n ) {\n tableColumn.scale = undefined\n }\n }\n\n if (\n dbColumn[\"DATA_TYPE_NAME\"].toLowerCase() ===\n \"array\"\n ) {\n tableColumn.isArray = true\n tableColumn.type =\n dbColumn[\"CS_DATA_TYPE_NAME\"].toLowerCase()\n }\n\n // check only columns that have length property\n if (\n this.driver.withLengthColumnTypes.indexOf(\n tableColumn.type as ColumnType,\n ) !== -1 &&\n dbColumn[\"LENGTH\"]\n ) {\n const length = dbColumn[\"LENGTH\"].toString()\n tableColumn.length =\n !this.isDefaultColumnLength(\n table,\n tableColumn,\n length,\n )\n ? length\n : \"\"\n }\n tableColumn.isUnique =\n columnUniqueIndices.length > 0 &&\n !hasIgnoredIndex &&\n !isConstraintComposite\n tableColumn.isNullable =\n dbColumn[\"IS_NULLABLE\"] === \"TRUE\"\n tableColumn.isPrimary = !!columnConstraints.find(\n (constraint) =>\n constraint[\"IS_PRIMARY_KEY\"] === \"TRUE\",\n )\n tableColumn.isGenerated =\n dbColumn[\"GENERATION_TYPE\"] ===\n \"ALWAYS AS IDENTITY\"\n if (tableColumn.isGenerated)\n tableColumn.generationStrategy = \"increment\"\n\n if (\n dbColumn[\"DEFAULT_VALUE\"] === null ||\n dbColumn[\"DEFAULT_VALUE\"] === undefined\n ) {\n tableColumn.default = undefined\n } else {\n if (\n tableColumn.type === \"char\" ||\n tableColumn.type === \"nchar\" ||\n tableColumn.type === \"varchar\" ||\n tableColumn.type === \"nvarchar\" ||\n tableColumn.type === \"alphanum\" ||\n tableColumn.type === \"shorttext\"\n ) {\n tableColumn.default = `'${dbColumn[\"DEFAULT_VALUE\"]}'`\n } else if (tableColumn.type === \"boolean\") {\n tableColumn.default =\n dbColumn[\"DEFAULT_VALUE\"] === \"1\"\n ? \"true\"\n : \"false\"\n } else {\n tableColumn.default =\n dbColumn[\"DEFAULT_VALUE\"]\n }\n }\n tableColumn.comment = \"\" // dbColumn[\"COLUMN_COMMENT\"];\n if (dbColumn[\"character_set_name\"])\n tableColumn.charset =\n dbColumn[\"character_set_name\"]\n if (dbColumn[\"collation_name\"])\n tableColumn.collation =\n dbColumn[\"collation_name\"]\n return tableColumn\n }),\n )\n\n // find check constraints of table, group them by constraint name and build TableCheck.\n const tableCheckConstraints = OrmUtils.uniq(\n dbConstraints.filter(\n (dbConstraint) =>\n dbConstraint[\"TABLE_NAME\"] ===\n dbTable[\"TABLE_NAME\"] &&\n dbConstraint[\"SCHEMA_NAME\"] ===\n dbTable[\"SCHEMA_NAME\"] &&\n dbConstraint[\"CHECK_CONDITION\"] !== null &&\n dbConstraint[\"CHECK_CONDITION\"] !== undefined,\n ),\n (dbConstraint) => dbConstraint[\"CONSTRAINT_NAME\"],\n )\n\n table.checks = tableCheckConstraints.map((constraint) => {\n const checks = dbConstraints.filter(\n (dbC) =>\n dbC[\"CONSTRAINT_NAME\"] ===\n constraint[\"CONSTRAINT_NAME\"],\n )\n return new TableCheck({\n name: constraint[\"CONSTRAINT_NAME\"],\n columnNames: checks.map((c) => c[\"COLUMN_NAME\"]),\n expression: constraint[\"CHECK_CONDITION\"],\n })\n })\n\n // find foreign key constraints of table, group them by constraint name and build TableForeignKey.\n const tableForeignKeyConstraints = OrmUtils.uniq(\n dbForeignKeys.filter(\n (dbForeignKey) =>\n dbForeignKey[\"TABLE_NAME\"] ===\n dbTable[\"TABLE_NAME\"] &&\n dbForeignKey[\"SCHEMA_NAME\"] ===\n dbTable[\"SCHEMA_NAME\"],\n ),\n (dbForeignKey) => dbForeignKey[\"CONSTRAINT_NAME\"],\n )\n\n table.foreignKeys = tableForeignKeyConstraints.map(\n (dbForeignKey) => {\n const foreignKeys = dbForeignKeys.filter(\n (dbFk) =>\n dbFk[\"CONSTRAINT_NAME\"] ===\n dbForeignKey[\"CONSTRAINT_NAME\"],\n )\n\n // if referenced table located in currently used schema, we don't need to concat schema name to table name.\n const schema = getSchemaFromKey(\n dbForeignKey,\n \"REFERENCED_SCHEMA_NAME\",\n )\n const referencedTableName = this.driver.buildTableName(\n dbForeignKey[\"REFERENCED_TABLE_NAME\"],\n schema,\n )\n\n return new TableForeignKey({\n name: dbForeignKey[\"CONSTRAINT_NAME\"],\n columnNames: foreignKeys.map(\n (dbFk) => dbFk[\"COLUMN_NAME\"],\n ),\n referencedDatabase: table.database,\n referencedSchema:\n dbForeignKey[\"REFERENCED_SCHEMA_NAME\"],\n referencedTableName: referencedTableName,\n referencedColumnNames: foreignKeys.map(\n (dbFk) => dbFk[\"REFERENCED_COLUMN_NAME\"],\n ),\n onDelete:\n dbForeignKey[\"DELETE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"DELETE_RULE\"],\n onUpdate:\n dbForeignKey[\"UPDATE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"UPDATE_RULE\"],\n deferrable: dbForeignKey[\"CHECK_TIME\"].replace(\n \"_\",\n \" \",\n ),\n })\n },\n )\n\n // find index constraints of table, group them by constraint name and build TableIndex.\n const tableIndexConstraints = OrmUtils.uniq(\n dbIndices.filter(\n (dbIndex) =>\n dbIndex[\"TABLE_NAME\"] === dbTable[\"TABLE_NAME\"] &&\n dbIndex[\"SCHEMA_NAME\"] === dbTable[\"SCHEMA_NAME\"],\n ),\n (dbIndex) => dbIndex[\"INDEX_NAME\"],\n )\n\n table.indices = tableIndexConstraints.map((constraint) => {\n const indices = dbIndices.filter((index) => {\n return (\n index[\"SCHEMA_NAME\"] ===\n constraint[\"SCHEMA_NAME\"] &&\n index[\"TABLE_NAME\"] === constraint[\"TABLE_NAME\"] &&\n index[\"INDEX_NAME\"] === constraint[\"INDEX_NAME\"]\n )\n })\n return new TableIndex(<TableIndexOptions>{\n table: table,\n name: constraint[\"INDEX_NAME\"],\n columnNames: indices.map((i) => i[\"COLUMN_NAME\"]),\n isUnique:\n constraint[\"CONSTRAINT\"] &&\n constraint[\"CONSTRAINT\"].indexOf(\"UNIQUE\") !== -1,\n isFulltext: constraint[\"INDEX_TYPE\"] === \"FULLTEXT\",\n })\n })\n\n return table\n }),\n )\n }\n\n /**\n * Builds and returns SQL for create table.\n */\n protected createTableSql(table: Table, createForeignKeys?: boolean): Query {\n const columnDefinitions = table.columns\n .map((column) => this.buildCreateColumnSql(column))\n .join(\", \")\n let sql = `CREATE TABLE ${this.escapePath(table)} (${columnDefinitions}`\n\n // we create unique indexes instead of unique constraints, because SAP HANA does not have unique constraints.\n // if we mark column as Unique, it means that we create UNIQUE INDEX.\n table.columns\n .filter((column) => column.isUnique)\n .forEach((column) => {\n const isUniqueIndexExist = table.indices.some((index) => {\n return (\n index.columnNames.length === 1 &&\n !!index.isUnique &&\n index.columnNames.indexOf(column.name) !== -1\n )\n })\n const isUniqueConstraintExist = table.uniques.some((unique) => {\n return (\n unique.columnNames.length === 1 &&\n unique.columnNames.indexOf(column.name) !== -1\n )\n })\n if (!isUniqueIndexExist && !isUniqueConstraintExist)\n table.indices.push(\n new TableIndex({\n name: this.connection.namingStrategy.uniqueConstraintName(\n table,\n [column.name],\n ),\n columnNames: [column.name],\n isUnique: true,\n }),\n )\n })\n\n // as SAP HANA does not have unique constraints, we must create table indices from table uniques and mark them as unique.\n if (table.uniques.length > 0) {\n table.uniques.forEach((unique) => {\n const uniqueExist = table.indices.some(\n (index) => index.name === unique.name,\n )\n if (!uniqueExist) {\n table.indices.push(\n new TableIndex({\n name: unique.name,\n columnNames: unique.columnNames,\n isUnique: true,\n }),\n )\n }\n })\n }\n\n if (table.checks.length > 0) {\n const checksSql = table.checks\n .map((check) => {\n const checkName = check.name\n ? check.name\n : this.connection.namingStrategy.checkConstraintName(\n table,\n check.expression!,\n )\n return `CONSTRAINT \"${checkName}\" CHECK (${check.expression})`\n })\n .join(\", \")\n\n sql += `, ${checksSql}`\n }\n\n if (table.foreignKeys.length > 0 && createForeignKeys) {\n const foreignKeysSql = table.foreignKeys\n .map((fk) => {\n const columnNames = fk.columnNames\n .map((columnName) => `\"${columnName}\"`)\n .join(\", \")\n if (!fk.name)\n fk.name = this.connection.namingStrategy.foreignKeyName(\n table,\n fk.columnNames,\n this.getTablePath(fk),\n fk.referencedColumnNames,\n )\n const referencedColumnNames = fk.referencedColumnNames\n .map((columnName) => `\"${columnName}\"`)\n .join(\", \")\n\n let constraint = `CONSTRAINT \"${\n fk.name\n }\" FOREIGN KEY (${columnNames}) REFERENCES ${this.escapePath(\n this.getTablePath(fk),\n )} (${referencedColumnNames})`\n // SAP HANA does not have \"NO ACTION\" option for FK's\n if (fk.onDelete) {\n const onDelete =\n fk.onDelete === \"NO ACTION\"\n ? \"RESTRICT\"\n : fk.onDelete\n constraint += ` ON DELETE ${onDelete}`\n }\n if (fk.onUpdate) {\n const onUpdate =\n fk.onUpdate === \"NO ACTION\"\n ? \"RESTRICT\"\n : fk.onUpdate\n constraint += ` ON UPDATE ${onUpdate}`\n }\n if (fk.deferrable) {\n constraint += ` ${fk.deferrable}`\n }\n\n return constraint\n })\n .join(\", \")\n\n sql += `, ${foreignKeysSql}`\n }\n\n const primaryColumns = table.columns.filter(\n (column) => column.isPrimary,\n )\n if (primaryColumns.length > 0) {\n const primaryKeyName =\n this.connection.namingStrategy.primaryKeyName(\n table,\n primaryColumns.map((column) => column.name),\n )\n const columnNames = primaryColumns\n .map((column) => `\"${column.name}\"`)\n .join(\", \")\n sql += `, CONSTRAINT \"${primaryKeyName}\" PRIMARY KEY (${columnNames})`\n }\n\n sql += `)`\n\n return new Query(sql)\n }\n\n /**\n * Builds drop table sql.\n */\n protected dropTableSql(\n tableOrName: Table | string,\n ifExist?: boolean,\n ): Query {\n const query = ifExist\n ? `DROP TABLE IF EXISTS ${this.escapePath(tableOrName)}`\n : `DROP TABLE ${this.escapePath(tableOrName)}`\n return new Query(query)\n }\n\n protected createViewSql(view: View): Query {\n if (typeof view.expression === \"string\") {\n return new Query(\n `CREATE VIEW ${this.escapePath(view)} AS ${view.expression}`,\n )\n } else {\n return new Query(\n `CREATE VIEW ${this.escapePath(view)} AS ${view\n .expression(this.connection)\n .getQuery()}`,\n )\n }\n }\n\n protected async insertViewDefinitionSql(view: View): Promise<Query> {\n let { schema, tableName: name } = this.driver.parseTableName(view)\n\n if (!schema) {\n schema = await this.getCurrentSchema()\n }\n\n const expression =\n typeof view.expression === \"string\"\n ? view.expression.trim()\n : view.expression(this.connection).getQuery()\n return this.insertTypeormMetadataSql({\n type: MetadataTableType.VIEW,\n schema: schema,\n name: name,\n value: expression,\n })\n }\n\n /**\n * Builds drop view sql.\n */\n protected dropViewSql(viewOrPath: View | string): Query {\n return new Query(`DROP VIEW ${this.escapePath(viewOrPath)}`)\n }\n\n /**\n * Builds remove view sql.\n */\n protected async deleteViewDefinitionSql(\n viewOrPath: View | string,\n ): Promise<Query> {\n let { schema, tableName: name } = this.driver.parseTableName(viewOrPath)\n\n if (!schema) {\n schema = await this.getCurrentSchema()\n }\n\n return this.deleteTypeormMetadataSql({\n type: MetadataTableType.VIEW,\n schema,\n name,\n })\n }\n\n protected addColumnSql(table: Table, column: TableColumn): string {\n return `ALTER TABLE ${this.escapePath(\n table,\n )} ADD (${this.buildCreateColumnSql(column)})`\n }\n\n protected dropColumnSql(table: Table, column: TableColumn): string {\n return `ALTER TABLE ${this.escapePath(table)} DROP (\"${column.name}\")`\n }\n\n /**\n * Builds create index sql.\n */\n protected createIndexSql(table: Table, index: TableIndex): Query {\n const columns = index.columnNames\n .map((columnName) => `\"${columnName}\"`)\n .join(\", \")\n let indexType = \"\"\n if (index.isUnique) {\n indexType += \"UNIQUE \"\n }\n if (index.isFulltext) {\n indexType += \"FULLTEXT \"\n }\n\n return new Query(\n `CREATE ${indexType}INDEX \"${index.name}\" ON ${this.escapePath(\n table,\n )} (${columns}) ${index.where ? \"WHERE \" + index.where : \"\"}`,\n )\n }\n\n /**\n * Builds drop index sql.\n */\n protected dropIndexSql(\n table: Table,\n indexOrName: TableIndex | string,\n ): Query {\n let indexName = InstanceChecker.isTableIndex(indexOrName)\n ? indexOrName.name\n : indexOrName\n const parsedTableName = this.driver.parseTableName(table)\n\n if (!parsedTableName.schema) {\n return new Query(`DROP INDEX \"${indexName}\"`)\n } else {\n return new Query(\n `DROP INDEX \"${parsedTableName.schema}\".\"${indexName}\"`,\n )\n }\n }\n\n /**\n * Builds create primary key sql.\n */\n protected createPrimaryKeySql(table: Table, columnNames: string[]): Query {\n const primaryKeyName = this.connection.namingStrategy.primaryKeyName(\n table,\n columnNames,\n )\n const columnNamesString = columnNames\n .map((columnName) => `\"${columnName}\"`)\n .join(\", \")\n return new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${primaryKeyName}\" PRIMARY KEY (${columnNamesString})`,\n )\n }\n\n /**\n * Builds drop primary key sql.\n */\n protected dropPrimaryKeySql(table: Table): Query {\n const columnNames = table.primaryColumns.map((column) => column.name)\n const primaryKeyName = this.connection.namingStrategy.primaryKeyName(\n table,\n columnNames,\n )\n return new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${primaryKeyName}\"`,\n )\n }\n\n /**\n * Builds create check constraint sql.\n */\n protected createCheckConstraintSql(\n table: Table,\n checkConstraint: TableCheck,\n ): Query {\n return new Query(\n `ALTER TABLE ${this.escapePath(table)} ADD CONSTRAINT \"${\n checkConstraint.name\n }\" CHECK (${checkConstraint.expression})`,\n )\n }\n\n /**\n * Builds drop check constraint sql.\n */\n protected dropCheckConstraintSql(\n table: Table,\n checkOrName: TableCheck | string,\n ): Query {\n const checkName = InstanceChecker.isTableCheck(checkOrName)\n ? checkOrName.name\n : checkOrName\n return new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${checkName}\"`,\n )\n }\n\n /**\n * Builds create foreign key sql.\n */\n protected createForeignKeySql(\n tableOrName: Table | string,\n foreignKey: TableForeignKey,\n ): Query {\n const columnNames = foreignKey.columnNames\n .map((column) => `\"` + column + `\"`)\n .join(\", \")\n const referencedColumnNames = foreignKey.referencedColumnNames\n .map((column) => `\"` + column + `\"`)\n .join(\",\")\n let sql =\n `ALTER TABLE ${this.escapePath(tableOrName)} ADD CONSTRAINT \"${\n foreignKey.name\n }\" FOREIGN KEY (${columnNames}) ` +\n `REFERENCES ${this.escapePath(\n this.getTablePath(foreignKey),\n )}(${referencedColumnNames})`\n\n // SAP HANA does not have \"NO ACTION\" option for FK's\n if (foreignKey.onDelete) {\n const onDelete =\n foreignKey.onDelete === \"NO ACTION\"\n ? \"RESTRICT\"\n : foreignKey.onDelete\n sql += ` ON DELETE ${onDelete}`\n }\n if (foreignKey.onUpdate) {\n const onUpdate =\n foreignKey.onUpdate === \"NO ACTION\"\n ? \"RESTRICT\"\n : foreignKey.onUpdate\n sql += ` ON UPDATE ${onUpdate}`\n }\n\n if (foreignKey.deferrable) {\n sql += ` ${foreignKey.deferrable}`\n }\n\n return new Query(sql)\n }\n\n /**\n * Builds drop foreign key sql.\n */\n protected dropForeignKeySql(\n tableOrName: Table | string,\n foreignKeyOrName: TableForeignKey | string,\n ): Query {\n const foreignKeyName = InstanceChecker.isTableForeignKey(\n foreignKeyOrName,\n )\n ? foreignKeyOrName.name\n : foreignKeyOrName\n return new Query(\n `ALTER TABLE ${this.escapePath(\n tableOrName,\n )} DROP CONSTRAINT \"${foreignKeyName}\"`,\n )\n }\n\n /**\n * Escapes given table or view path.\n */\n protected escapePath(target: Table | View | string): string {\n const { schema, tableName } = this.driver.parseTableName(target)\n\n if (schema) {\n return `\"${schema}\".\"${tableName}\"`\n }\n\n return `\"${tableName}\"`\n }\n\n /**\n * Concat database name and schema name to the foreign key name.\n * Needs because FK name is relevant to the schema and database.\n */\n protected buildForeignKeyName(\n fkName: string,\n schemaName: string | undefined,\n dbName: string | undefined,\n ): string {\n let joinedFkName = fkName\n if (schemaName) joinedFkName = schemaName + \".\" + joinedFkName\n if (dbName) joinedFkName = dbName + \".\" + joinedFkName\n\n return joinedFkName\n }\n\n /**\n * Removes parenthesis around default value.\n * Sql server returns default value with parenthesis around, e.g.\n * ('My text') - for string\n * ((1)) - for number\n * (newsequentialId()) - for function\n */\n protected removeParenthesisFromDefault(defaultValue: any): any {\n if (defaultValue.substr(0, 1) !== \"(\") return defaultValue\n const normalizedDefault = defaultValue.substr(\n 1,\n defaultValue.lastIndexOf(\")\") - 1,\n )\n return this.removeParenthesisFromDefault(normalizedDefault)\n }\n\n /**\n * Builds a query for create column.\n */\n protected buildCreateColumnSql(column: TableColumn) {\n let c =\n `\"${column.name}\" ` + this.connection.driver.createFullType(column)\n if (column.charset) c += \" CHARACTER SET \" + column.charset\n if (column.collation) c += \" COLLATE \" + column.collation\n if (column.default !== undefined && column.default !== null)\n // DEFAULT must be placed before NOT NULL\n c += \" DEFAULT \" + column.default\n if (column.isNullable !== true && !column.isGenerated)\n // NOT NULL is not supported with GENERATED\n c += \" NOT NULL\"\n if (\n column.isGenerated === true &&\n column.generationStrategy === \"increment\"\n )\n c += \" GENERATED ALWAYS AS IDENTITY\"\n\n return c\n }\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../browser/src/driver/sap/SapQueryRunner.ts"],"names":[],"mappings":"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","file":"SapQueryRunner.js","sourcesContent":["import type { ObjectLiteral } from \"../../common/ObjectLiteral\"\nimport { QueryRunnerAlreadyReleasedError } from \"../../error/QueryRunnerAlreadyReleasedError\"\nimport { TransactionAlreadyStartedError } from \"../../error/TransactionAlreadyStartedError\"\nimport { TransactionNotStartedError } from \"../../error/TransactionNotStartedError\"\nimport type { ColumnType } from \"../types/ColumnTypes\"\nimport type { ReadStream } from \"../../platform/PlatformTools\"\nimport { BaseQueryRunner } from \"../../query-runner/BaseQueryRunner\"\nimport type { QueryRunner } from \"../../query-runner/QueryRunner\"\nimport type { TableIndexOptions } from \"../../schema-builder/options/TableIndexOptions\"\nimport { Table } from \"../../schema-builder/table/Table\"\nimport { TableCheck } from \"../../schema-builder/table/TableCheck\"\nimport { TableColumn } from \"../../schema-builder/table/TableColumn\"\nimport type { TableExclusion } from \"../../schema-builder/table/TableExclusion\"\nimport { TableForeignKey } from \"../../schema-builder/table/TableForeignKey\"\nimport { TableIndex } from \"../../schema-builder/table/TableIndex\"\nimport { TableUnique } from \"../../schema-builder/table/TableUnique\"\nimport { View } from \"../../schema-builder/view/View\"\nimport { Broadcaster } from \"../../subscriber/Broadcaster\"\nimport { OrmUtils } from \"../../util/OrmUtils\"\nimport { Query } from \"../Query\"\nimport type { IsolationLevel } from \"../types/IsolationLevel\"\nimport type { SapDriver } from \"./SapDriver\"\nimport type { ReplicationMode } from \"../types/ReplicationMode\"\nimport { QueryFailedError, TypeORMError } from \"../../error\"\nimport { QueryResult } from \"../../query-runner/QueryResult\"\nimport { QueryLock } from \"../../query-runner/QueryLock\"\nimport { MetadataTableType } from \"../types/MetadataTableType\"\nimport { InstanceChecker } from \"../../util/InstanceChecker\"\nimport { promisify } from \"util\"\n\n/**\n * Runs queries on a single SQL Server database connection.\n */\nexport class SapQueryRunner extends BaseQueryRunner implements QueryRunner {\n // -------------------------------------------------------------------------\n // Public Implemented Properties\n // -------------------------------------------------------------------------\n\n /**\n * Database driver used by connection.\n */\n driver: SapDriver\n\n // -------------------------------------------------------------------------\n // Protected Properties\n // -------------------------------------------------------------------------\n\n /**\n * Promise used to obtain a database connection from a pool for a first time.\n */\n protected databaseConnectionPromise: Promise<any>\n\n private lock: QueryLock = new QueryLock()\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: SapDriver, mode: ReplicationMode) {\n super()\n this.driver = driver\n this.connection = driver.connection\n this.broadcaster = new Broadcaster(this)\n this.mode = mode\n }\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n /**\n * Creates/uses database connection from the connection pool to perform further operations.\n * Returns obtained database connection.\n */\n async connect(): Promise<any> {\n if (this.databaseConnection) return this.databaseConnection\n\n this.databaseConnection = await this.driver.obtainMasterConnection()\n\n return this.databaseConnection\n }\n\n /**\n * Releases used database connection.\n * You cannot use query runner methods once its released.\n */\n release(): Promise<void> {\n this.isReleased = true\n\n if (this.databaseConnection) {\n return this.driver.master.release(this.databaseConnection)\n }\n\n return Promise.resolve()\n }\n\n /**\n * Starts transaction.\n */\n async startTransaction(isolationLevel?: IsolationLevel): Promise<void> {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError()\n\n if (\n this.isTransactionActive &&\n this.driver.transactionSupport === \"simple\"\n )\n throw new TransactionAlreadyStartedError()\n\n await this.broadcaster.broadcast(\"BeforeTransactionStart\")\n\n this.isTransactionActive = true\n\n /**\n * Disable AUTOCOMMIT while running transaction.\n * Otherwise, COMMIT/ROLLBACK doesn't work in autocommit mode.\n */\n await this.setAutoCommit({ status: \"off\" })\n\n if (isolationLevel) {\n await this.query(\n `SET TRANSACTION ISOLATION LEVEL ${isolationLevel || \"\"}`,\n )\n }\n\n await this.broadcaster.broadcast(\"AfterTransactionStart\")\n }\n\n /**\n * Commits transaction.\n * Error will be thrown if transaction was not started.\n */\n async commitTransaction(): Promise<void> {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError()\n\n if (!this.isTransactionActive) throw new TransactionNotStartedError()\n\n await this.broadcaster.broadcast(\"BeforeTransactionCommit\")\n\n await this.query(\"COMMIT\")\n this.isTransactionActive = false\n\n await this.setAutoCommit({ status: \"on\" })\n await this.broadcaster.broadcast(\"AfterTransactionCommit\")\n }\n\n /**\n * Rollbacks transaction.\n * Error will be thrown if transaction was not started.\n */\n async rollbackTransaction(): Promise<void> {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError()\n\n if (!this.isTransactionActive) throw new TransactionNotStartedError()\n\n await this.broadcaster.broadcast(\"BeforeTransactionRollback\")\n\n await this.query(\"ROLLBACK\")\n this.isTransactionActive = false\n\n await this.setAutoCommit({ status: \"on\" })\n await this.broadcaster.broadcast(\"AfterTransactionRollback\")\n }\n\n /**\n * @description Switches on/off AUTOCOMMIT mode\n * @link https://help.sap.com/docs/HANA_SERVICE_CF/7c78579ce9b14a669c1f3295b0d8ca16/d538d11053bd4f3f847ec5ce817a3d4c.html?locale=en-US\n */\n async setAutoCommit(options: { status: \"on\" | \"off\" }) {\n const connection = await this.connect()\n\n const execute = promisify(connection.exec.bind(connection))\n\n connection.setAutoCommit(options.status === \"on\")\n\n const query = `SET TRANSACTION AUTOCOMMIT DDL ${options.status.toUpperCase()};`\n try {\n await execute(query)\n } catch (error) {\n throw new QueryFailedError(query, [], error)\n }\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) throw new QueryRunnerAlreadyReleasedError()\n\n const release = await this.lock.acquire()\n\n let statement: any\n const result = new QueryResult()\n\n try {\n const databaseConnection = await this.connect()\n\n this.driver.connection.logger.logQuery(query, parameters, this)\n const queryStartTime = +new Date()\n const isInsertQuery = query.substr(0, 11) === \"INSERT INTO\"\n\n statement = databaseConnection.prepare(query)\n\n const raw = await new Promise<any>((ok, fail) => {\n statement.exec(parameters, (err: any, raw: any) =>\n err\n ? fail(new QueryFailedError(query, parameters, err))\n : ok(raw),\n )\n })\n\n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime =\n this.driver.connection.options.maxQueryExecutionTime\n const queryEndTime = +new Date()\n const queryExecutionTime = queryEndTime - queryStartTime\n if (\n maxQueryExecutionTime &&\n queryExecutionTime > maxQueryExecutionTime\n ) {\n this.driver.connection.logger.logQuerySlow(\n queryExecutionTime,\n query,\n parameters,\n this,\n )\n }\n\n if (typeof raw === \"number\") {\n result.affected = raw\n } else if (Array.isArray(raw)) {\n result.records = raw\n }\n\n result.raw = raw\n\n if (isInsertQuery) {\n const lastIdQuery = `SELECT CURRENT_IDENTITY_VALUE() FROM \"SYS\".\"DUMMY\"`\n this.driver.connection.logger.logQuery(lastIdQuery, [], this)\n const identityValueResult = await new Promise<any>(\n (ok, fail) => {\n databaseConnection.exec(\n lastIdQuery,\n (err: any, raw: any) =>\n err\n ? fail(\n new QueryFailedError(\n lastIdQuery,\n [],\n err,\n ),\n )\n : ok(raw),\n )\n },\n )\n\n result.raw = identityValueResult[0][\"CURRENT_IDENTITY_VALUE()\"]\n result.records = identityValueResult\n }\n } catch (e) {\n this.driver.connection.logger.logQueryError(\n e,\n query,\n parameters,\n this,\n )\n throw e\n } finally {\n // Never forget to drop the statement we reserved\n if (statement?.drop) {\n await new Promise<void>((ok) => statement.drop(() => ok()))\n }\n\n // Always release the lock.\n release()\n }\n\n if (useStructuredResult) {\n return result\n } else {\n return result.raw\n }\n }\n\n /**\n * Returns raw data stream.\n */\n async stream(\n query: string,\n parameters?: any[],\n onEnd?: Function,\n onError?: Function,\n ): Promise<ReadStream> {\n throw new TypeORMError(`Stream is not supported by SAP driver.`)\n }\n\n /**\n * Returns all available database names including system databases.\n */\n async getDatabases(): Promise<string[]> {\n const results: ObjectLiteral[] = await this.query(\n `SELECT DATABASE_NAME FROM \"SYS\".\"M_DATABASES\"`,\n )\n return results.map((result) => result[\"DATABASE_NAME\"])\n }\n\n /**\n * Returns all available schema names including system schemas.\n * If database parameter specified, returns schemas of that database.\n */\n async getSchemas(database?: string): Promise<string[]> {\n const query = database\n ? `SELECT * FROM \"${database}\".\"SYS\".\"SCHEMAS\"`\n : `SELECT * FROM \"SYS\".\"SCHEMAS\"`\n const results: ObjectLiteral[] = await this.query(query)\n return results.map((result) => result[\"SCHEMA_NAME\"])\n }\n\n /**\n * Checks if database with the given name exist.\n */\n async hasDatabase(database: string): Promise<boolean> {\n const databases = await this.getDatabases()\n return databases.indexOf(database) !== -1\n }\n\n /**\n * Returns current database.\n */\n async getCurrentDatabase(): Promise<string> {\n const currentDBQuery = await this.query(\n `SELECT \"VALUE\" AS \"db_name\" FROM \"SYS\".\"M_SYSTEM_OVERVIEW\" WHERE \"SECTION\" = 'System' and \"NAME\" = 'Instance ID'`,\n )\n return currentDBQuery[0][\"db_name\"]\n }\n\n /**\n * Checks if schema with the given name exist.\n */\n async hasSchema(schema: string): Promise<boolean> {\n const schemas = await this.getSchemas()\n return schemas.indexOf(schema) !== -1\n }\n\n /**\n * Returns current schema.\n */\n async getCurrentSchema(): Promise<string> {\n const currentSchemaQuery = await this.query(\n `SELECT CURRENT_SCHEMA AS \"schema_name\" FROM \"SYS\".\"DUMMY\"`,\n )\n return currentSchemaQuery[0][\"schema_name\"]\n }\n\n /**\n * Checks if table with the given name exist in the database.\n */\n async hasTable(tableOrName: Table | string): Promise<boolean> {\n const parsedTableName = this.driver.parseTableName(tableOrName)\n\n if (!parsedTableName.schema) {\n parsedTableName.schema = await this.getCurrentSchema()\n }\n\n const sql = `SELECT * FROM \"SYS\".\"TABLES\" WHERE \"SCHEMA_NAME\" = '${parsedTableName.schema}' AND \"TABLE_NAME\" = '${parsedTableName.tableName}'`\n const result = await this.query(sql)\n return result.length ? true : false\n }\n\n /**\n * Checks if column with the given name exist in the given table.\n */\n async hasColumn(\n tableOrName: Table | string,\n columnName: string,\n ): Promise<boolean> {\n const parsedTableName = this.driver.parseTableName(tableOrName)\n\n if (!parsedTableName.schema) {\n parsedTableName.schema = await this.getCurrentSchema()\n }\n\n const sql = `SELECT * FROM \"SYS\".\"TABLE_COLUMNS\" WHERE \"SCHEMA_NAME\" = ${parsedTableName.schema} AND \"TABLE_NAME\" = ${parsedTableName.tableName} AND \"COLUMN_NAME\" = '${columnName}'`\n const result = await this.query(sql)\n return result.length ? true : false\n }\n\n /**\n * Creates a new database.\n */\n async createDatabase(\n database: string,\n ifNotExist?: boolean,\n ): Promise<void> {\n return Promise.resolve()\n }\n\n /**\n * Drops database.\n */\n async dropDatabase(database: string, ifExist?: boolean): Promise<void> {\n return Promise.resolve()\n }\n\n /**\n * Creates a new table schema.\n */\n async createSchema(\n schemaPath: string,\n ifNotExist?: boolean,\n ): Promise<void> {\n const schema =\n schemaPath.indexOf(\".\") === -1\n ? schemaPath\n : schemaPath.split(\".\")[1]\n\n let exist = false\n if (ifNotExist) {\n const result = await this.query(\n `SELECT * FROM \"SYS\".\"SCHEMAS\" WHERE \"SCHEMA_NAME\" = '${schema}'`,\n )\n exist = !!result.length\n }\n if (!ifNotExist || (ifNotExist && !exist)) {\n const up = `CREATE SCHEMA \"${schema}\"`\n const down = `DROP SCHEMA \"${schema}\" CASCADE`\n await this.executeQueries(new Query(up), new Query(down))\n }\n }\n\n /**\n * Drops table schema\n */\n async dropSchema(\n schemaPath: string,\n ifExist?: boolean,\n isCascade?: boolean,\n ): Promise<void> {\n const schema =\n schemaPath.indexOf(\".\") === -1\n ? schemaPath\n : schemaPath.split(\".\")[0]\n let exist = false\n if (ifExist) {\n const result = await this.query(\n `SELECT * FROM \"SYS\".\"SCHEMAS\" WHERE \"SCHEMA_NAME\" = '${schema}'`,\n )\n exist = !!result.length\n }\n if (!ifExist || (ifExist && exist)) {\n const up = `DROP SCHEMA \"${schema}\" ${isCascade ? \"CASCADE\" : \"\"}`\n const down = `CREATE SCHEMA \"${schema}\"`\n await this.executeQueries(new Query(up), new Query(down))\n }\n }\n\n /**\n * Creates a new table.\n */\n async createTable(\n table: Table,\n ifNotExist = false,\n createForeignKeys = true,\n createIndices = true,\n ): Promise<void> {\n if (ifNotExist) {\n const isTableExist = await this.hasTable(table)\n if (isTableExist) return Promise.resolve()\n }\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n\n upQueries.push(this.createTableSql(table, createForeignKeys))\n downQueries.push(this.dropTableSql(table))\n\n // if createForeignKeys is true, we must drop created foreign keys in down query.\n // createTable does not need separate method to create foreign keys, because it create fk's in the same query with table creation.\n if (createForeignKeys)\n table.foreignKeys.forEach((foreignKey) =>\n downQueries.push(this.dropForeignKeySql(table, foreignKey)),\n )\n\n if (createIndices) {\n table.indices.forEach((index) => {\n // new index may be passed without name. In this case we generate index name manually.\n if (!index.name)\n index.name = this.connection.namingStrategy.indexName(\n table,\n index.columnNames,\n index.where,\n )\n upQueries.push(this.createIndexSql(table, index))\n downQueries.push(this.dropIndexSql(table, index))\n })\n }\n\n await this.executeQueries(upQueries, downQueries)\n }\n\n /**\n * Drops the table.\n */\n async dropTable(\n tableOrName: Table | string,\n ifExist?: boolean,\n dropForeignKeys = true,\n dropIndices = true,\n ): Promise<void> {\n if (ifExist) {\n const isTableExist = await this.hasTable(tableOrName)\n if (!isTableExist) return Promise.resolve()\n }\n\n // if dropTable called with dropForeignKeys = true, we must create foreign keys in down query.\n const createForeignKeys: boolean = dropForeignKeys\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n\n // It needs because if table does not exist and dropForeignKeys or dropIndices is true, we don't need\n // to perform drop queries for foreign keys and indices.\n\n if (dropIndices) {\n table.indices.forEach((index) => {\n upQueries.push(this.dropIndexSql(table, index))\n downQueries.push(this.createIndexSql(table, index))\n })\n }\n\n // if dropForeignKeys is true, we just drop the table, otherwise we also drop table foreign keys.\n // createTable does not need separate method to create foreign keys, because it create fk's in the same query with table creation.\n if (dropForeignKeys)\n table.foreignKeys.forEach((foreignKey) =>\n upQueries.push(this.dropForeignKeySql(table, foreignKey)),\n )\n\n upQueries.push(this.dropTableSql(table))\n downQueries.push(this.createTableSql(table, createForeignKeys))\n\n await this.executeQueries(upQueries, downQueries)\n }\n\n /**\n * Creates a new view.\n */\n async createView(view: View, syncWithMetadata = false): Promise<void> {\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n upQueries.push(this.createViewSql(view))\n if (syncWithMetadata)\n upQueries.push(await this.insertViewDefinitionSql(view))\n downQueries.push(this.dropViewSql(view))\n if (syncWithMetadata)\n downQueries.push(await this.deleteViewDefinitionSql(view))\n await this.executeQueries(upQueries, downQueries)\n }\n\n /**\n * Drops the view.\n */\n async dropView(target: View | string): Promise<void> {\n const viewName = InstanceChecker.isView(target) ? target.name : target\n const view = await this.getCachedView(viewName)\n\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n upQueries.push(await this.deleteViewDefinitionSql(view))\n upQueries.push(this.dropViewSql(view))\n downQueries.push(await this.insertViewDefinitionSql(view))\n downQueries.push(this.createViewSql(view))\n await this.executeQueries(upQueries, downQueries)\n }\n\n /**\n * Renames a table.\n */\n async renameTable(\n oldTableOrName: Table | string,\n newTableName: string,\n ): Promise<void> {\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n const oldTable = InstanceChecker.isTable(oldTableOrName)\n ? oldTableOrName\n : await this.getCachedTable(oldTableOrName)\n const newTable = oldTable.clone()\n\n const { schema: schemaName, tableName: oldTableName } =\n this.driver.parseTableName(oldTable)\n\n newTable.name = schemaName\n ? `${schemaName}.${newTableName}`\n : newTableName\n\n // rename table\n upQueries.push(\n new Query(\n `RENAME TABLE ${this.escapePath(oldTable)} TO ${this.escapePath(\n newTableName,\n )}`,\n ),\n )\n downQueries.push(\n new Query(\n `RENAME TABLE ${this.escapePath(newTable)} TO ${this.escapePath(\n oldTableName,\n )}`,\n ),\n )\n\n // drop old FK's. Foreign keys must be dropped before the primary keys are dropped\n newTable.foreignKeys.forEach((foreignKey) => {\n upQueries.push(this.dropForeignKeySql(newTable, foreignKey))\n downQueries.push(this.createForeignKeySql(newTable, foreignKey))\n })\n\n // SAP HANA does not allow to drop PK's which is referenced by foreign keys.\n // To avoid this, we must drop all referential foreign keys and recreate them later\n const referencedForeignKeySql = `SELECT * FROM \"SYS\".\"REFERENTIAL_CONSTRAINTS\" WHERE \"REFERENCED_SCHEMA_NAME\" = '${schemaName}' AND \"REFERENCED_TABLE_NAME\" = '${oldTableName}'`\n const dbForeignKeys: ObjectLiteral[] = await this.query(\n referencedForeignKeySql,\n )\n let referencedForeignKeys: TableForeignKey[] = []\n const referencedForeignKeyTableMapping: {\n tableName: string\n fkName: string\n }[] = []\n if (dbForeignKeys.length > 0) {\n referencedForeignKeys = dbForeignKeys.map((dbForeignKey) => {\n const foreignKeys = dbForeignKeys.filter(\n (dbFk) =>\n dbFk[\"CONSTRAINT_NAME\"] ===\n dbForeignKey[\"CONSTRAINT_NAME\"],\n )\n\n referencedForeignKeyTableMapping.push({\n tableName: `${dbForeignKey[\"SCHEMA_NAME\"]}.${dbForeignKey[\"TABLE_NAME\"]}`,\n fkName: dbForeignKey[\"CONSTRAINT_NAME\"],\n })\n return new TableForeignKey({\n name: dbForeignKey[\"CONSTRAINT_NAME\"],\n columnNames: foreignKeys.map((dbFk) => dbFk[\"COLUMN_NAME\"]),\n referencedDatabase: newTable.database,\n referencedSchema: newTable.schema,\n referencedTableName: newTable.name, // we use renamed table name\n referencedColumnNames: foreignKeys.map(\n (dbFk) => dbFk[\"REFERENCED_COLUMN_NAME\"],\n ),\n onDelete:\n dbForeignKey[\"DELETE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"DELETE_RULE\"],\n onUpdate:\n dbForeignKey[\"UPDATE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"UPDATE_RULE\"],\n deferrable: dbForeignKey[\"CHECK_TIME\"].replace(\"_\", \" \"), // \"CHECK_TIME\" is \"INITIALLY_IMMEDIATE\" or \"INITIALLY DEFERRED\"\n })\n })\n\n // drop referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.createForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n }\n\n // rename primary key constraint\n if (newTable.primaryColumns.length > 0) {\n const columnNames = newTable.primaryColumns.map(\n (column) => column.name,\n )\n const columnNamesString = columnNames\n .map((columnName) => `\"${columnName}\"`)\n .join(\", \")\n\n const oldPkName = this.connection.namingStrategy.primaryKeyName(\n oldTable,\n columnNames,\n )\n const newPkName = this.connection.namingStrategy.primaryKeyName(\n newTable,\n columnNames,\n )\n\n // drop old PK\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n newTable,\n )} DROP CONSTRAINT \"${oldPkName}\"`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n newTable,\n )} ADD CONSTRAINT \"${oldPkName}\" PRIMARY KEY (${columnNamesString})`,\n ),\n )\n\n // create new PK\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n newTable,\n )} ADD CONSTRAINT \"${newPkName}\" PRIMARY KEY (${columnNamesString})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n newTable,\n )} DROP CONSTRAINT \"${newPkName}\"`,\n ),\n )\n }\n\n // recreate foreign keys with new constraint names\n newTable.foreignKeys.forEach((foreignKey) => {\n // replace constraint name\n foreignKey.name = this.connection.namingStrategy.foreignKeyName(\n newTable,\n foreignKey.columnNames,\n this.getTablePath(foreignKey),\n foreignKey.referencedColumnNames,\n )\n\n // create new FK's\n upQueries.push(this.createForeignKeySql(newTable, foreignKey))\n downQueries.push(this.dropForeignKeySql(newTable, foreignKey))\n })\n\n // restore referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.createForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n\n // rename index constraints\n newTable.indices.forEach((index) => {\n // build new constraint name\n const newIndexName = this.connection.namingStrategy.indexName(\n newTable,\n index.columnNames,\n index.where,\n )\n\n // drop old index\n upQueries.push(this.dropIndexSql(newTable, index))\n downQueries.push(this.createIndexSql(newTable, index))\n\n // replace constraint name\n index.name = newIndexName\n\n // create new index\n upQueries.push(this.createIndexSql(newTable, index))\n downQueries.push(this.dropIndexSql(newTable, index))\n })\n\n await this.executeQueries(upQueries, downQueries)\n\n // rename old table and replace it in cached tabled;\n oldTable.name = newTable.name\n this.replaceCachedTable(oldTable, newTable)\n }\n\n /**\n * Creates a new column from the column in the table.\n */\n async addColumn(\n tableOrName: Table | string,\n column: TableColumn,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const parsedTableName = this.driver.parseTableName(table)\n\n if (!parsedTableName.schema) {\n parsedTableName.schema = await this.getCurrentSchema()\n }\n\n const clonedTable = table.clone()\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n\n upQueries.push(new Query(this.addColumnSql(table, column)))\n downQueries.push(new Query(this.dropColumnSql(table, column)))\n\n // create or update primary key constraint\n if (column.isPrimary) {\n const primaryColumns = clonedTable.primaryColumns\n // if table already have primary key, me must drop it and recreate again\n if (primaryColumns.length > 0) {\n // SAP HANA does not allow to drop PK's which is referenced by foreign keys.\n // To avoid this, we must drop all referential foreign keys and recreate them later\n const referencedForeignKeySql = `SELECT * FROM \"SYS\".\"REFERENTIAL_CONSTRAINTS\" WHERE \"REFERENCED_SCHEMA_NAME\" = '${parsedTableName.schema}' AND \"REFERENCED_TABLE_NAME\" = '${parsedTableName.tableName}'`\n const dbForeignKeys: ObjectLiteral[] = await this.query(\n referencedForeignKeySql,\n )\n let referencedForeignKeys: TableForeignKey[] = []\n const referencedForeignKeyTableMapping: {\n tableName: string\n fkName: string\n }[] = []\n if (dbForeignKeys.length > 0) {\n referencedForeignKeys = dbForeignKeys.map(\n (dbForeignKey) => {\n const foreignKeys = dbForeignKeys.filter(\n (dbFk) =>\n dbFk[\"CONSTRAINT_NAME\"] ===\n dbForeignKey[\"CONSTRAINT_NAME\"],\n )\n\n referencedForeignKeyTableMapping.push({\n tableName: `${dbForeignKey[\"SCHEMA_NAME\"]}.${dbForeignKey[\"TABLE_NAME\"]}`,\n fkName: dbForeignKey[\"CONSTRAINT_NAME\"],\n })\n return new TableForeignKey({\n name: dbForeignKey[\"CONSTRAINT_NAME\"],\n columnNames: foreignKeys.map(\n (dbFk) => dbFk[\"COLUMN_NAME\"],\n ),\n referencedDatabase: table.database,\n referencedSchema: table.schema,\n referencedTableName: table.name,\n referencedColumnNames: foreignKeys.map(\n (dbFk) => dbFk[\"REFERENCED_COLUMN_NAME\"],\n ),\n onDelete:\n dbForeignKey[\"DELETE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"DELETE_RULE\"],\n onUpdate:\n dbForeignKey[\"UPDATE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"UPDATE_RULE\"],\n deferrable: dbForeignKey[\"CHECK_TIME\"].replace(\n \"_\",\n \" \",\n ),\n })\n },\n )\n\n // drop referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.dropForeignKeySql(\n mapping!.tableName,\n foreignKey,\n ),\n )\n downQueries.push(\n this.createForeignKeySql(\n mapping!.tableName,\n foreignKey,\n ),\n )\n })\n }\n\n const pkName = this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n primaryColumns.map((column) => column.name),\n )\n const columnNames = primaryColumns\n .map((column) => `\"${column.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNames})`,\n ),\n )\n\n // restore referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.createForeignKeySql(\n mapping!.tableName,\n foreignKey,\n ),\n )\n downQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n }\n\n primaryColumns.push(column)\n const pkName = this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n primaryColumns.map((column) => column.name),\n )\n const columnNames = primaryColumns\n .map((column) => `\"${column.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNames})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n }\n\n // create column index\n const columnIndex = clonedTable.indices.find(\n (index) =>\n index.columnNames.length === 1 &&\n index.columnNames[0] === column.name,\n )\n if (columnIndex) {\n upQueries.push(this.createIndexSql(table, columnIndex))\n downQueries.push(this.dropIndexSql(table, columnIndex))\n } else if (column.isUnique) {\n const uniqueIndex = new TableIndex({\n name: this.connection.namingStrategy.indexName(table, [\n column.name,\n ]),\n columnNames: [column.name],\n isUnique: true,\n })\n clonedTable.indices.push(uniqueIndex)\n clonedTable.uniques.push(\n new TableUnique({\n name: uniqueIndex.name,\n columnNames: uniqueIndex.columnNames,\n }),\n )\n upQueries.push(this.createIndexSql(table, uniqueIndex))\n downQueries.push(this.dropIndexSql(table, uniqueIndex))\n }\n\n await this.executeQueries(upQueries, downQueries)\n\n clonedTable.addColumn(column)\n this.replaceCachedTable(table, clonedTable)\n }\n\n /**\n * Creates a new columns from the column in the table.\n */\n async addColumns(\n tableOrName: Table | string,\n columns: TableColumn[],\n ): Promise<void> {\n for (const column of columns) {\n await this.addColumn(tableOrName, column)\n }\n }\n\n /**\n * Renames column in the given table.\n */\n async renameColumn(\n tableOrName: Table | string,\n oldTableColumnOrName: TableColumn | string,\n newTableColumnOrName: TableColumn | string,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const oldColumn = InstanceChecker.isTableColumn(oldTableColumnOrName)\n ? oldTableColumnOrName\n : table.columns.find((c) => c.name === oldTableColumnOrName)\n if (!oldColumn)\n throw new TypeORMError(\n `Column \"${oldTableColumnOrName}\" was not found in the \"${table.name}\" table.`,\n )\n\n let newColumn: TableColumn | undefined = undefined\n if (InstanceChecker.isTableColumn(newTableColumnOrName)) {\n newColumn = newTableColumnOrName\n } else {\n newColumn = oldColumn.clone()\n newColumn.name = newTableColumnOrName\n }\n\n await this.changeColumn(table, oldColumn, newColumn)\n }\n\n /**\n * Changes a column in the table.\n */\n async changeColumn(\n tableOrName: Table | string,\n oldTableColumnOrName: TableColumn | string,\n newColumn: TableColumn,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n let clonedTable = table.clone()\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n\n const oldColumn = InstanceChecker.isTableColumn(oldTableColumnOrName)\n ? oldTableColumnOrName\n : table.columns.find(\n (column) => column.name === oldTableColumnOrName,\n )\n if (!oldColumn)\n throw new TypeORMError(\n `Column \"${oldTableColumnOrName}\" was not found in the \"${table.name}\" table.`,\n )\n\n if (\n (newColumn.isGenerated !== oldColumn.isGenerated &&\n newColumn.generationStrategy !== \"uuid\") ||\n newColumn.type !== oldColumn.type ||\n newColumn.length !== oldColumn.length\n ) {\n // SQL Server does not support changing of IDENTITY column, so we must drop column and recreate it again.\n // Also, we recreate column if column type changed\n await this.dropColumn(table, oldColumn)\n await this.addColumn(table, newColumn)\n\n // update cloned table\n clonedTable = table.clone()\n } else {\n if (newColumn.name !== oldColumn.name) {\n // rename column\n upQueries.push(\n new Query(\n `RENAME COLUMN ${this.escapePath(table)}.\"${\n oldColumn.name\n }\" TO \"${newColumn.name}\"`,\n ),\n )\n downQueries.push(\n new Query(\n `RENAME COLUMN ${this.escapePath(table)}.\"${\n newColumn.name\n }\" TO \"${oldColumn.name}\"`,\n ),\n )\n\n if (oldColumn.isPrimary === true) {\n const primaryColumns = clonedTable.primaryColumns\n\n // build old primary constraint name\n const columnNames = primaryColumns.map(\n (column) => column.name,\n )\n const oldPkName =\n this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n columnNames,\n )\n\n // replace old column name with new column name\n columnNames.splice(columnNames.indexOf(oldColumn.name), 1)\n columnNames.push(newColumn.name)\n const columnNamesString = columnNames\n .map((columnName) => `\"${columnName}\"`)\n .join(\", \")\n\n // drop old PK\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} DROP CONSTRAINT \"${oldPkName}\"`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} ADD CONSTRAINT \"${oldPkName}\" PRIMARY KEY (${columnNamesString})`,\n ),\n )\n\n // build new primary constraint name\n const newPkName =\n this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n columnNames,\n )\n\n // create new PK\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} ADD CONSTRAINT \"${newPkName}\" PRIMARY KEY (${columnNamesString})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} DROP CONSTRAINT \"${newPkName}\"`,\n ),\n )\n }\n\n // rename index constraints\n clonedTable.findColumnIndices(oldColumn).forEach((index) => {\n // build new constraint name\n index.columnNames.splice(\n index.columnNames.indexOf(oldColumn.name),\n 1,\n )\n index.columnNames.push(newColumn.name)\n const newIndexName =\n this.connection.namingStrategy.indexName(\n clonedTable,\n index.columnNames,\n index.where,\n )\n\n // drop old index\n upQueries.push(this.dropIndexSql(clonedTable, index))\n downQueries.push(this.createIndexSql(clonedTable, index))\n\n // replace constraint name\n index.name = newIndexName\n\n // create new index\n upQueries.push(this.createIndexSql(clonedTable, index))\n downQueries.push(this.dropIndexSql(clonedTable, index))\n })\n\n // rename foreign key constraints\n clonedTable\n .findColumnForeignKeys(oldColumn)\n .forEach((foreignKey) => {\n // build new constraint name\n foreignKey.columnNames.splice(\n foreignKey.columnNames.indexOf(oldColumn.name),\n 1,\n )\n foreignKey.columnNames.push(newColumn.name)\n const newForeignKeyName =\n this.connection.namingStrategy.foreignKeyName(\n clonedTable,\n foreignKey.columnNames,\n this.getTablePath(foreignKey),\n foreignKey.referencedColumnNames,\n )\n\n upQueries.push(\n this.dropForeignKeySql(clonedTable, foreignKey),\n )\n downQueries.push(\n this.createForeignKeySql(clonedTable, foreignKey),\n )\n\n // replace constraint name\n foreignKey.name = newForeignKeyName\n\n // create new FK's\n upQueries.push(\n this.createForeignKeySql(clonedTable, foreignKey),\n )\n downQueries.push(\n this.dropForeignKeySql(clonedTable, foreignKey),\n )\n })\n\n // rename check constraints\n clonedTable.findColumnChecks(oldColumn).forEach((check) => {\n // build new constraint name\n check.columnNames!.splice(\n check.columnNames!.indexOf(oldColumn.name),\n 1,\n )\n check.columnNames!.push(newColumn.name)\n const newCheckName =\n this.connection.namingStrategy.checkConstraintName(\n clonedTable,\n check.expression!,\n )\n\n upQueries.push(\n this.dropCheckConstraintSql(clonedTable, check),\n )\n downQueries.push(\n this.createCheckConstraintSql(clonedTable, check),\n )\n\n // replace constraint name\n check.name = newCheckName\n\n upQueries.push(\n this.createCheckConstraintSql(clonedTable, check),\n )\n downQueries.push(\n this.dropCheckConstraintSql(clonedTable, check),\n )\n })\n\n // rename old column in the Table object\n const oldTableColumn = clonedTable.columns.find(\n (column) => column.name === oldColumn.name,\n )\n clonedTable.columns[\n clonedTable.columns.indexOf(oldTableColumn!)\n ].name = newColumn.name\n oldColumn.name = newColumn.name\n }\n\n if (this.isColumnChanged(oldColumn, newColumn)) {\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ALTER (${this.buildCreateColumnSql(newColumn)})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ALTER (${this.buildCreateColumnSql(oldColumn)})`,\n ),\n )\n }\n\n if (newColumn.isPrimary !== oldColumn.isPrimary) {\n const primaryColumns = clonedTable.primaryColumns\n\n // if primary column state changed, we must always drop existed constraint.\n if (primaryColumns.length > 0) {\n const pkName =\n this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n primaryColumns.map((column) => column.name),\n )\n const columnNames = primaryColumns\n .map((column) => `\"${column.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNames})`,\n ),\n )\n }\n\n if (newColumn.isPrimary === true) {\n primaryColumns.push(newColumn)\n // update column in table\n const column = clonedTable.columns.find(\n (column) => column.name === newColumn.name,\n )\n column!.isPrimary = true\n const pkName =\n this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n primaryColumns.map((column) => column.name),\n )\n const columnNames = primaryColumns\n .map((column) => `\"${column.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNames})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n } else {\n const primaryColumn = primaryColumns.find(\n (c) => c.name === newColumn.name,\n )\n primaryColumns.splice(\n primaryColumns.indexOf(primaryColumn!),\n 1,\n )\n\n // update column in table\n const column = clonedTable.columns.find(\n (column) => column.name === newColumn.name,\n )\n column!.isPrimary = false\n\n // if we have another primary keys, we must recreate constraint.\n if (primaryColumns.length > 0) {\n const pkName =\n this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n primaryColumns.map((column) => column.name),\n )\n const columnNames = primaryColumns\n .map((column) => `\"${column.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNames})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n }\n }\n }\n\n if (newColumn.isUnique !== oldColumn.isUnique) {\n if (newColumn.isUnique === true) {\n const uniqueIndex = new TableIndex({\n name: this.connection.namingStrategy.indexName(table, [\n newColumn.name,\n ]),\n columnNames: [newColumn.name],\n isUnique: true,\n })\n clonedTable.indices.push(uniqueIndex)\n clonedTable.uniques.push(\n new TableUnique({\n name: uniqueIndex.name,\n columnNames: uniqueIndex.columnNames,\n }),\n )\n upQueries.push(this.createIndexSql(table, uniqueIndex))\n downQueries.push(this.dropIndexSql(table, uniqueIndex))\n } else {\n const uniqueIndex = clonedTable.indices.find((index) => {\n return (\n index.columnNames.length === 1 &&\n index.isUnique === true &&\n !!index.columnNames.find(\n (columnName) => columnName === newColumn.name,\n )\n )\n })\n clonedTable.indices.splice(\n clonedTable.indices.indexOf(uniqueIndex!),\n 1,\n )\n\n const tableUnique = clonedTable.uniques.find(\n (unique) => unique.name === uniqueIndex!.name,\n )\n clonedTable.uniques.splice(\n clonedTable.uniques.indexOf(tableUnique!),\n 1,\n )\n\n upQueries.push(this.dropIndexSql(table, uniqueIndex!))\n downQueries.push(this.createIndexSql(table, uniqueIndex!))\n }\n }\n\n if (newColumn.default !== oldColumn.default) {\n if (\n newColumn.default !== null &&\n newColumn.default !== undefined\n ) {\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(table)} ALTER (\"${\n newColumn.name\n }\" ${this.connection.driver.createFullType(\n newColumn,\n )} DEFAULT ${newColumn.default})`,\n ),\n )\n\n if (\n oldColumn.default !== null &&\n oldColumn.default !== undefined\n ) {\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ALTER (\"${\n oldColumn.name\n }\" ${this.connection.driver.createFullType(\n oldColumn,\n )} DEFAULT ${oldColumn.default})`,\n ),\n )\n } else {\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ALTER (\"${\n oldColumn.name\n }\" ${this.connection.driver.createFullType(\n oldColumn,\n )} DEFAULT NULL)`,\n ),\n )\n }\n } else if (\n oldColumn.default !== null &&\n oldColumn.default !== undefined\n ) {\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(table)} ALTER (\"${\n newColumn.name\n }\" ${this.connection.driver.createFullType(\n newColumn,\n )} DEFAULT NULL)`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(table)} ALTER (\"${\n oldColumn.name\n }\" ${this.connection.driver.createFullType(\n oldColumn,\n )} DEFAULT ${oldColumn.default})`,\n ),\n )\n }\n }\n\n await this.executeQueries(upQueries, downQueries)\n this.replaceCachedTable(table, clonedTable)\n }\n }\n\n /**\n * Changes a column in the table.\n */\n async changeColumns(\n tableOrName: Table | string,\n changedColumns: { newColumn: TableColumn; oldColumn: TableColumn }[],\n ): Promise<void> {\n for (const { oldColumn, newColumn } of changedColumns) {\n await this.changeColumn(tableOrName, oldColumn, newColumn)\n }\n }\n\n /**\n * Drops column in the table.\n */\n async dropColumn(\n tableOrName: Table | string,\n columnOrName: TableColumn | string,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const parsedTableName = this.driver.parseTableName(table)\n\n if (!parsedTableName.schema) {\n parsedTableName.schema = await this.getCurrentSchema()\n }\n\n const column = InstanceChecker.isTableColumn(columnOrName)\n ? columnOrName\n : table.findColumnByName(columnOrName)\n if (!column)\n throw new TypeORMError(\n `Column \"${columnOrName}\" was not found in table \"${table.name}\"`,\n )\n\n const clonedTable = table.clone()\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n\n // drop primary key constraint\n if (column.isPrimary) {\n // SAP HANA does not allow to drop PK's which is referenced by foreign keys.\n // To avoid this, we must drop all referential foreign keys and recreate them later\n const referencedForeignKeySql = `SELECT * FROM \"SYS\".\"REFERENTIAL_CONSTRAINTS\" WHERE \"REFERENCED_SCHEMA_NAME\" = '${parsedTableName.schema}' AND \"REFERENCED_TABLE_NAME\" = '${parsedTableName.tableName}'`\n const dbForeignKeys: ObjectLiteral[] = await this.query(\n referencedForeignKeySql,\n )\n let referencedForeignKeys: TableForeignKey[] = []\n const referencedForeignKeyTableMapping: {\n tableName: string\n fkName: string\n }[] = []\n if (dbForeignKeys.length > 0) {\n referencedForeignKeys = dbForeignKeys.map((dbForeignKey) => {\n const foreignKeys = dbForeignKeys.filter(\n (dbFk) =>\n dbFk[\"CONSTRAINT_NAME\"] ===\n dbForeignKey[\"CONSTRAINT_NAME\"],\n )\n\n referencedForeignKeyTableMapping.push({\n tableName: `${dbForeignKey[\"SCHEMA_NAME\"]}.${dbForeignKey[\"TABLE_NAME\"]}`,\n fkName: dbForeignKey[\"CONSTRAINT_NAME\"],\n })\n return new TableForeignKey({\n name: dbForeignKey[\"CONSTRAINT_NAME\"],\n columnNames: foreignKeys.map(\n (dbFk) => dbFk[\"COLUMN_NAME\"],\n ),\n referencedDatabase: table.database,\n referencedSchema: table.schema,\n referencedTableName: table.name,\n referencedColumnNames: foreignKeys.map(\n (dbFk) => dbFk[\"REFERENCED_COLUMN_NAME\"],\n ),\n onDelete:\n dbForeignKey[\"DELETE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"DELETE_RULE\"],\n onUpdate:\n dbForeignKey[\"UPDATE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"UPDATE_RULE\"],\n deferrable: dbForeignKey[\"CHECK_TIME\"].replace(\n \"_\",\n \" \",\n ),\n })\n })\n\n // drop referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.createForeignKeySql(\n mapping!.tableName,\n foreignKey,\n ),\n )\n })\n }\n\n const pkName = this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n clonedTable.primaryColumns.map((column) => column.name),\n )\n const columnNames = clonedTable.primaryColumns\n .map((primaryColumn) => `\"${primaryColumn.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNames})`,\n ),\n )\n\n // update column in table\n const tableColumn = clonedTable.findColumnByName(column.name)\n tableColumn!.isPrimary = false\n\n // if primary key have multiple columns, we must recreate it without dropped column\n if (clonedTable.primaryColumns.length > 0) {\n const pkName = this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n clonedTable.primaryColumns.map((column) => column.name),\n )\n const columnNames = clonedTable.primaryColumns\n .map((primaryColumn) => `\"${primaryColumn.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNames})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n clonedTable,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n }\n\n // restore referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.createForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n }\n\n // drop column index\n const columnIndex = clonedTable.indices.find(\n (index) =>\n index.columnNames.length === 1 &&\n index.columnNames[0] === column.name,\n )\n if (columnIndex) {\n clonedTable.indices.splice(\n clonedTable.indices.indexOf(columnIndex),\n 1,\n )\n upQueries.push(this.dropIndexSql(table, columnIndex))\n downQueries.push(this.createIndexSql(table, columnIndex))\n } else if (column.isUnique) {\n // we splice constraints both from table uniques and indices.\n const uniqueName =\n this.connection.namingStrategy.uniqueConstraintName(table, [\n column.name,\n ])\n const foundUnique = clonedTable.uniques.find(\n (unique) => unique.name === uniqueName,\n )\n if (foundUnique) {\n clonedTable.uniques.splice(\n clonedTable.uniques.indexOf(foundUnique),\n 1,\n )\n upQueries.push(this.dropIndexSql(table, uniqueName))\n downQueries.push(\n new Query(\n `CREATE UNIQUE INDEX \"${uniqueName}\" ON ${this.escapePath(\n table,\n )} (\"${column.name}\")`,\n ),\n )\n }\n\n const indexName = this.connection.namingStrategy.indexName(table, [\n column.name,\n ])\n const foundIndex = clonedTable.indices.find(\n (index) => index.name === indexName,\n )\n if (foundIndex) {\n clonedTable.indices.splice(\n clonedTable.indices.indexOf(foundIndex),\n 1,\n )\n upQueries.push(this.dropIndexSql(table, indexName))\n downQueries.push(\n new Query(\n `CREATE UNIQUE INDEX \"${indexName}\" ON ${this.escapePath(\n table,\n )} (\"${column.name}\")`,\n ),\n )\n }\n }\n\n // drop column check\n const columnCheck = clonedTable.checks.find(\n (check) =>\n !!check.columnNames &&\n check.columnNames.length === 1 &&\n check.columnNames[0] === column.name,\n )\n if (columnCheck) {\n clonedTable.checks.splice(\n clonedTable.checks.indexOf(columnCheck),\n 1,\n )\n upQueries.push(this.dropCheckConstraintSql(table, columnCheck))\n downQueries.push(this.createCheckConstraintSql(table, columnCheck))\n }\n\n upQueries.push(new Query(this.dropColumnSql(table, column)))\n downQueries.push(new Query(this.addColumnSql(table, column)))\n\n await this.executeQueries(upQueries, downQueries)\n\n clonedTable.removeColumn(column)\n this.replaceCachedTable(table, clonedTable)\n }\n\n /**\n * Drops the columns in the table.\n */\n async dropColumns(\n tableOrName: Table | string,\n columns: TableColumn[] | string[],\n ): Promise<void> {\n for (const column of columns) {\n await this.dropColumn(tableOrName, column)\n }\n }\n\n /**\n * Creates a new primary key.\n */\n async createPrimaryKey(\n tableOrName: Table | string,\n columnNames: string[],\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const clonedTable = table.clone()\n\n const up = this.createPrimaryKeySql(table, columnNames)\n\n // mark columns as primary, because dropPrimaryKeySql build constraint name from table primary column names.\n clonedTable.columns.forEach((column) => {\n if (columnNames.find((columnName) => columnName === column.name))\n column.isPrimary = true\n })\n const down = this.dropPrimaryKeySql(clonedTable)\n\n await this.executeQueries(up, down)\n this.replaceCachedTable(table, clonedTable)\n }\n\n /**\n * Updates composite primary keys.\n */\n async updatePrimaryKeys(\n tableOrName: Table | string,\n columns: TableColumn[],\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const parsedTableName = this.driver.parseTableName(table)\n\n if (!parsedTableName.schema) {\n parsedTableName.schema = await this.getCurrentSchema()\n }\n\n const clonedTable = table.clone()\n const columnNames = columns.map((column) => column.name)\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n\n // SAP HANA does not allow to drop PK's which is referenced by foreign keys.\n // To avoid this, we must drop all referential foreign keys and recreate them later\n const referencedForeignKeySql = `SELECT * FROM \"SYS\".\"REFERENTIAL_CONSTRAINTS\" WHERE \"REFERENCED_SCHEMA_NAME\" = '${parsedTableName.schema}' AND \"REFERENCED_TABLE_NAME\" = '${parsedTableName.tableName}'`\n const dbForeignKeys: ObjectLiteral[] = await this.query(\n referencedForeignKeySql,\n )\n let referencedForeignKeys: TableForeignKey[] = []\n const referencedForeignKeyTableMapping: {\n tableName: string\n fkName: string\n }[] = []\n if (dbForeignKeys.length > 0) {\n referencedForeignKeys = dbForeignKeys.map((dbForeignKey) => {\n const foreignKeys = dbForeignKeys.filter(\n (dbFk) =>\n dbFk[\"CONSTRAINT_NAME\"] ===\n dbForeignKey[\"CONSTRAINT_NAME\"],\n )\n\n referencedForeignKeyTableMapping.push({\n tableName: `${dbForeignKey[\"SCHEMA_NAME\"]}.${dbForeignKey[\"TABLE_NAME\"]}`,\n fkName: dbForeignKey[\"CONSTRAINT_NAME\"],\n })\n return new TableForeignKey({\n name: dbForeignKey[\"CONSTRAINT_NAME\"],\n columnNames: foreignKeys.map((dbFk) => dbFk[\"COLUMN_NAME\"]),\n referencedDatabase: table.database,\n referencedSchema: table.schema,\n referencedTableName: table.name,\n referencedColumnNames: foreignKeys.map(\n (dbFk) => dbFk[\"REFERENCED_COLUMN_NAME\"],\n ),\n onDelete:\n dbForeignKey[\"DELETE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"DELETE_RULE\"],\n onUpdate:\n dbForeignKey[\"UPDATE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"UPDATE_RULE\"],\n deferrable: dbForeignKey[\"CHECK_TIME\"].replace(\"_\", \" \"),\n })\n })\n\n // drop referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.createForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n }\n\n // if table already have primary columns, we must drop them.\n const primaryColumns = clonedTable.primaryColumns\n if (primaryColumns.length > 0) {\n const pkName = this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n primaryColumns.map((column) => column.name),\n )\n const columnNamesString = primaryColumns\n .map((column) => `\"${column.name}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNamesString})`,\n ),\n )\n }\n\n // update columns in table.\n clonedTable.columns\n .filter((column) => columnNames.indexOf(column.name) !== -1)\n .forEach((column) => (column.isPrimary = true))\n\n const pkName = this.connection.namingStrategy.primaryKeyName(\n clonedTable,\n columnNames,\n )\n const columnNamesString = columnNames\n .map((columnName) => `\"${columnName}\"`)\n .join(\", \")\n upQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${pkName}\" PRIMARY KEY (${columnNamesString})`,\n ),\n )\n downQueries.push(\n new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${pkName}\"`,\n ),\n )\n\n // restore referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.createForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n\n await this.executeQueries(upQueries, downQueries)\n this.replaceCachedTable(table, clonedTable)\n }\n\n /**\n * Drops a primary key.\n */\n async dropPrimaryKey(tableOrName: Table | string): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const parsedTableName = this.driver.parseTableName(table)\n\n if (!parsedTableName.schema) {\n parsedTableName.schema = await this.getCurrentSchema()\n }\n\n const upQueries: Query[] = []\n const downQueries: Query[] = []\n\n // SAP HANA does not allow to drop PK's which is referenced by foreign keys.\n // To avoid this, we must drop all referential foreign keys and recreate them later\n const referencedForeignKeySql = `SELECT * FROM \"SYS\".\"REFERENTIAL_CONSTRAINTS\" WHERE \"REFERENCED_SCHEMA_NAME\" = '${parsedTableName.schema}' AND \"REFERENCED_TABLE_NAME\" = '${parsedTableName.tableName}'`\n const dbForeignKeys: ObjectLiteral[] = await this.query(\n referencedForeignKeySql,\n )\n let referencedForeignKeys: TableForeignKey[] = []\n const referencedForeignKeyTableMapping: {\n tableName: string\n fkName: string\n }[] = []\n if (dbForeignKeys.length > 0) {\n referencedForeignKeys = dbForeignKeys.map((dbForeignKey) => {\n const foreignKeys = dbForeignKeys.filter(\n (dbFk) =>\n dbFk[\"CONSTRAINT_NAME\"] ===\n dbForeignKey[\"CONSTRAINT_NAME\"],\n )\n\n referencedForeignKeyTableMapping.push({\n tableName: `${dbForeignKey[\"SCHEMA_NAME\"]}.${dbForeignKey[\"TABLE_NAME\"]}`,\n fkName: dbForeignKey[\"CONSTRAINT_NAME\"],\n })\n return new TableForeignKey({\n name: dbForeignKey[\"CONSTRAINT_NAME\"],\n columnNames: foreignKeys.map((dbFk) => dbFk[\"COLUMN_NAME\"]),\n referencedDatabase: table.database,\n referencedSchema: table.schema,\n referencedTableName: table.name,\n referencedColumnNames: foreignKeys.map(\n (dbFk) => dbFk[\"REFERENCED_COLUMN_NAME\"],\n ),\n onDelete:\n dbForeignKey[\"DELETE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"DELETE_RULE\"],\n onUpdate:\n dbForeignKey[\"UPDATE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"UPDATE_RULE\"],\n deferrable: dbForeignKey[\"CHECK_TIME\"].replace(\"_\", \" \"),\n })\n })\n\n // drop referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.createForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n }\n\n upQueries.push(this.dropPrimaryKeySql(table))\n downQueries.push(\n this.createPrimaryKeySql(\n table,\n table.primaryColumns.map((column) => column.name),\n ),\n )\n\n // restore referenced foreign keys\n referencedForeignKeys.forEach((foreignKey) => {\n const mapping = referencedForeignKeyTableMapping.find(\n (it) => it.fkName === foreignKey.name,\n )\n upQueries.push(\n this.createForeignKeySql(mapping!.tableName, foreignKey),\n )\n downQueries.push(\n this.dropForeignKeySql(mapping!.tableName, foreignKey),\n )\n })\n\n await this.executeQueries(upQueries, downQueries)\n table.primaryColumns.forEach((column) => {\n column.isPrimary = false\n })\n }\n\n /**\n * Creates a new unique constraint.\n */\n async createUniqueConstraint(\n tableOrName: Table | string,\n uniqueConstraint: TableUnique,\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support unique constraints. Use unique index instead.`,\n )\n }\n\n /**\n * Creates a new unique constraints.\n */\n async createUniqueConstraints(\n tableOrName: Table | string,\n uniqueConstraints: TableUnique[],\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support unique constraints. Use unique index instead.`,\n )\n }\n\n /**\n * Drops unique constraint.\n */\n async dropUniqueConstraint(\n tableOrName: Table | string,\n uniqueOrName: TableUnique | string,\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support unique constraints. Use unique index instead.`,\n )\n }\n\n /**\n * Drops an unique constraints.\n */\n async dropUniqueConstraints(\n tableOrName: Table | string,\n uniqueConstraints: TableUnique[],\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support unique constraints. Use unique index instead.`,\n )\n }\n\n /**\n * Creates a new check constraint.\n */\n async createCheckConstraint(\n tableOrName: Table | string,\n checkConstraint: TableCheck,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n\n // new unique constraint may be passed without name. In this case we generate unique name manually.\n if (!checkConstraint.name)\n checkConstraint.name =\n this.connection.namingStrategy.checkConstraintName(\n table,\n checkConstraint.expression!,\n )\n\n const up = this.createCheckConstraintSql(table, checkConstraint)\n const down = this.dropCheckConstraintSql(table, checkConstraint)\n await this.executeQueries(up, down)\n table.addCheckConstraint(checkConstraint)\n }\n\n /**\n * Creates a new check constraints.\n */\n async createCheckConstraints(\n tableOrName: Table | string,\n checkConstraints: TableCheck[],\n ): Promise<void> {\n const promises = checkConstraints.map((checkConstraint) =>\n this.createCheckConstraint(tableOrName, checkConstraint),\n )\n await Promise.all(promises)\n }\n\n /**\n * Drops check constraint.\n */\n async dropCheckConstraint(\n tableOrName: Table | string,\n checkOrName: TableCheck | string,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const checkConstraint = InstanceChecker.isTableCheck(checkOrName)\n ? checkOrName\n : table.checks.find((c) => c.name === checkOrName)\n if (!checkConstraint)\n throw new TypeORMError(\n `Supplied check constraint was not found in table ${table.name}`,\n )\n\n const up = this.dropCheckConstraintSql(table, checkConstraint)\n const down = this.createCheckConstraintSql(table, checkConstraint)\n await this.executeQueries(up, down)\n table.removeCheckConstraint(checkConstraint)\n }\n\n /**\n * Drops check constraints.\n */\n async dropCheckConstraints(\n tableOrName: Table | string,\n checkConstraints: TableCheck[],\n ): Promise<void> {\n const promises = checkConstraints.map((checkConstraint) =>\n this.dropCheckConstraint(tableOrName, checkConstraint),\n )\n await Promise.all(promises)\n }\n\n /**\n * Creates a new exclusion constraint.\n */\n async createExclusionConstraint(\n tableOrName: Table | string,\n exclusionConstraint: TableExclusion,\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support exclusion constraints.`,\n )\n }\n\n /**\n * Creates a new exclusion constraints.\n */\n async createExclusionConstraints(\n tableOrName: Table | string,\n exclusionConstraints: TableExclusion[],\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support exclusion constraints.`,\n )\n }\n\n /**\n * Drops exclusion constraint.\n */\n async dropExclusionConstraint(\n tableOrName: Table | string,\n exclusionOrName: TableExclusion | string,\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support exclusion constraints.`,\n )\n }\n\n /**\n * Drops exclusion constraints.\n */\n async dropExclusionConstraints(\n tableOrName: Table | string,\n exclusionConstraints: TableExclusion[],\n ): Promise<void> {\n throw new TypeORMError(\n `SAP HANA does not support exclusion constraints.`,\n )\n }\n\n /**\n * Creates a new foreign key.\n */\n async createForeignKey(\n tableOrName: Table | string,\n foreignKey: TableForeignKey,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n\n // new FK may be passed without name. In this case we generate FK name manually.\n if (!foreignKey.name)\n foreignKey.name = this.connection.namingStrategy.foreignKeyName(\n table,\n foreignKey.columnNames,\n this.getTablePath(foreignKey),\n foreignKey.referencedColumnNames,\n )\n\n const up = this.createForeignKeySql(table, foreignKey)\n const down = this.dropForeignKeySql(table, foreignKey)\n await this.executeQueries(up, down)\n table.addForeignKey(foreignKey)\n }\n\n /**\n * Creates a new foreign keys.\n */\n async createForeignKeys(\n tableOrName: Table | string,\n foreignKeys: TableForeignKey[],\n ): Promise<void> {\n const promises = foreignKeys.map((foreignKey) =>\n this.createForeignKey(tableOrName, foreignKey),\n )\n await Promise.all(promises)\n }\n\n /**\n * Drops a foreign key from the table.\n */\n async dropForeignKey(\n tableOrName: Table | string,\n foreignKeyOrName: TableForeignKey | string,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const foreignKey = InstanceChecker.isTableForeignKey(foreignKeyOrName)\n ? foreignKeyOrName\n : table.foreignKeys.find((fk) => fk.name === foreignKeyOrName)\n if (!foreignKey)\n throw new TypeORMError(\n `Supplied foreign key was not found in table ${table.name}`,\n )\n\n const up = this.dropForeignKeySql(table, foreignKey)\n const down = this.createForeignKeySql(table, foreignKey)\n await this.executeQueries(up, down)\n table.removeForeignKey(foreignKey)\n }\n\n /**\n * Drops a foreign keys from the table.\n */\n async dropForeignKeys(\n tableOrName: Table | string,\n foreignKeys: TableForeignKey[],\n ): Promise<void> {\n const promises = foreignKeys.map((foreignKey) =>\n this.dropForeignKey(tableOrName, foreignKey),\n )\n await Promise.all(promises)\n }\n\n /**\n * Creates a new index.\n */\n async createIndex(\n tableOrName: Table | string,\n index: TableIndex,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n\n // new index may be passed without name. In this case we generate index name manually.\n if (!index.name) index.name = this.generateIndexName(table, index)\n\n const up = this.createIndexSql(table, index)\n const down = this.dropIndexSql(table, index)\n await this.executeQueries(up, down)\n table.addIndex(index)\n }\n\n /**\n * Creates a new indices\n */\n async createIndices(\n tableOrName: Table | string,\n indices: TableIndex[],\n ): Promise<void> {\n const promises = indices.map((index) =>\n this.createIndex(tableOrName, index),\n )\n await Promise.all(promises)\n }\n\n /**\n * Drops an index.\n */\n async dropIndex(\n tableOrName: Table | string,\n indexOrName: TableIndex | string,\n ): Promise<void> {\n const table = InstanceChecker.isTable(tableOrName)\n ? tableOrName\n : await this.getCachedTable(tableOrName)\n const index = InstanceChecker.isTableIndex(indexOrName)\n ? indexOrName\n : table.indices.find((i) => i.name === indexOrName)\n if (!index)\n throw new TypeORMError(\n `Supplied index ${indexOrName} was not found in table ${table.name}`,\n )\n\n // old index may be passed without name. In this case we generate index name manually.\n if (!index.name) index.name = this.generateIndexName(table, index)\n\n const up = this.dropIndexSql(table, index)\n const down = this.createIndexSql(table, index)\n await this.executeQueries(up, down)\n table.removeIndex(index)\n }\n\n /**\n * Drops an indices from the table.\n */\n async dropIndices(\n tableOrName: Table | string,\n indices: TableIndex[],\n ): Promise<void> {\n const promises = indices.map((index) =>\n this.dropIndex(tableOrName, index),\n )\n await Promise.all(promises)\n }\n\n /**\n * Clears all table contents.\n * Note: this operation uses SQL's TRUNCATE query which cannot be reverted in transactions.\n */\n async clearTable(tablePath: string): Promise<void> {\n await this.query(`TRUNCATE TABLE ${this.escapePath(tablePath)}`)\n }\n\n /**\n * Removes all tables from the currently connected database.\n */\n async clearDatabase(): Promise<void> {\n const schemas: string[] = []\n this.connection.entityMetadatas\n .filter((metadata) => metadata.schema)\n .forEach((metadata) => {\n const isSchemaExist = !!schemas.find(\n (schema) => schema === metadata.schema,\n )\n if (!isSchemaExist) schemas.push(metadata.schema!)\n })\n\n schemas.push(this.driver.options.schema || \"current_schema\")\n const schemaNamesString = schemas\n .map((name) => {\n return name === \"current_schema\" ? name : \"'\" + name + \"'\"\n })\n .join(\", \")\n\n const isAnotherTransactionActive = this.isTransactionActive\n if (!isAnotherTransactionActive) await this.startTransaction()\n try {\n // const selectViewDropsQuery = `SELECT 'DROP VIEW IF EXISTS \"' || schemaname || '\".\"' || viewname || '\" CASCADE;' as \"query\" ` +\n // `FROM \"pg_views\" WHERE \"schemaname\" IN (${schemaNamesString}) AND \"viewname\" NOT IN ('geography_columns', 'geometry_columns', 'raster_columns', 'raster_overviews')`;\n // const dropViewQueries: ObjectLiteral[] = await this.query(selectViewDropsQuery);\n // await Promise.all(dropViewQueries.map(q => this.query(q[\"query\"])));\n\n // ignore spatial_ref_sys; it's a special table supporting PostGIS\n const selectTableDropsQuery = `SELECT 'DROP TABLE \"' || schema_name || '\".\"' || table_name || '\" CASCADE;' as \"query\" FROM \"SYS\".\"TABLES\" WHERE \"SCHEMA_NAME\" IN (${schemaNamesString}) AND \"TABLE_NAME\" NOT IN ('SYS_AFL_GENERATOR_PARAMETERS') AND \"IS_COLUMN_TABLE\" = 'TRUE'`\n const dropTableQueries: ObjectLiteral[] = await this.query(\n selectTableDropsQuery,\n )\n await Promise.all(\n dropTableQueries.map((q) => this.query(q[\"query\"])),\n )\n\n if (!isAnotherTransactionActive) await this.commitTransaction()\n } catch (error) {\n try {\n // we throw original error even if rollback thrown an error\n if (!isAnotherTransactionActive)\n await this.rollbackTransaction()\n } catch (rollbackError) {}\n throw error\n }\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n protected async loadViews(viewNames?: string[]): Promise<View[]> {\n const hasTable = await this.hasTable(this.getTypeormMetadataTableName())\n if (!hasTable) {\n return []\n }\n\n if (!viewNames) {\n viewNames = []\n }\n\n const currentDatabase = await this.getCurrentDatabase()\n const currentSchema = await this.getCurrentSchema()\n\n const viewsCondition = viewNames\n .map((viewName) => {\n let { schema, tableName: name } =\n this.driver.parseTableName(viewName)\n\n if (!schema) {\n schema = currentSchema\n }\n\n return `(\"t\".\"schema\" = '${schema}' AND \"t\".\"name\" = '${name}')`\n })\n .join(\" OR \")\n\n const query = `SELECT \"t\".* FROM ${this.escapePath(\n this.getTypeormMetadataTableName(),\n )} \"t\" WHERE \"t\".\"type\" = '${MetadataTableType.VIEW}' ${\n viewsCondition ? `AND (${viewsCondition})` : \"\"\n }`\n const dbViews = await this.query(query)\n return dbViews.map((dbView: any) => {\n const view = new View()\n const schema =\n dbView[\"schema\"] === currentSchema &&\n !this.driver.options.schema\n ? undefined\n : dbView[\"schema\"]\n view.database = currentDatabase\n view.schema = dbView[\"schema\"]\n view.name = this.driver.buildTableName(dbView[\"name\"], schema)\n view.expression = dbView[\"value\"]\n return view\n })\n }\n\n /**\n * Loads all tables (with given names) from the database and creates a Table from them.\n */\n protected async loadTables(tableNames?: string[]): Promise<Table[]> {\n if (tableNames && tableNames.length === 0) {\n return []\n }\n\n const currentSchema = await this.getCurrentSchema()\n const currentDatabase = await this.getCurrentDatabase()\n\n const dbTables: { SCHEMA_NAME: string; TABLE_NAME: string }[] = []\n\n if (!tableNames) {\n const tablesSql = `SELECT \"SCHEMA_NAME\", \"TABLE_NAME\" FROM \"SYS\".\"TABLES\"`\n\n dbTables.push(...(await this.query(tablesSql)))\n } else {\n const tablesCondition = tableNames\n .map((tableName) => {\n let [schema, name] = tableName.split(\".\")\n if (!name) {\n name = schema\n schema = this.driver.options.schema || currentSchema\n }\n return `(\"SCHEMA_NAME\" = '${schema}' AND \"TABLE_NAME\" = '${name}')`\n })\n .join(\" OR \")\n\n const tablesSql =\n `SELECT \"SCHEMA_NAME\", \"TABLE_NAME\" FROM \"SYS\".\"TABLES\" WHERE ` +\n tablesCondition\n\n dbTables.push(...(await this.query(tablesSql)))\n }\n\n // if tables were not found in the db, no need to proceed\n if (dbTables.length === 0) return []\n\n const columnsCondition = dbTables\n .map(({ SCHEMA_NAME, TABLE_NAME }) => {\n return `(\"SCHEMA_NAME\" = '${SCHEMA_NAME}' AND \"TABLE_NAME\" = '${TABLE_NAME}')`\n })\n .join(\" OR \")\n const columnsSql =\n `SELECT * FROM \"SYS\".\"TABLE_COLUMNS\" WHERE ` +\n columnsCondition +\n ` ORDER BY \"POSITION\"`\n\n const constraintsCondition = dbTables\n .map(({ SCHEMA_NAME, TABLE_NAME }) => {\n return `(\"SCHEMA_NAME\" = '${SCHEMA_NAME}' AND \"TABLE_NAME\" = '${TABLE_NAME}')`\n })\n .join(\" OR \")\n const constraintsSql = `SELECT * FROM \"SYS\".\"CONSTRAINTS\" WHERE (${constraintsCondition}) ORDER BY \"POSITION\"`\n\n const indicesCondition = dbTables\n .map(({ SCHEMA_NAME, TABLE_NAME }) => {\n return `(\"I\".\"SCHEMA_NAME\" = '${SCHEMA_NAME}' AND \"I\".\"TABLE_NAME\" = '${TABLE_NAME}')`\n })\n .join(\" OR \")\n // excluding primary key and autogenerated fulltext indices\n const indicesSql =\n `SELECT \"I\".\"INDEX_TYPE\", \"I\".\"SCHEMA_NAME\", \"I\".\"TABLE_NAME\", \"I\".\"INDEX_NAME\", \"IC\".\"COLUMN_NAME\", \"I\".\"CONSTRAINT\" ` +\n `FROM \"SYS\".\"INDEXES\" \"I\" INNER JOIN \"SYS\".\"INDEX_COLUMNS\" \"IC\" ON \"IC\".\"INDEX_OID\" = \"I\".\"INDEX_OID\" ` +\n `WHERE (${indicesCondition}) AND (\"I\".\"CONSTRAINT\" IS NULL OR \"I\".\"CONSTRAINT\" != 'PRIMARY KEY') AND \"I\".\"INDEX_NAME\" NOT LIKE '%_SYS_FULLTEXT_%' ORDER BY \"IC\".\"POSITION\"`\n\n const foreignKeysCondition = dbTables\n .map(({ SCHEMA_NAME, TABLE_NAME }) => {\n return `(\"SCHEMA_NAME\" = '${SCHEMA_NAME}' AND \"TABLE_NAME\" = '${TABLE_NAME}')`\n })\n .join(\" OR \")\n const foreignKeysSql = `SELECT * FROM \"SYS\".\"REFERENTIAL_CONSTRAINTS\" WHERE (${foreignKeysCondition}) ORDER BY \"POSITION\"`\n const [\n dbColumns,\n dbConstraints,\n dbIndices,\n dbForeignKeys,\n ]: ObjectLiteral[][] = await Promise.all([\n this.query(columnsSql),\n this.query(constraintsSql),\n this.query(indicesSql),\n this.query(foreignKeysSql),\n ])\n\n // create tables for loaded tables\n return Promise.all(\n dbTables.map(async (dbTable) => {\n const table = new Table()\n const getSchemaFromKey = (dbObject: any, key: string) => {\n return dbObject[key] === currentSchema &&\n (!this.driver.options.schema ||\n this.driver.options.schema === currentSchema)\n ? undefined\n : dbObject[key]\n }\n\n // We do not need to join schema name, when database is by default.\n const schema = getSchemaFromKey(dbTable, \"SCHEMA_NAME\")\n table.database = currentDatabase\n table.schema = dbTable[\"SCHEMA_NAME\"]\n table.name = this.driver.buildTableName(\n dbTable[\"TABLE_NAME\"],\n schema,\n )\n\n // create columns from the loaded columns\n table.columns = await Promise.all(\n dbColumns\n .filter(\n (dbColumn) =>\n dbColumn[\"TABLE_NAME\"] ===\n dbTable[\"TABLE_NAME\"] &&\n dbColumn[\"SCHEMA_NAME\"] ===\n dbTable[\"SCHEMA_NAME\"],\n )\n .map(async (dbColumn) => {\n const columnConstraints = dbConstraints.filter(\n (dbConstraint) =>\n dbConstraint[\"TABLE_NAME\"] ===\n dbColumn[\"TABLE_NAME\"] &&\n dbConstraint[\"SCHEMA_NAME\"] ===\n dbColumn[\"SCHEMA_NAME\"] &&\n dbConstraint[\"COLUMN_NAME\"] ===\n dbColumn[\"COLUMN_NAME\"],\n )\n\n const columnUniqueIndices = dbIndices.filter(\n (dbIndex) => {\n return (\n dbIndex[\"TABLE_NAME\"] ===\n dbTable[\"TABLE_NAME\"] &&\n dbIndex[\"SCHEMA_NAME\"] ===\n dbTable[\"SCHEMA_NAME\"] &&\n dbIndex[\"COLUMN_NAME\"] ===\n dbColumn[\"COLUMN_NAME\"] &&\n dbIndex[\"CONSTRAINT\"] &&\n dbIndex[\"CONSTRAINT\"].indexOf(\n \"UNIQUE\",\n ) !== -1\n )\n },\n )\n\n const tableMetadata =\n this.connection.entityMetadatas.find(\n (metadata) =>\n this.getTablePath(table) ===\n this.getTablePath(metadata),\n )\n const hasIgnoredIndex =\n columnUniqueIndices.length > 0 &&\n tableMetadata &&\n tableMetadata.indices.some((index) => {\n return columnUniqueIndices.some(\n (uniqueIndex) => {\n return (\n index.name ===\n uniqueIndex[\"INDEX_NAME\"] &&\n index.synchronize === false\n )\n },\n )\n })\n\n const isConstraintComposite =\n columnUniqueIndices.every((uniqueIndex) => {\n return dbIndices.some(\n (dbIndex) =>\n dbIndex[\"INDEX_NAME\"] ===\n uniqueIndex[\"INDEX_NAME\"] &&\n dbIndex[\"COLUMN_NAME\"] !==\n dbColumn[\"COLUMN_NAME\"],\n )\n })\n\n const tableColumn = new TableColumn()\n tableColumn.name = dbColumn[\"COLUMN_NAME\"]\n tableColumn.type =\n dbColumn[\"DATA_TYPE_NAME\"].toLowerCase()\n\n if (\n tableColumn.type === \"dec\" ||\n tableColumn.type === \"decimal\"\n ) {\n // If one of these properties was set, and another was not, Postgres sets '0' in to unspecified property\n // we set 'undefined' in to unspecified property to avoid changing column on sync\n if (\n dbColumn[\"LENGTH\"] !== null &&\n !this.isDefaultColumnPrecision(\n table,\n tableColumn,\n dbColumn[\"LENGTH\"],\n )\n ) {\n tableColumn.precision = dbColumn[\"LENGTH\"]\n } else if (\n dbColumn[\"SCALE\"] !== null &&\n !this.isDefaultColumnScale(\n table,\n tableColumn,\n dbColumn[\"SCALE\"],\n )\n ) {\n tableColumn.precision = undefined\n }\n if (\n dbColumn[\"SCALE\"] !== null &&\n !this.isDefaultColumnScale(\n table,\n tableColumn,\n dbColumn[\"SCALE\"],\n )\n ) {\n tableColumn.scale = dbColumn[\"SCALE\"]\n } else if (\n dbColumn[\"LENGTH\"] !== null &&\n !this.isDefaultColumnPrecision(\n table,\n tableColumn,\n dbColumn[\"LENGTH\"],\n )\n ) {\n tableColumn.scale = undefined\n }\n }\n\n if (\n dbColumn[\"DATA_TYPE_NAME\"].toLowerCase() ===\n \"array\"\n ) {\n tableColumn.isArray = true\n tableColumn.type =\n dbColumn[\"CS_DATA_TYPE_NAME\"].toLowerCase()\n }\n\n // check only columns that have length property\n if (\n this.driver.withLengthColumnTypes.indexOf(\n tableColumn.type as ColumnType,\n ) !== -1 &&\n dbColumn[\"LENGTH\"]\n ) {\n const length = dbColumn[\"LENGTH\"].toString()\n tableColumn.length =\n !this.isDefaultColumnLength(\n table,\n tableColumn,\n length,\n )\n ? length\n : \"\"\n }\n tableColumn.isUnique =\n columnUniqueIndices.length > 0 &&\n !hasIgnoredIndex &&\n !isConstraintComposite\n tableColumn.isNullable =\n dbColumn[\"IS_NULLABLE\"] === \"TRUE\"\n tableColumn.isPrimary = !!columnConstraints.find(\n (constraint) =>\n constraint[\"IS_PRIMARY_KEY\"] === \"TRUE\",\n )\n tableColumn.isGenerated =\n dbColumn[\"GENERATION_TYPE\"] ===\n \"ALWAYS AS IDENTITY\"\n if (tableColumn.isGenerated)\n tableColumn.generationStrategy = \"increment\"\n\n if (\n dbColumn[\"DEFAULT_VALUE\"] === null ||\n dbColumn[\"DEFAULT_VALUE\"] === undefined\n ) {\n tableColumn.default = undefined\n } else {\n if (\n tableColumn.type === \"char\" ||\n tableColumn.type === \"nchar\" ||\n tableColumn.type === \"varchar\" ||\n tableColumn.type === \"nvarchar\" ||\n tableColumn.type === \"alphanum\" ||\n tableColumn.type === \"shorttext\"\n ) {\n tableColumn.default = `'${dbColumn[\"DEFAULT_VALUE\"]}'`\n } else if (tableColumn.type === \"boolean\") {\n tableColumn.default =\n dbColumn[\"DEFAULT_VALUE\"] === \"1\"\n ? \"true\"\n : \"false\"\n } else {\n tableColumn.default =\n dbColumn[\"DEFAULT_VALUE\"]\n }\n }\n tableColumn.comment = \"\" // dbColumn[\"COLUMN_COMMENT\"];\n if (dbColumn[\"character_set_name\"])\n tableColumn.charset =\n dbColumn[\"character_set_name\"]\n if (dbColumn[\"collation_name\"])\n tableColumn.collation =\n dbColumn[\"collation_name\"]\n return tableColumn\n }),\n )\n\n // find check constraints of table, group them by constraint name and build TableCheck.\n const tableCheckConstraints = OrmUtils.uniq(\n dbConstraints.filter(\n (dbConstraint) =>\n dbConstraint[\"TABLE_NAME\"] ===\n dbTable[\"TABLE_NAME\"] &&\n dbConstraint[\"SCHEMA_NAME\"] ===\n dbTable[\"SCHEMA_NAME\"] &&\n dbConstraint[\"CHECK_CONDITION\"] !== null &&\n dbConstraint[\"CHECK_CONDITION\"] !== undefined,\n ),\n (dbConstraint) => dbConstraint[\"CONSTRAINT_NAME\"],\n )\n\n table.checks = tableCheckConstraints.map((constraint) => {\n const checks = dbConstraints.filter(\n (dbC) =>\n dbC[\"CONSTRAINT_NAME\"] ===\n constraint[\"CONSTRAINT_NAME\"],\n )\n return new TableCheck({\n name: constraint[\"CONSTRAINT_NAME\"],\n columnNames: checks.map((c) => c[\"COLUMN_NAME\"]),\n expression: constraint[\"CHECK_CONDITION\"],\n })\n })\n\n // find foreign key constraints of table, group them by constraint name and build TableForeignKey.\n const tableForeignKeyConstraints = OrmUtils.uniq(\n dbForeignKeys.filter(\n (dbForeignKey) =>\n dbForeignKey[\"TABLE_NAME\"] ===\n dbTable[\"TABLE_NAME\"] &&\n dbForeignKey[\"SCHEMA_NAME\"] ===\n dbTable[\"SCHEMA_NAME\"],\n ),\n (dbForeignKey) => dbForeignKey[\"CONSTRAINT_NAME\"],\n )\n\n table.foreignKeys = tableForeignKeyConstraints.map(\n (dbForeignKey) => {\n const foreignKeys = dbForeignKeys.filter(\n (dbFk) =>\n dbFk[\"CONSTRAINT_NAME\"] ===\n dbForeignKey[\"CONSTRAINT_NAME\"],\n )\n\n // if referenced table located in currently used schema, we don't need to concat schema name to table name.\n const schema = getSchemaFromKey(\n dbForeignKey,\n \"REFERENCED_SCHEMA_NAME\",\n )\n const referencedTableName = this.driver.buildTableName(\n dbForeignKey[\"REFERENCED_TABLE_NAME\"],\n schema,\n )\n\n return new TableForeignKey({\n name: dbForeignKey[\"CONSTRAINT_NAME\"],\n columnNames: foreignKeys.map(\n (dbFk) => dbFk[\"COLUMN_NAME\"],\n ),\n referencedDatabase: table.database,\n referencedSchema:\n dbForeignKey[\"REFERENCED_SCHEMA_NAME\"],\n referencedTableName: referencedTableName,\n referencedColumnNames: foreignKeys.map(\n (dbFk) => dbFk[\"REFERENCED_COLUMN_NAME\"],\n ),\n onDelete:\n dbForeignKey[\"DELETE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"DELETE_RULE\"],\n onUpdate:\n dbForeignKey[\"UPDATE_RULE\"] === \"RESTRICT\"\n ? \"NO ACTION\"\n : dbForeignKey[\"UPDATE_RULE\"],\n deferrable: dbForeignKey[\"CHECK_TIME\"].replace(\n \"_\",\n \" \",\n ),\n })\n },\n )\n\n // find index constraints of table, group them by constraint name and build TableIndex.\n const tableIndexConstraints = OrmUtils.uniq(\n dbIndices.filter(\n (dbIndex) =>\n dbIndex[\"TABLE_NAME\"] === dbTable[\"TABLE_NAME\"] &&\n dbIndex[\"SCHEMA_NAME\"] === dbTable[\"SCHEMA_NAME\"],\n ),\n (dbIndex) => dbIndex[\"INDEX_NAME\"],\n )\n\n table.indices = tableIndexConstraints.map((constraint) => {\n const indices = dbIndices.filter((index) => {\n return (\n index[\"SCHEMA_NAME\"] ===\n constraint[\"SCHEMA_NAME\"] &&\n index[\"TABLE_NAME\"] === constraint[\"TABLE_NAME\"] &&\n index[\"INDEX_NAME\"] === constraint[\"INDEX_NAME\"]\n )\n })\n return new TableIndex(<TableIndexOptions>{\n table: table,\n name: constraint[\"INDEX_NAME\"],\n columnNames: indices.map((i) => i[\"COLUMN_NAME\"]),\n isUnique:\n constraint[\"CONSTRAINT\"] &&\n constraint[\"CONSTRAINT\"].indexOf(\"UNIQUE\") !== -1,\n isFulltext: constraint[\"INDEX_TYPE\"] === \"FULLTEXT\",\n })\n })\n\n return table\n }),\n )\n }\n\n /**\n * Builds and returns SQL for create table.\n */\n protected createTableSql(table: Table, createForeignKeys?: boolean): Query {\n const columnDefinitions = table.columns\n .map((column) => this.buildCreateColumnSql(column))\n .join(\", \")\n let sql = `CREATE TABLE ${this.escapePath(table)} (${columnDefinitions}`\n\n // we create unique indexes instead of unique constraints, because SAP HANA does not have unique constraints.\n // if we mark column as Unique, it means that we create UNIQUE INDEX.\n table.columns\n .filter((column) => column.isUnique)\n .forEach((column) => {\n const isUniqueIndexExist = table.indices.some((index) => {\n return (\n index.columnNames.length === 1 &&\n !!index.isUnique &&\n index.columnNames.indexOf(column.name) !== -1\n )\n })\n const isUniqueConstraintExist = table.uniques.some((unique) => {\n return (\n unique.columnNames.length === 1 &&\n unique.columnNames.indexOf(column.name) !== -1\n )\n })\n if (!isUniqueIndexExist && !isUniqueConstraintExist)\n table.indices.push(\n new TableIndex({\n name: this.connection.namingStrategy.uniqueConstraintName(\n table,\n [column.name],\n ),\n columnNames: [column.name],\n isUnique: true,\n }),\n )\n })\n\n // as SAP HANA does not have unique constraints, we must create table indices from table uniques and mark them as unique.\n if (table.uniques.length > 0) {\n table.uniques.forEach((unique) => {\n const uniqueExist = table.indices.some(\n (index) => index.name === unique.name,\n )\n if (!uniqueExist) {\n table.indices.push(\n new TableIndex({\n name: unique.name,\n columnNames: unique.columnNames,\n isUnique: true,\n }),\n )\n }\n })\n }\n\n if (table.checks.length > 0) {\n const checksSql = table.checks\n .map((check) => {\n const checkName = check.name\n ? check.name\n : this.connection.namingStrategy.checkConstraintName(\n table,\n check.expression!,\n )\n return `CONSTRAINT \"${checkName}\" CHECK (${check.expression})`\n })\n .join(\", \")\n\n sql += `, ${checksSql}`\n }\n\n if (table.foreignKeys.length > 0 && createForeignKeys) {\n const foreignKeysSql = table.foreignKeys\n .map((fk) => {\n const columnNames = fk.columnNames\n .map((columnName) => `\"${columnName}\"`)\n .join(\", \")\n if (!fk.name)\n fk.name = this.connection.namingStrategy.foreignKeyName(\n table,\n fk.columnNames,\n this.getTablePath(fk),\n fk.referencedColumnNames,\n )\n const referencedColumnNames = fk.referencedColumnNames\n .map((columnName) => `\"${columnName}\"`)\n .join(\", \")\n\n let constraint = `CONSTRAINT \"${\n fk.name\n }\" FOREIGN KEY (${columnNames}) REFERENCES ${this.escapePath(\n this.getTablePath(fk),\n )} (${referencedColumnNames})`\n // SAP HANA does not have \"NO ACTION\" option for FK's\n if (fk.onDelete) {\n const onDelete =\n fk.onDelete === \"NO ACTION\"\n ? \"RESTRICT\"\n : fk.onDelete\n constraint += ` ON DELETE ${onDelete}`\n }\n if (fk.onUpdate) {\n const onUpdate =\n fk.onUpdate === \"NO ACTION\"\n ? \"RESTRICT\"\n : fk.onUpdate\n constraint += ` ON UPDATE ${onUpdate}`\n }\n if (fk.deferrable) {\n constraint += ` ${fk.deferrable}`\n }\n\n return constraint\n })\n .join(\", \")\n\n sql += `, ${foreignKeysSql}`\n }\n\n const primaryColumns = table.columns.filter(\n (column) => column.isPrimary,\n )\n if (primaryColumns.length > 0) {\n const primaryKeyName =\n this.connection.namingStrategy.primaryKeyName(\n table,\n primaryColumns.map((column) => column.name),\n )\n const columnNames = primaryColumns\n .map((column) => `\"${column.name}\"`)\n .join(\", \")\n sql += `, CONSTRAINT \"${primaryKeyName}\" PRIMARY KEY (${columnNames})`\n }\n\n sql += `)`\n\n return new Query(sql)\n }\n\n /**\n * Builds drop table sql.\n */\n protected dropTableSql(\n tableOrName: Table | string,\n ifExist?: boolean,\n ): Query {\n const query = ifExist\n ? `DROP TABLE IF EXISTS ${this.escapePath(tableOrName)}`\n : `DROP TABLE ${this.escapePath(tableOrName)}`\n return new Query(query)\n }\n\n protected createViewSql(view: View): Query {\n if (typeof view.expression === \"string\") {\n return new Query(\n `CREATE VIEW ${this.escapePath(view)} AS ${view.expression}`,\n )\n } else {\n return new Query(\n `CREATE VIEW ${this.escapePath(view)} AS ${view\n .expression(this.connection)\n .getQuery()}`,\n )\n }\n }\n\n protected async insertViewDefinitionSql(view: View): Promise<Query> {\n let { schema, tableName: name } = this.driver.parseTableName(view)\n\n if (!schema) {\n schema = await this.getCurrentSchema()\n }\n\n const expression =\n typeof view.expression === \"string\"\n ? view.expression.trim()\n : view.expression(this.connection).getQuery()\n return this.insertTypeormMetadataSql({\n type: MetadataTableType.VIEW,\n schema: schema,\n name: name,\n value: expression,\n })\n }\n\n /**\n * Builds drop view sql.\n */\n protected dropViewSql(viewOrPath: View | string): Query {\n return new Query(`DROP VIEW ${this.escapePath(viewOrPath)}`)\n }\n\n /**\n * Builds remove view sql.\n */\n protected async deleteViewDefinitionSql(\n viewOrPath: View | string,\n ): Promise<Query> {\n let { schema, tableName: name } = this.driver.parseTableName(viewOrPath)\n\n if (!schema) {\n schema = await this.getCurrentSchema()\n }\n\n return this.deleteTypeormMetadataSql({\n type: MetadataTableType.VIEW,\n schema,\n name,\n })\n }\n\n protected addColumnSql(table: Table, column: TableColumn): string {\n return `ALTER TABLE ${this.escapePath(\n table,\n )} ADD (${this.buildCreateColumnSql(column)})`\n }\n\n protected dropColumnSql(table: Table, column: TableColumn): string {\n return `ALTER TABLE ${this.escapePath(table)} DROP (\"${column.name}\")`\n }\n\n /**\n * Builds create index sql.\n */\n protected createIndexSql(table: Table, index: TableIndex): Query {\n const columns = index.columnNames\n .map((columnName) => `\"${columnName}\"`)\n .join(\", \")\n let indexType = \"\"\n if (index.isUnique) {\n indexType += \"UNIQUE \"\n }\n if (index.isFulltext) {\n indexType += \"FULLTEXT \"\n }\n\n return new Query(\n `CREATE ${indexType}INDEX \"${index.name}\" ON ${this.escapePath(\n table,\n )} (${columns}) ${index.where ? \"WHERE \" + index.where : \"\"}`,\n )\n }\n\n /**\n * Builds drop index sql.\n */\n protected dropIndexSql(\n table: Table,\n indexOrName: TableIndex | string,\n ): Query {\n const indexName = InstanceChecker.isTableIndex(indexOrName)\n ? indexOrName.name\n : indexOrName\n const parsedTableName = this.driver.parseTableName(table)\n\n if (!parsedTableName.schema) {\n return new Query(`DROP INDEX \"${indexName}\"`)\n } else {\n return new Query(\n `DROP INDEX \"${parsedTableName.schema}\".\"${indexName}\"`,\n )\n }\n }\n\n /**\n * Builds create primary key sql.\n */\n protected createPrimaryKeySql(table: Table, columnNames: string[]): Query {\n const primaryKeyName = this.connection.namingStrategy.primaryKeyName(\n table,\n columnNames,\n )\n const columnNamesString = columnNames\n .map((columnName) => `\"${columnName}\"`)\n .join(\", \")\n return new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} ADD CONSTRAINT \"${primaryKeyName}\" PRIMARY KEY (${columnNamesString})`,\n )\n }\n\n /**\n * Builds drop primary key sql.\n */\n protected dropPrimaryKeySql(table: Table): Query {\n const columnNames = table.primaryColumns.map((column) => column.name)\n const primaryKeyName = this.connection.namingStrategy.primaryKeyName(\n table,\n columnNames,\n )\n return new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${primaryKeyName}\"`,\n )\n }\n\n /**\n * Builds create check constraint sql.\n */\n protected createCheckConstraintSql(\n table: Table,\n checkConstraint: TableCheck,\n ): Query {\n return new Query(\n `ALTER TABLE ${this.escapePath(table)} ADD CONSTRAINT \"${\n checkConstraint.name\n }\" CHECK (${checkConstraint.expression})`,\n )\n }\n\n /**\n * Builds drop check constraint sql.\n */\n protected dropCheckConstraintSql(\n table: Table,\n checkOrName: TableCheck | string,\n ): Query {\n const checkName = InstanceChecker.isTableCheck(checkOrName)\n ? checkOrName.name\n : checkOrName\n return new Query(\n `ALTER TABLE ${this.escapePath(\n table,\n )} DROP CONSTRAINT \"${checkName}\"`,\n )\n }\n\n /**\n * Builds create foreign key sql.\n */\n protected createForeignKeySql(\n tableOrName: Table | string,\n foreignKey: TableForeignKey,\n ): Query {\n const columnNames = foreignKey.columnNames\n .map((column) => `\"` + column + `\"`)\n .join(\", \")\n const referencedColumnNames = foreignKey.referencedColumnNames\n .map((column) => `\"` + column + `\"`)\n .join(\",\")\n let sql =\n `ALTER TABLE ${this.escapePath(tableOrName)} ADD CONSTRAINT \"${\n foreignKey.name\n }\" FOREIGN KEY (${columnNames}) ` +\n `REFERENCES ${this.escapePath(\n this.getTablePath(foreignKey),\n )}(${referencedColumnNames})`\n\n // SAP HANA does not have \"NO ACTION\" option for FK's\n if (foreignKey.onDelete) {\n const onDelete =\n foreignKey.onDelete === \"NO ACTION\"\n ? \"RESTRICT\"\n : foreignKey.onDelete\n sql += ` ON DELETE ${onDelete}`\n }\n if (foreignKey.onUpdate) {\n const onUpdate =\n foreignKey.onUpdate === \"NO ACTION\"\n ? \"RESTRICT\"\n : foreignKey.onUpdate\n sql += ` ON UPDATE ${onUpdate}`\n }\n\n if (foreignKey.deferrable) {\n sql += ` ${foreignKey.deferrable}`\n }\n\n return new Query(sql)\n }\n\n /**\n * Builds drop foreign key sql.\n */\n protected dropForeignKeySql(\n tableOrName: Table | string,\n foreignKeyOrName: TableForeignKey | string,\n ): Query {\n const foreignKeyName = InstanceChecker.isTableForeignKey(\n foreignKeyOrName,\n )\n ? foreignKeyOrName.name\n : foreignKeyOrName\n return new Query(\n `ALTER TABLE ${this.escapePath(\n tableOrName,\n )} DROP CONSTRAINT \"${foreignKeyName}\"`,\n )\n }\n\n /**\n * Escapes given table or view path.\n */\n protected escapePath(target: Table | View | string): string {\n const { schema, tableName } = this.driver.parseTableName(target)\n\n if (schema) {\n return `\"${schema}\".\"${tableName}\"`\n }\n\n return `\"${tableName}\"`\n }\n\n /**\n * Concat database name and schema name to the foreign key name.\n * Needs because FK name is relevant to the schema and database.\n */\n protected buildForeignKeyName(\n fkName: string,\n schemaName: string | undefined,\n dbName: string | undefined,\n ): string {\n let joinedFkName = fkName\n if (schemaName) joinedFkName = schemaName + \".\" + joinedFkName\n if (dbName) joinedFkName = dbName + \".\" + joinedFkName\n\n return joinedFkName\n }\n\n /**\n * Removes parenthesis around default value.\n * Sql server returns default value with parenthesis around, e.g.\n * ('My text') - for string\n * ((1)) - for number\n * (newsequentialId()) - for function\n */\n protected removeParenthesisFromDefault(defaultValue: any): any {\n if (defaultValue.substr(0, 1) !== \"(\") return defaultValue\n const normalizedDefault = defaultValue.substr(\n 1,\n defaultValue.lastIndexOf(\")\") - 1,\n )\n return this.removeParenthesisFromDefault(normalizedDefault)\n }\n\n /**\n * Builds a query for create column.\n */\n protected buildCreateColumnSql(column: TableColumn) {\n let c =\n `\"${column.name}\" ` + this.connection.driver.createFullType(column)\n if (column.charset) c += \" CHARACTER SET \" + column.charset\n if (column.collation) c += \" COLLATE \" + column.collation\n if (column.default !== undefined && column.default !== null)\n // DEFAULT must be placed before NOT NULL\n c += \" DEFAULT \" + column.default\n if (column.isNullable !== true && !column.isGenerated)\n // NOT NULL is not supported with GENERATED\n c += \" NOT NULL\"\n if (\n column.isGenerated === true &&\n column.generationStrategy === \"increment\"\n )\n c += \" GENERATED ALWAYS AS IDENTITY\"\n\n return c\n }\n}\n"],"sourceRoot":"../.."}