noormme 1.0.0

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 (1230) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +727 -0
  3. package/dist/cjs/cache/cache-manager.d.ts +76 -0
  4. package/dist/cjs/cache/cache-manager.js +169 -0
  5. package/dist/cjs/cli/commands/analyze.d.ts +7 -0
  6. package/dist/cjs/cli/commands/analyze.js +132 -0
  7. package/dist/cjs/cli/commands/generate.d.ts +7 -0
  8. package/dist/cjs/cli/commands/generate.js +514 -0
  9. package/dist/cjs/cli/commands/init.d.ts +7 -0
  10. package/dist/cjs/cli/commands/init.js +470 -0
  11. package/dist/cjs/cli/commands/inspect.d.ts +7 -0
  12. package/dist/cjs/cli/commands/inspect.js +365 -0
  13. package/dist/cjs/cli/commands/migrate.d.ts +8 -0
  14. package/dist/cjs/cli/commands/migrate.js +218 -0
  15. package/dist/cjs/cli/commands/optimize.d.ts +8 -0
  16. package/dist/cjs/cli/commands/optimize.js +156 -0
  17. package/dist/cjs/cli/commands/status.d.ts +6 -0
  18. package/dist/cjs/cli/commands/status.js +267 -0
  19. package/dist/cjs/cli/commands/watch.d.ts +7 -0
  20. package/dist/cjs/cli/commands/watch.js +216 -0
  21. package/dist/cjs/cli/index.d.ts +2 -0
  22. package/dist/cjs/cli/index.js +157 -0
  23. package/dist/cjs/dialect/database-introspector.d.ts +61 -0
  24. package/dist/cjs/dialect/database-introspector.js +85 -0
  25. package/dist/cjs/dialect/dialect-adapter-base.d.ts +94 -0
  26. package/dist/cjs/dialect/dialect-adapter-base.js +24 -0
  27. package/dist/cjs/dialect/dialect-adapter.d.ts +115 -0
  28. package/dist/cjs/dialect/dialect-adapter.js +2 -0
  29. package/dist/cjs/dialect/dialect.d.ts +34 -0
  30. package/dist/cjs/dialect/dialect.js +2 -0
  31. package/dist/cjs/dialect/sqlite/sqlite-adapter.d.ts +80 -0
  32. package/dist/cjs/dialect/sqlite/sqlite-adapter.js +23 -0
  33. package/dist/cjs/dialect/sqlite/sqlite-auto-indexer.d.ts +181 -0
  34. package/dist/cjs/dialect/sqlite/sqlite-auto-indexer.js +541 -0
  35. package/dist/cjs/dialect/sqlite/sqlite-auto-optimizer.d.ts +102 -0
  36. package/dist/cjs/dialect/sqlite/sqlite-auto-optimizer.js +373 -0
  37. package/dist/cjs/dialect/sqlite/sqlite-dialect-config.d.ts +41 -0
  38. package/dist/cjs/dialect/sqlite/sqlite-dialect-config.js +2 -0
  39. package/dist/cjs/dialect/sqlite/sqlite-dialect.d.ts +55 -0
  40. package/dist/cjs/dialect/sqlite/sqlite-dialect.js +51 -0
  41. package/dist/cjs/dialect/sqlite/sqlite-driver.d.ts +42 -0
  42. package/dist/cjs/dialect/sqlite/sqlite-driver.js +152 -0
  43. package/dist/cjs/dialect/sqlite/sqlite-introspector.d.ts +36 -0
  44. package/dist/cjs/dialect/sqlite/sqlite-introspector.js +236 -0
  45. package/dist/cjs/dialect/sqlite/sqlite-query-compiler.d.ts +16 -0
  46. package/dist/cjs/dialect/sqlite/sqlite-query-compiler.js +43 -0
  47. package/dist/cjs/driver/connection-provider.d.ts +8 -0
  48. package/dist/cjs/driver/connection-provider.js +2 -0
  49. package/dist/cjs/driver/database-connection.d.ts +35 -0
  50. package/dist/cjs/driver/database-connection.js +2 -0
  51. package/dist/cjs/driver/default-connection-provider.d.ts +12 -0
  52. package/dist/cjs/driver/default-connection-provider.js +19 -0
  53. package/dist/cjs/driver/driver.d.ts +61 -0
  54. package/dist/cjs/driver/driver.js +22 -0
  55. package/dist/cjs/driver/dummy-driver.d.ts +75 -0
  56. package/dist/cjs/driver/dummy-driver.js +83 -0
  57. package/dist/cjs/driver/runtime-driver.d.ts +47 -0
  58. package/dist/cjs/driver/runtime-driver.js +165 -0
  59. package/dist/cjs/driver/single-connection-provider.d.ts +11 -0
  60. package/dist/cjs/driver/single-connection-provider.js +29 -0
  61. package/dist/cjs/dynamic/dynamic-reference-builder.d.ts +18 -0
  62. package/dist/cjs/dynamic/dynamic-reference-builder.js +36 -0
  63. package/dist/cjs/dynamic/dynamic-table-builder.d.ts +16 -0
  64. package/dist/cjs/dynamic/dynamic-table-builder.js +46 -0
  65. package/dist/cjs/dynamic/dynamic.d.ts +124 -0
  66. package/dist/cjs/dynamic/dynamic.js +132 -0
  67. package/dist/cjs/errors/NoormError.d.ts +56 -0
  68. package/dist/cjs/errors/NoormError.js +158 -0
  69. package/dist/cjs/expression/expression-builder.d.ts +920 -0
  70. package/dist/cjs/expression/expression-builder.js +128 -0
  71. package/dist/cjs/expression/expression-wrapper.d.ts +631 -0
  72. package/dist/cjs/expression/expression-wrapper.js +134 -0
  73. package/dist/cjs/expression/expression.d.ts +198 -0
  74. package/dist/cjs/expression/expression.js +15 -0
  75. package/dist/cjs/helpers/sqlite.d.ts +189 -0
  76. package/dist/cjs/helpers/sqlite.js +204 -0
  77. package/dist/cjs/index.d.ts +211 -0
  78. package/dist/cjs/index.js +223 -0
  79. package/dist/cjs/kysely.d.ts +848 -0
  80. package/dist/cjs/kysely.js +924 -0
  81. package/dist/cjs/logging/logger.d.ts +96 -0
  82. package/dist/cjs/logging/logger.js +179 -0
  83. package/dist/cjs/noormme.d.ts +137 -0
  84. package/dist/cjs/noormme.js +521 -0
  85. package/dist/cjs/operation-node/add-column-node.d.ts +13 -0
  86. package/dist/cjs/operation-node/add-column-node.js +18 -0
  87. package/dist/cjs/operation-node/add-constraint-node.d.ts +13 -0
  88. package/dist/cjs/operation-node/add-constraint-node.js +18 -0
  89. package/dist/cjs/operation-node/add-index-node.d.ts +21 -0
  90. package/dist/cjs/operation-node/add-index-node.js +31 -0
  91. package/dist/cjs/operation-node/aggregate-function-node.d.ts +27 -0
  92. package/dist/cjs/operation-node/aggregate-function-node.js +58 -0
  93. package/dist/cjs/operation-node/alias-node.d.ts +13 -0
  94. package/dist/cjs/operation-node/alias-node.js +19 -0
  95. package/dist/cjs/operation-node/alter-column-node.d.ts +21 -0
  96. package/dist/cjs/operation-node/alter-column-node.js +20 -0
  97. package/dist/cjs/operation-node/alter-table-node.d.ts +36 -0
  98. package/dist/cjs/operation-node/alter-table-node.js +32 -0
  99. package/dist/cjs/operation-node/and-node.d.ts +13 -0
  100. package/dist/cjs/operation-node/and-node.js +19 -0
  101. package/dist/cjs/operation-node/binary-operation-node.d.ts +14 -0
  102. package/dist/cjs/operation-node/binary-operation-node.js +20 -0
  103. package/dist/cjs/operation-node/case-node.d.ts +19 -0
  104. package/dist/cjs/operation-node/case-node.js +42 -0
  105. package/dist/cjs/operation-node/cast-node.d.ts +13 -0
  106. package/dist/cjs/operation-node/cast-node.js +19 -0
  107. package/dist/cjs/operation-node/check-constraint-node.d.ts +14 -0
  108. package/dist/cjs/operation-node/check-constraint-node.js +20 -0
  109. package/dist/cjs/operation-node/collate-node.d.ts +13 -0
  110. package/dist/cjs/operation-node/collate-node.js +19 -0
  111. package/dist/cjs/operation-node/column-definition-node.d.ts +36 -0
  112. package/dist/cjs/operation-node/column-definition-node.js +42 -0
  113. package/dist/cjs/operation-node/column-node.d.ts +13 -0
  114. package/dist/cjs/operation-node/column-node.js +19 -0
  115. package/dist/cjs/operation-node/column-update-node.d.ts +13 -0
  116. package/dist/cjs/operation-node/column-update-node.js +19 -0
  117. package/dist/cjs/operation-node/common-table-expression-name-node.d.ts +15 -0
  118. package/dist/cjs/operation-node/common-table-expression-name-node.js +23 -0
  119. package/dist/cjs/operation-node/common-table-expression-node.d.ts +18 -0
  120. package/dist/cjs/operation-node/common-table-expression-node.js +25 -0
  121. package/dist/cjs/operation-node/constraint-node.d.ts +5 -0
  122. package/dist/cjs/operation-node/constraint-node.js +2 -0
  123. package/dist/cjs/operation-node/create-index-node.d.ts +27 -0
  124. package/dist/cjs/operation-node/create-index-node.js +31 -0
  125. package/dist/cjs/operation-node/create-schema-node.d.ts +16 -0
  126. package/dist/cjs/operation-node/create-schema-node.js +26 -0
  127. package/dist/cjs/operation-node/create-table-node.d.ts +32 -0
  128. package/dist/cjs/operation-node/create-table-node.js +56 -0
  129. package/dist/cjs/operation-node/create-type-node.d.ts +17 -0
  130. package/dist/cjs/operation-node/create-type-node.js +26 -0
  131. package/dist/cjs/operation-node/create-view-node.d.ts +24 -0
  132. package/dist/cjs/operation-node/create-view-node.js +25 -0
  133. package/dist/cjs/operation-node/data-type-node.d.ts +18 -0
  134. package/dist/cjs/operation-node/data-type-node.js +86 -0
  135. package/dist/cjs/operation-node/default-insert-value-node.d.ts +11 -0
  136. package/dist/cjs/operation-node/default-insert-value-node.js +17 -0
  137. package/dist/cjs/operation-node/default-value-node.d.ts +12 -0
  138. package/dist/cjs/operation-node/default-value-node.js +18 -0
  139. package/dist/cjs/operation-node/delete-query-node.d.ts +46 -0
  140. package/dist/cjs/operation-node/delete-query-node.js +52 -0
  141. package/dist/cjs/operation-node/drop-column-node.d.ts +13 -0
  142. package/dist/cjs/operation-node/drop-column-node.js +19 -0
  143. package/dist/cjs/operation-node/drop-constraint-node.d.ts +17 -0
  144. package/dist/cjs/operation-node/drop-constraint-node.js +25 -0
  145. package/dist/cjs/operation-node/drop-index-node.d.ts +19 -0
  146. package/dist/cjs/operation-node/drop-index-node.js +26 -0
  147. package/dist/cjs/operation-node/drop-schema-node.d.ts +17 -0
  148. package/dist/cjs/operation-node/drop-schema-node.js +26 -0
  149. package/dist/cjs/operation-node/drop-table-node.d.ts +17 -0
  150. package/dist/cjs/operation-node/drop-table-node.js +25 -0
  151. package/dist/cjs/operation-node/drop-type-node.d.ts +16 -0
  152. package/dist/cjs/operation-node/drop-type-node.js +24 -0
  153. package/dist/cjs/operation-node/drop-view-node.d.ts +18 -0
  154. package/dist/cjs/operation-node/drop-view-node.js +25 -0
  155. package/dist/cjs/operation-node/explain-node.d.ts +14 -0
  156. package/dist/cjs/operation-node/explain-node.js +19 -0
  157. package/dist/cjs/operation-node/fetch-node.d.ts +15 -0
  158. package/dist/cjs/operation-node/fetch-node.js +19 -0
  159. package/dist/cjs/operation-node/foreign-key-constraint-node.d.ts +33 -0
  160. package/dist/cjs/operation-node/foreign-key-constraint-node.js +28 -0
  161. package/dist/cjs/operation-node/from-node.d.ts +13 -0
  162. package/dist/cjs/operation-node/from-node.js +24 -0
  163. package/dist/cjs/operation-node/function-node.d.ts +13 -0
  164. package/dist/cjs/operation-node/function-node.js +19 -0
  165. package/dist/cjs/operation-node/generated-node.d.ts +19 -0
  166. package/dist/cjs/operation-node/generated-node.js +31 -0
  167. package/dist/cjs/operation-node/group-by-item-node.d.ts +12 -0
  168. package/dist/cjs/operation-node/group-by-item-node.js +18 -0
  169. package/dist/cjs/operation-node/group-by-node.d.ts +14 -0
  170. package/dist/cjs/operation-node/group-by-node.js +24 -0
  171. package/dist/cjs/operation-node/having-node.d.ts +13 -0
  172. package/dist/cjs/operation-node/having-node.js +28 -0
  173. package/dist/cjs/operation-node/identifier-node.d.ts +12 -0
  174. package/dist/cjs/operation-node/identifier-node.js +18 -0
  175. package/dist/cjs/operation-node/insert-query-node.d.ts +40 -0
  176. package/dist/cjs/operation-node/insert-query-node.js +31 -0
  177. package/dist/cjs/operation-node/join-node.d.ts +18 -0
  178. package/dist/cjs/operation-node/join-node.js +37 -0
  179. package/dist/cjs/operation-node/json-operator-chain-node.d.ts +16 -0
  180. package/dist/cjs/operation-node/json-operator-chain-node.js +25 -0
  181. package/dist/cjs/operation-node/json-path-leg-node.d.ts +14 -0
  182. package/dist/cjs/operation-node/json-path-leg-node.js +19 -0
  183. package/dist/cjs/operation-node/json-path-node.d.ts +16 -0
  184. package/dist/cjs/operation-node/json-path-node.js +25 -0
  185. package/dist/cjs/operation-node/json-reference-node.d.ts +17 -0
  186. package/dist/cjs/operation-node/json-reference-node.js +25 -0
  187. package/dist/cjs/operation-node/limit-node.d.ts +12 -0
  188. package/dist/cjs/operation-node/limit-node.js +18 -0
  189. package/dist/cjs/operation-node/list-node.d.ts +12 -0
  190. package/dist/cjs/operation-node/list-node.js +18 -0
  191. package/dist/cjs/operation-node/matched-node.d.ts +13 -0
  192. package/dist/cjs/operation-node/matched-node.js +19 -0
  193. package/dist/cjs/operation-node/merge-query-node.d.ts +30 -0
  194. package/dist/cjs/operation-node/merge-query-node.js +45 -0
  195. package/dist/cjs/operation-node/modify-column-node.d.ts +13 -0
  196. package/dist/cjs/operation-node/modify-column-node.js +18 -0
  197. package/dist/cjs/operation-node/offset-node.d.ts +12 -0
  198. package/dist/cjs/operation-node/offset-node.js +18 -0
  199. package/dist/cjs/operation-node/on-conflict-node.d.ts +30 -0
  200. package/dist/cjs/operation-node/on-conflict-node.js +68 -0
  201. package/dist/cjs/operation-node/on-duplicate-key-node.d.ts +14 -0
  202. package/dist/cjs/operation-node/on-duplicate-key-node.js +18 -0
  203. package/dist/cjs/operation-node/on-node.d.ts +13 -0
  204. package/dist/cjs/operation-node/on-node.js +28 -0
  205. package/dist/cjs/operation-node/operation-node-source.d.ts +5 -0
  206. package/dist/cjs/operation-node/operation-node-source.js +7 -0
  207. package/dist/cjs/operation-node/operation-node-transformer.d.ts +238 -0
  208. package/dist/cjs/operation-node/operation-node-transformer.js +929 -0
  209. package/dist/cjs/operation-node/operation-node-visitor.d.ts +201 -0
  210. package/dist/cjs/operation-node/operation-node-visitor.js +115 -0
  211. package/dist/cjs/operation-node/operation-node.d.ts +4 -0
  212. package/dist/cjs/operation-node/operation-node.js +2 -0
  213. package/dist/cjs/operation-node/operator-node.d.ts +32 -0
  214. package/dist/cjs/operation-node/operator-node.js +107 -0
  215. package/dist/cjs/operation-node/or-action-node.d.ts +12 -0
  216. package/dist/cjs/operation-node/or-action-node.js +18 -0
  217. package/dist/cjs/operation-node/or-node.d.ts +13 -0
  218. package/dist/cjs/operation-node/or-node.js +19 -0
  219. package/dist/cjs/operation-node/order-by-item-node.d.ts +18 -0
  220. package/dist/cjs/operation-node/order-by-item-node.js +25 -0
  221. package/dist/cjs/operation-node/order-by-node.d.ts +14 -0
  222. package/dist/cjs/operation-node/order-by-node.js +24 -0
  223. package/dist/cjs/operation-node/output-node.d.ts +13 -0
  224. package/dist/cjs/operation-node/output-node.js +26 -0
  225. package/dist/cjs/operation-node/over-node.d.ts +19 -0
  226. package/dist/cjs/operation-node/over-node.js +35 -0
  227. package/dist/cjs/operation-node/parens-node.d.ts +12 -0
  228. package/dist/cjs/operation-node/parens-node.js +18 -0
  229. package/dist/cjs/operation-node/partition-by-item-node.d.ts +13 -0
  230. package/dist/cjs/operation-node/partition-by-item-node.js +18 -0
  231. package/dist/cjs/operation-node/partition-by-node.d.ts +14 -0
  232. package/dist/cjs/operation-node/partition-by-node.js +24 -0
  233. package/dist/cjs/operation-node/primary-key-constraint-node.d.ts +29 -0
  234. package/dist/cjs/operation-node/primary-key-constraint-node.js +30 -0
  235. package/dist/cjs/operation-node/primitive-value-list-node.d.ts +17 -0
  236. package/dist/cjs/operation-node/primitive-value-list-node.js +18 -0
  237. package/dist/cjs/operation-node/query-node.d.ts +60 -0
  238. package/dist/cjs/operation-node/query-node.js +102 -0
  239. package/dist/cjs/operation-node/raw-node.d.ts +16 -0
  240. package/dist/cjs/operation-node/raw-node.js +28 -0
  241. package/dist/cjs/operation-node/reference-node.d.ts +17 -0
  242. package/dist/cjs/operation-node/reference-node.js +27 -0
  243. package/dist/cjs/operation-node/references-node.d.ts +22 -0
  244. package/dist/cjs/operation-node/references-node.js +38 -0
  245. package/dist/cjs/operation-node/refresh-materialized-view-node.d.ts +17 -0
  246. package/dist/cjs/operation-node/refresh-materialized-view-node.js +25 -0
  247. package/dist/cjs/operation-node/rename-column-node.d.ts +14 -0
  248. package/dist/cjs/operation-node/rename-column-node.js +20 -0
  249. package/dist/cjs/operation-node/rename-constraint-node.d.ts +14 -0
  250. package/dist/cjs/operation-node/rename-constraint-node.js +20 -0
  251. package/dist/cjs/operation-node/returning-node.d.ts +14 -0
  252. package/dist/cjs/operation-node/returning-node.js +26 -0
  253. package/dist/cjs/operation-node/schemable-identifier-node.d.ts +15 -0
  254. package/dist/cjs/operation-node/schemable-identifier-node.js +26 -0
  255. package/dist/cjs/operation-node/select-all-node.d.ts +11 -0
  256. package/dist/cjs/operation-node/select-all-node.js +17 -0
  257. package/dist/cjs/operation-node/select-modifier-node.d.ts +16 -0
  258. package/dist/cjs/operation-node/select-modifier-node.js +25 -0
  259. package/dist/cjs/operation-node/select-query-node.d.ts +67 -0
  260. package/dist/cjs/operation-node/select-query-node.js +129 -0
  261. package/dist/cjs/operation-node/selection-node.d.ts +20 -0
  262. package/dist/cjs/operation-node/selection-node.js +32 -0
  263. package/dist/cjs/operation-node/set-operation-node.d.ts +15 -0
  264. package/dist/cjs/operation-node/set-operation-node.js +20 -0
  265. package/dist/cjs/operation-node/simple-reference-expression-node.d.ts +3 -0
  266. package/dist/cjs/operation-node/simple-reference-expression-node.js +2 -0
  267. package/dist/cjs/operation-node/table-node.d.ts +14 -0
  268. package/dist/cjs/operation-node/table-node.js +25 -0
  269. package/dist/cjs/operation-node/top-node.d.ts +14 -0
  270. package/dist/cjs/operation-node/top-node.js +19 -0
  271. package/dist/cjs/operation-node/tuple-node.d.ts +12 -0
  272. package/dist/cjs/operation-node/tuple-node.js +18 -0
  273. package/dist/cjs/operation-node/unary-operation-node.d.ts +13 -0
  274. package/dist/cjs/operation-node/unary-operation-node.js +19 -0
  275. package/dist/cjs/operation-node/unique-constraint-node.d.ts +20 -0
  276. package/dist/cjs/operation-node/unique-constraint-node.js +28 -0
  277. package/dist/cjs/operation-node/update-query-node.d.ts +39 -0
  278. package/dist/cjs/operation-node/update-query-node.js +50 -0
  279. package/dist/cjs/operation-node/using-node.d.ts +13 -0
  280. package/dist/cjs/operation-node/using-node.js +24 -0
  281. package/dist/cjs/operation-node/value-list-node.d.ts +12 -0
  282. package/dist/cjs/operation-node/value-list-node.js +18 -0
  283. package/dist/cjs/operation-node/value-node.d.ts +14 -0
  284. package/dist/cjs/operation-node/value-node.js +25 -0
  285. package/dist/cjs/operation-node/values-node.d.ts +15 -0
  286. package/dist/cjs/operation-node/values-node.js +18 -0
  287. package/dist/cjs/operation-node/when-node.d.ts +14 -0
  288. package/dist/cjs/operation-node/when-node.js +24 -0
  289. package/dist/cjs/operation-node/where-node.d.ts +13 -0
  290. package/dist/cjs/operation-node/where-node.js +28 -0
  291. package/dist/cjs/operation-node/with-node.d.ts +16 -0
  292. package/dist/cjs/operation-node/with-node.js +25 -0
  293. package/dist/cjs/package.json +1 -0
  294. package/dist/cjs/parser/binary-operation-parser.d.ts +21 -0
  295. package/dist/cjs/parser/binary-operation-parser.js +74 -0
  296. package/dist/cjs/parser/coalesce-parser.d.ts +12 -0
  297. package/dist/cjs/parser/coalesce-parser.js +2 -0
  298. package/dist/cjs/parser/collate-parser.d.ts +1 -0
  299. package/dist/cjs/parser/collate-parser.js +2 -0
  300. package/dist/cjs/parser/data-type-parser.d.ts +5 -0
  301. package/dist/cjs/parser/data-type-parser.js +14 -0
  302. package/dist/cjs/parser/default-value-parser.d.ts +4 -0
  303. package/dist/cjs/parser/default-value-parser.js +10 -0
  304. package/dist/cjs/parser/delete-from-parser.d.ts +9 -0
  305. package/dist/cjs/parser/delete-from-parser.js +2 -0
  306. package/dist/cjs/parser/expression-parser.d.ts +20 -0
  307. package/dist/cjs/parser/expression-parser.js +30 -0
  308. package/dist/cjs/parser/fetch-parser.d.ts +2 -0
  309. package/dist/cjs/parser/fetch-parser.js +17 -0
  310. package/dist/cjs/parser/group-by-parser.d.ts +6 -0
  311. package/dist/cjs/parser/group-by-parser.js +11 -0
  312. package/dist/cjs/parser/identifier-parser.d.ts +2 -0
  313. package/dist/cjs/parser/identifier-parser.js +22 -0
  314. package/dist/cjs/parser/insert-values-parser.d.ts +14 -0
  315. package/dist/cjs/parser/insert-values-parser.js +64 -0
  316. package/dist/cjs/parser/join-parser.d.ts +10 -0
  317. package/dist/cjs/parser/join-parser.js +30 -0
  318. package/dist/cjs/parser/merge-into-parser.d.ts +7 -0
  319. package/dist/cjs/parser/merge-into-parser.js +2 -0
  320. package/dist/cjs/parser/merge-parser.d.ts +9 -0
  321. package/dist/cjs/parser/merge-parser.js +31 -0
  322. package/dist/cjs/parser/on-commit-action-parse.d.ts +2 -0
  323. package/dist/cjs/parser/on-commit-action-parse.js +10 -0
  324. package/dist/cjs/parser/on-modify-action-parser.d.ts +2 -0
  325. package/dist/cjs/parser/on-modify-action-parser.js +10 -0
  326. package/dist/cjs/parser/order-by-parser.d.ts +25 -0
  327. package/dist/cjs/parser/order-by-parser.js +71 -0
  328. package/dist/cjs/parser/parse-utils.d.ts +10 -0
  329. package/dist/cjs/parser/parse-utils.js +38 -0
  330. package/dist/cjs/parser/partition-by-parser.d.ts +6 -0
  331. package/dist/cjs/parser/partition-by-parser.js +8 -0
  332. package/dist/cjs/parser/reference-parser.d.ts +31 -0
  333. package/dist/cjs/parser/reference-parser.js +104 -0
  334. package/dist/cjs/parser/returning-parser.d.ts +8 -0
  335. package/dist/cjs/parser/returning-parser.js +2 -0
  336. package/dist/cjs/parser/savepoint-parser.d.ts +4 -0
  337. package/dist/cjs/parser/savepoint-parser.js +11 -0
  338. package/dist/cjs/parser/select-from-parser.d.ts +6 -0
  339. package/dist/cjs/parser/select-from-parser.js +2 -0
  340. package/dist/cjs/parser/select-parser.d.ts +36 -0
  341. package/dist/cjs/parser/select-parser.js +50 -0
  342. package/dist/cjs/parser/set-operation-parser.d.ts +5 -0
  343. package/dist/cjs/parser/set-operation-parser.js +16 -0
  344. package/dist/cjs/parser/table-parser.d.ts +24 -0
  345. package/dist/cjs/parser/table-parser.js +54 -0
  346. package/dist/cjs/parser/top-parser.d.ts +2 -0
  347. package/dist/cjs/parser/top-parser.js +19 -0
  348. package/dist/cjs/parser/tuple-parser.d.ts +47 -0
  349. package/dist/cjs/parser/tuple-parser.js +2 -0
  350. package/dist/cjs/parser/unary-operation-parser.d.ts +8 -0
  351. package/dist/cjs/parser/unary-operation-parser.js +17 -0
  352. package/dist/cjs/parser/update-parser.d.ts +9 -0
  353. package/dist/cjs/parser/update-parser.js +2 -0
  354. package/dist/cjs/parser/update-set-parser.d.ts +16 -0
  355. package/dist/cjs/parser/update-set-parser.js +26 -0
  356. package/dist/cjs/parser/value-parser.d.ts +13 -0
  357. package/dist/cjs/parser/value-parser.js +38 -0
  358. package/dist/cjs/parser/with-parser.d.ts +45 -0
  359. package/dist/cjs/parser/with-parser.js +33 -0
  360. package/dist/cjs/performance/query-analyzer.d.ts +89 -0
  361. package/dist/cjs/performance/query-analyzer.js +263 -0
  362. package/dist/cjs/plugin/camel-case/camel-case-plugin.d.ts +170 -0
  363. package/dist/cjs/plugin/camel-case/camel-case-plugin.js +122 -0
  364. package/dist/cjs/plugin/camel-case/camel-case-transformer.d.ts +9 -0
  365. package/dist/cjs/plugin/camel-case/camel-case-transformer.js +19 -0
  366. package/dist/cjs/plugin/camel-case/camel-case.d.ts +15 -0
  367. package/dist/cjs/plugin/camel-case/camel-case.js +111 -0
  368. package/dist/cjs/plugin/deduplicate-joins/deduplicate-joins-plugin.d.ts +70 -0
  369. package/dist/cjs/plugin/deduplicate-joins/deduplicate-joins-plugin.js +19 -0
  370. package/dist/cjs/plugin/deduplicate-joins/deduplicate-joins-transformer.d.ts +11 -0
  371. package/dist/cjs/plugin/deduplicate-joins/deduplicate-joins-transformer.js +42 -0
  372. package/dist/cjs/plugin/handle-empty-in-lists/handle-empty-in-lists-plugin.d.ts +211 -0
  373. package/dist/cjs/plugin/handle-empty-in-lists/handle-empty-in-lists-plugin.js +162 -0
  374. package/dist/cjs/plugin/handle-empty-in-lists/handle-empty-in-lists-transformer.d.ts +8 -0
  375. package/dist/cjs/plugin/handle-empty-in-lists/handle-empty-in-lists-transformer.js +29 -0
  376. package/dist/cjs/plugin/handle-empty-in-lists/handle-empty-in-lists.d.ts +44 -0
  377. package/dist/cjs/plugin/handle-empty-in-lists/handle-empty-in-lists.js +66 -0
  378. package/dist/cjs/plugin/immediate-value/immediate-value-plugin.d.ts +73 -0
  379. package/dist/cjs/plugin/immediate-value/immediate-value-plugin.js +22 -0
  380. package/dist/cjs/plugin/immediate-value/immediate-value-transformer.d.ts +15 -0
  381. package/dist/cjs/plugin/immediate-value/immediate-value-transformer.js +23 -0
  382. package/dist/cjs/plugin/kysely-plugin.d.ts +72 -0
  383. package/dist/cjs/plugin/kysely-plugin.js +2 -0
  384. package/dist/cjs/plugin/noop-plugin.d.ts +64 -0
  385. package/dist/cjs/plugin/noop-plugin.js +12 -0
  386. package/dist/cjs/plugin/parse-json-results/parse-json-results-plugin.d.ts +126 -0
  387. package/dist/cjs/plugin/parse-json-results/parse-json-results-plugin.js +107 -0
  388. package/dist/cjs/plugin/with-schema/with-schema-plugin.d.ts +66 -0
  389. package/dist/cjs/plugin/with-schema/with-schema-plugin.js +17 -0
  390. package/dist/cjs/plugin/with-schema/with-schema-transformer.d.ts +16 -0
  391. package/dist/cjs/plugin/with-schema/with-schema-transformer.js +181 -0
  392. package/dist/cjs/query-builder/aggregate-function-builder.d.ts +379 -0
  393. package/dist/cjs/query-builder/aggregate-function-builder.js +242 -0
  394. package/dist/cjs/query-builder/case-builder.d.ts +112 -0
  395. package/dist/cjs/query-builder/case-builder.js +79 -0
  396. package/dist/cjs/query-builder/cte-builder.d.ts +20 -0
  397. package/dist/cjs/query-builder/cte-builder.js +37 -0
  398. package/dist/cjs/query-builder/delete-query-builder.d.ts +1348 -0
  399. package/dist/cjs/query-builder/delete-query-builder.js +504 -0
  400. package/dist/cjs/query-builder/delete-result.d.ts +4 -0
  401. package/dist/cjs/query-builder/delete-result.js +10 -0
  402. package/dist/cjs/query-builder/function-module.d.ts +592 -0
  403. package/dist/cjs/query-builder/function-module.js +62 -0
  404. package/dist/cjs/query-builder/having-interface.d.ts +15 -0
  405. package/dist/cjs/query-builder/having-interface.js +2 -0
  406. package/dist/cjs/query-builder/insert-query-builder.d.ts +1235 -0
  407. package/dist/cjs/query-builder/insert-query-builder.js +1160 -0
  408. package/dist/cjs/query-builder/insert-result.d.ts +46 -0
  409. package/dist/cjs/query-builder/insert-result.js +53 -0
  410. package/dist/cjs/query-builder/join-builder.d.ts +38 -0
  411. package/dist/cjs/query-builder/join-builder.js +51 -0
  412. package/dist/cjs/query-builder/json-path-builder.d.ts +294 -0
  413. package/dist/cjs/query-builder/json-path-builder.js +200 -0
  414. package/dist/cjs/query-builder/merge-query-builder.d.ts +1001 -0
  415. package/dist/cjs/query-builder/merge-query-builder.js +630 -0
  416. package/dist/cjs/query-builder/merge-result.d.ts +4 -0
  417. package/dist/cjs/query-builder/merge-result.js +10 -0
  418. package/dist/cjs/query-builder/no-result-error.d.ts +10 -0
  419. package/dist/cjs/query-builder/no-result-error.js +18 -0
  420. package/dist/cjs/query-builder/on-conflict-builder.d.ts +872 -0
  421. package/dist/cjs/query-builder/on-conflict-builder.js +259 -0
  422. package/dist/cjs/query-builder/order-by-interface.d.ts +158 -0
  423. package/dist/cjs/query-builder/order-by-interface.js +2 -0
  424. package/dist/cjs/query-builder/order-by-item-builder.d.ts +43 -0
  425. package/dist/cjs/query-builder/order-by-item-builder.js +75 -0
  426. package/dist/cjs/query-builder/output-interface.d.ts +138 -0
  427. package/dist/cjs/query-builder/output-interface.js +2 -0
  428. package/dist/cjs/query-builder/over-builder.d.ts +101 -0
  429. package/dist/cjs/query-builder/over-builder.js +40 -0
  430. package/dist/cjs/query-builder/returning-interface.d.ts +91 -0
  431. package/dist/cjs/query-builder/returning-interface.js +2 -0
  432. package/dist/cjs/query-builder/select-query-builder-expression.d.ts +28 -0
  433. package/dist/cjs/query-builder/select-query-builder-expression.js +2 -0
  434. package/dist/cjs/query-builder/select-query-builder.d.ts +2391 -0
  435. package/dist/cjs/query-builder/select-query-builder.js +376 -0
  436. package/dist/cjs/query-builder/update-query-builder.d.ts +1392 -0
  437. package/dist/cjs/query-builder/update-query-builder.js +513 -0
  438. package/dist/cjs/query-builder/update-result.d.ts +14 -0
  439. package/dist/cjs/query-builder/update-result.js +21 -0
  440. package/dist/cjs/query-builder/where-interface.d.ts +382 -0
  441. package/dist/cjs/query-builder/where-interface.js +2 -0
  442. package/dist/cjs/query-compiler/compiled-query.d.ts +11 -0
  443. package/dist/cjs/query-compiler/compiled-query.js +16 -0
  444. package/dist/cjs/query-compiler/default-query-compiler.d.ts +235 -0
  445. package/dist/cjs/query-compiler/default-query-compiler.js +1390 -0
  446. package/dist/cjs/query-compiler/query-compiler.d.ts +24 -0
  447. package/dist/cjs/query-compiler/query-compiler.js +2 -0
  448. package/dist/cjs/query-creator.d.ts +592 -0
  449. package/dist/cjs/query-creator.js +622 -0
  450. package/dist/cjs/query-executor/default-query-executor.d.ts +50 -0
  451. package/dist/cjs/query-executor/default-query-executor.js +40 -0
  452. package/dist/cjs/query-executor/noop-query-executor.d.ts +50 -0
  453. package/dist/cjs/query-executor/noop-query-executor.js +37 -0
  454. package/dist/cjs/query-executor/query-executor-base.d.ts +68 -0
  455. package/dist/cjs/query-executor/query-executor-base.js +62 -0
  456. package/dist/cjs/query-executor/query-executor-provider.d.ts +8 -0
  457. package/dist/cjs/query-executor/query-executor-provider.js +2 -0
  458. package/dist/cjs/query-executor/query-executor.d.ts +74 -0
  459. package/dist/cjs/query-executor/query-executor.js +2 -0
  460. package/dist/cjs/raw-builder/raw-builder.d.ts +218 -0
  461. package/dist/cjs/raw-builder/raw-builder.js +86 -0
  462. package/dist/cjs/raw-builder/sql.d.ts +366 -0
  463. package/dist/cjs/raw-builder/sql.js +84 -0
  464. package/dist/cjs/relationships/relationship-engine.d.ts +59 -0
  465. package/dist/cjs/relationships/relationship-engine.js +206 -0
  466. package/dist/cjs/repository/repository-factory.d.ts +54 -0
  467. package/dist/cjs/repository/repository-factory.js +449 -0
  468. package/dist/cjs/schema/builders/alter-column-builder.d.ts +53 -0
  469. package/dist/cjs/schema/builders/alter-column-builder.js +74 -0
  470. package/dist/cjs/schema/builders/alter-table-add-foreign-key-constraint-builder.d.ts +32 -0
  471. package/dist/cjs/schema/builders/alter-table-add-foreign-key-constraint-builder.js +67 -0
  472. package/dist/cjs/schema/builders/alter-table-add-index-builder.d.ts +138 -0
  473. package/dist/cjs/schema/builders/alter-table-add-index-builder.js +165 -0
  474. package/dist/cjs/schema/builders/alter-table-builder.d.ts +148 -0
  475. package/dist/cjs/schema/builders/alter-table-builder.js +267 -0
  476. package/dist/cjs/schema/builders/alter-table-drop-constraint-builder.d.ts +26 -0
  477. package/dist/cjs/schema/builders/alter-table-drop-constraint-builder.js +59 -0
  478. package/dist/cjs/schema/builders/alter-table-executor.d.ts +18 -0
  479. package/dist/cjs/schema/builders/alter-table-executor.js +20 -0
  480. package/dist/cjs/schema/builders/check-constraint-builder.d.ts +13 -0
  481. package/dist/cjs/schema/builders/check-constraint-builder.js +20 -0
  482. package/dist/cjs/schema/builders/column-definition-builder.d.ts +514 -0
  483. package/dist/cjs/schema/builders/column-definition-builder.js +600 -0
  484. package/dist/cjs/schema/builders/create-index-builder.d.ts +173 -0
  485. package/dist/cjs/schema/builders/create-index-builder.js +202 -0
  486. package/dist/cjs/schema/builders/create-schema-builder.d.ts +24 -0
  487. package/dist/cjs/schema/builders/create-schema-builder.js +34 -0
  488. package/dist/cjs/schema/builders/create-table-builder.d.ts +331 -0
  489. package/dist/cjs/schema/builders/create-table-builder.js +411 -0
  490. package/dist/cjs/schema/builders/create-type-builder.d.ts +33 -0
  491. package/dist/cjs/schema/builders/create-type-builder.js +43 -0
  492. package/dist/cjs/schema/builders/create-view-builder.d.ts +48 -0
  493. package/dist/cjs/schema/builders/create-view-builder.js +98 -0
  494. package/dist/cjs/schema/builders/drop-index-builder.d.ts +30 -0
  495. package/dist/cjs/schema/builders/drop-index-builder.js +57 -0
  496. package/dist/cjs/schema/builders/drop-schema-builder.d.ts +25 -0
  497. package/dist/cjs/schema/builders/drop-schema-builder.js +44 -0
  498. package/dist/cjs/schema/builders/drop-table-builder.d.ts +25 -0
  499. package/dist/cjs/schema/builders/drop-table-builder.js +44 -0
  500. package/dist/cjs/schema/builders/drop-type-builder.d.ts +24 -0
  501. package/dist/cjs/schema/builders/drop-type-builder.js +36 -0
  502. package/dist/cjs/schema/builders/drop-view-builder.d.ts +26 -0
  503. package/dist/cjs/schema/builders/drop-view-builder.js +52 -0
  504. package/dist/cjs/schema/builders/foreign-key-constraint-builder.d.ts +28 -0
  505. package/dist/cjs/schema/builders/foreign-key-constraint-builder.js +48 -0
  506. package/dist/cjs/schema/builders/index.d.ts +22 -0
  507. package/dist/cjs/schema/builders/index.js +39 -0
  508. package/dist/cjs/schema/builders/primary-key-constraint-builder.d.ts +17 -0
  509. package/dist/cjs/schema/builders/primary-key-constraint-builder.js +37 -0
  510. package/dist/cjs/schema/builders/refresh-materialized-view-builder.d.ts +47 -0
  511. package/dist/cjs/schema/builders/refresh-materialized-view-builder.js +75 -0
  512. package/dist/cjs/schema/builders/unique-constraint-builder.d.ts +23 -0
  513. package/dist/cjs/schema/builders/unique-constraint-builder.js +45 -0
  514. package/dist/cjs/schema/core/coordinators/schema-discovery.coordinator.d.ts +35 -0
  515. package/dist/cjs/schema/core/coordinators/schema-discovery.coordinator.js +63 -0
  516. package/dist/cjs/schema/core/discovery/relationship-discovery.d.ts +36 -0
  517. package/dist/cjs/schema/core/discovery/relationship-discovery.js +162 -0
  518. package/dist/cjs/schema/core/discovery/table-metadata-discovery.d.ts +29 -0
  519. package/dist/cjs/schema/core/discovery/table-metadata-discovery.js +126 -0
  520. package/dist/cjs/schema/core/discovery/view-discovery.d.ts +36 -0
  521. package/dist/cjs/schema/core/discovery/view-discovery.js +137 -0
  522. package/dist/cjs/schema/core/factories/discovery-factory.d.ts +66 -0
  523. package/dist/cjs/schema/core/factories/discovery-factory.js +122 -0
  524. package/dist/cjs/schema/core/types/schema-discovery-types.d.ts +43 -0
  525. package/dist/cjs/schema/core/types/schema-discovery-types.js +3 -0
  526. package/dist/cjs/schema/core/utils/name-generator.d.ts +21 -0
  527. package/dist/cjs/schema/core/utils/name-generator.js +55 -0
  528. package/dist/cjs/schema/core/utils/type-mapper.d.ts +25 -0
  529. package/dist/cjs/schema/core/utils/type-mapper.js +61 -0
  530. package/dist/cjs/schema/dialects/sqlite/discovery/sqlite-constraint-discovery.d.ts +97 -0
  531. package/dist/cjs/schema/dialects/sqlite/discovery/sqlite-constraint-discovery.js +533 -0
  532. package/dist/cjs/schema/dialects/sqlite/discovery/sqlite-index-discovery.d.ts +32 -0
  533. package/dist/cjs/schema/dialects/sqlite/discovery/sqlite-index-discovery.js +133 -0
  534. package/dist/cjs/schema/dialects/sqlite/introspection/sqlite-schema-introspector.d.ts +31 -0
  535. package/dist/cjs/schema/dialects/sqlite/introspection/sqlite-schema-introspector.js +192 -0
  536. package/dist/cjs/schema/dialects/sqlite/sqlite-discovery.coordinator.d.ts +51 -0
  537. package/dist/cjs/schema/dialects/sqlite/sqlite-discovery.coordinator.js +180 -0
  538. package/dist/cjs/schema/index.d.ts +14 -0
  539. package/dist/cjs/schema/index.js +49 -0
  540. package/dist/cjs/schema/schema-discovery.d.ts +23 -0
  541. package/dist/cjs/schema/schema-discovery.js +33 -0
  542. package/dist/cjs/schema/schema.d.ts +230 -0
  543. package/dist/cjs/schema/schema.js +328 -0
  544. package/dist/cjs/schema/test/basic-schema-test.d.ts +8 -0
  545. package/dist/cjs/schema/test/basic-schema-test.js +184 -0
  546. package/dist/cjs/schema/test/dialect-capabilities.test.d.ts +1 -0
  547. package/dist/cjs/schema/test/dialect-capabilities.test.js +153 -0
  548. package/dist/cjs/schema/test/discovery-factory.test.d.ts +1 -0
  549. package/dist/cjs/schema/test/discovery-factory.test.js +151 -0
  550. package/dist/cjs/schema/test/error-handling.test.d.ts +1 -0
  551. package/dist/cjs/schema/test/error-handling.test.js +149 -0
  552. package/dist/cjs/schema/test/integration.test.d.ts +1 -0
  553. package/dist/cjs/schema/test/integration.test.js +135 -0
  554. package/dist/cjs/schema/test/schema-discovery-coordinator.test.d.ts +1 -0
  555. package/dist/cjs/schema/test/schema-discovery-coordinator.test.js +139 -0
  556. package/dist/cjs/schema/test/simple-schema-test.d.ts +5 -0
  557. package/dist/cjs/schema/test/simple-schema-test.js +77 -0
  558. package/dist/cjs/schema/test/sqlite-discovery-coordinator.test.d.ts +1 -0
  559. package/dist/cjs/schema/test/sqlite-discovery-coordinator.test.js +377 -0
  560. package/dist/cjs/schema/test/test-runner.d.ts +66 -0
  561. package/dist/cjs/schema/test/test-runner.js +90 -0
  562. package/dist/cjs/sqlite-migration/index.d.ts +6 -0
  563. package/dist/cjs/sqlite-migration/index.js +20 -0
  564. package/dist/cjs/sqlite-migration/sqlite-migration-manager.d.ts +104 -0
  565. package/dist/cjs/sqlite-migration/sqlite-migration-manager.js +335 -0
  566. package/dist/cjs/sqlite-migration/sqlite-migration-provider.d.ts +77 -0
  567. package/dist/cjs/sqlite-migration/sqlite-migration-provider.js +342 -0
  568. package/dist/cjs/testing/test-utils.d.ts +110 -0
  569. package/dist/cjs/testing/test-utils.js +328 -0
  570. package/dist/cjs/types/index.d.ts +155 -0
  571. package/dist/cjs/types/index.js +5 -0
  572. package/dist/cjs/types/type-generator.d.ts +52 -0
  573. package/dist/cjs/types/type-generator.js +261 -0
  574. package/dist/cjs/util/assert.d.ts +2 -0
  575. package/dist/cjs/util/assert.js +14 -0
  576. package/dist/cjs/util/column-type.d.ts +175 -0
  577. package/dist/cjs/util/column-type.js +2 -0
  578. package/dist/cjs/util/compilable.d.ts +5 -0
  579. package/dist/cjs/util/compilable.js +7 -0
  580. package/dist/cjs/util/deferred.d.ts +7 -0
  581. package/dist/cjs/util/deferred.js +28 -0
  582. package/dist/cjs/util/explainable.d.ts +40 -0
  583. package/dist/cjs/util/explainable.js +2 -0
  584. package/dist/cjs/util/infer-result.d.ts +48 -0
  585. package/dist/cjs/util/infer-result.js +2 -0
  586. package/dist/cjs/util/json-object-args.d.ts +3 -0
  587. package/dist/cjs/util/json-object-args.js +34 -0
  588. package/dist/cjs/util/log-once.d.ts +5 -0
  589. package/dist/cjs/util/log-once.js +15 -0
  590. package/dist/cjs/util/log.d.ts +26 -0
  591. package/dist/cjs/util/log.js +58 -0
  592. package/dist/cjs/util/object-utils.d.ts +23 -0
  593. package/dist/cjs/util/object-utils.js +162 -0
  594. package/dist/cjs/util/performance-now.d.ts +1 -0
  595. package/dist/cjs/util/performance-now.js +12 -0
  596. package/dist/cjs/util/provide-controlled-connection.d.ts +7 -0
  597. package/dist/cjs/util/provide-controlled-connection.js +24 -0
  598. package/dist/cjs/util/query-id.d.ts +4 -0
  599. package/dist/cjs/util/query-id.js +16 -0
  600. package/dist/cjs/util/random-string.d.ts +1 -0
  601. package/dist/cjs/util/random-string.js +77 -0
  602. package/dist/cjs/util/require-all-props.d.ts +45 -0
  603. package/dist/cjs/util/require-all-props.js +41 -0
  604. package/dist/cjs/util/stack-trace-utils.d.ts +1 -0
  605. package/dist/cjs/util/stack-trace-utils.js +16 -0
  606. package/dist/cjs/util/streamable.d.ts +29 -0
  607. package/dist/cjs/util/streamable.js +2 -0
  608. package/dist/cjs/util/type-error.d.ts +3 -0
  609. package/dist/cjs/util/type-error.js +2 -0
  610. package/dist/cjs/util/type-utils.d.ts +189 -0
  611. package/dist/cjs/util/type-utils.js +2 -0
  612. package/dist/cjs/utils/errorHelpers.d.ts +26 -0
  613. package/dist/cjs/utils/errorHelpers.js +186 -0
  614. package/dist/cjs/watch/schema-watcher.d.ts +68 -0
  615. package/dist/cjs/watch/schema-watcher.js +186 -0
  616. package/dist/esm/cache/cache-manager.d.ts +76 -0
  617. package/dist/esm/cache/cache-manager.js +166 -0
  618. package/dist/esm/cli/commands/analyze.d.ts +7 -0
  619. package/dist/esm/cli/commands/analyze.js +130 -0
  620. package/dist/esm/cli/commands/generate.d.ts +7 -0
  621. package/dist/esm/cli/commands/generate.js +512 -0
  622. package/dist/esm/cli/commands/init.d.ts +7 -0
  623. package/dist/esm/cli/commands/init.js +468 -0
  624. package/dist/esm/cli/commands/inspect.d.ts +7 -0
  625. package/dist/esm/cli/commands/inspect.js +363 -0
  626. package/dist/esm/cli/commands/migrate.d.ts +8 -0
  627. package/dist/esm/cli/commands/migrate.js +216 -0
  628. package/dist/esm/cli/commands/optimize.d.ts +8 -0
  629. package/dist/esm/cli/commands/optimize.js +154 -0
  630. package/dist/esm/cli/commands/status.d.ts +6 -0
  631. package/dist/esm/cli/commands/status.js +265 -0
  632. package/dist/esm/cli/commands/watch.d.ts +7 -0
  633. package/dist/esm/cli/commands/watch.js +214 -0
  634. package/dist/esm/cli/index.d.ts +2 -0
  635. package/dist/esm/cli/index.js +156 -0
  636. package/dist/esm/dialect/database-introspector.d.ts +61 -0
  637. package/dist/esm/dialect/database-introspector.js +82 -0
  638. package/dist/esm/dialect/dialect-adapter-base.d.ts +94 -0
  639. package/dist/esm/dialect/dialect-adapter-base.js +21 -0
  640. package/dist/esm/dialect/dialect-adapter.d.ts +115 -0
  641. package/dist/esm/dialect/dialect-adapter.js +2 -0
  642. package/dist/esm/dialect/dialect.d.ts +34 -0
  643. package/dist/esm/dialect/dialect.js +2 -0
  644. package/dist/esm/dialect/sqlite/sqlite-adapter.d.ts +80 -0
  645. package/dist/esm/dialect/sqlite/sqlite-adapter.js +20 -0
  646. package/dist/esm/dialect/sqlite/sqlite-auto-indexer.d.ts +181 -0
  647. package/dist/esm/dialect/sqlite/sqlite-auto-indexer.js +538 -0
  648. package/dist/esm/dialect/sqlite/sqlite-auto-optimizer.d.ts +102 -0
  649. package/dist/esm/dialect/sqlite/sqlite-auto-optimizer.js +370 -0
  650. package/dist/esm/dialect/sqlite/sqlite-dialect-config.d.ts +41 -0
  651. package/dist/esm/dialect/sqlite/sqlite-dialect-config.js +2 -0
  652. package/dist/esm/dialect/sqlite/sqlite-dialect.d.ts +55 -0
  653. package/dist/esm/dialect/sqlite/sqlite-dialect.js +48 -0
  654. package/dist/esm/dialect/sqlite/sqlite-driver.d.ts +42 -0
  655. package/dist/esm/dialect/sqlite/sqlite-driver.js +149 -0
  656. package/dist/esm/dialect/sqlite/sqlite-introspector.d.ts +36 -0
  657. package/dist/esm/dialect/sqlite/sqlite-introspector.js +233 -0
  658. package/dist/esm/dialect/sqlite/sqlite-query-compiler.d.ts +16 -0
  659. package/dist/esm/dialect/sqlite/sqlite-query-compiler.js +40 -0
  660. package/dist/esm/driver/connection-provider.d.ts +8 -0
  661. package/dist/esm/driver/connection-provider.js +2 -0
  662. package/dist/esm/driver/database-connection.d.ts +35 -0
  663. package/dist/esm/driver/database-connection.js +2 -0
  664. package/dist/esm/driver/default-connection-provider.d.ts +12 -0
  665. package/dist/esm/driver/default-connection-provider.js +16 -0
  666. package/dist/esm/driver/driver.d.ts +61 -0
  667. package/dist/esm/driver/driver.js +19 -0
  668. package/dist/esm/driver/dummy-driver.d.ts +75 -0
  669. package/dist/esm/driver/dummy-driver.js +80 -0
  670. package/dist/esm/driver/runtime-driver.d.ts +47 -0
  671. package/dist/esm/driver/runtime-driver.js +162 -0
  672. package/dist/esm/driver/single-connection-provider.d.ts +11 -0
  673. package/dist/esm/driver/single-connection-provider.js +26 -0
  674. package/dist/esm/dynamic/dynamic-reference-builder.d.ts +18 -0
  675. package/dist/esm/dynamic/dynamic-reference-builder.js +32 -0
  676. package/dist/esm/dynamic/dynamic-table-builder.d.ts +16 -0
  677. package/dist/esm/dynamic/dynamic-table-builder.js +41 -0
  678. package/dist/esm/dynamic/dynamic.d.ts +124 -0
  679. package/dist/esm/dynamic/dynamic.js +129 -0
  680. package/dist/esm/errors/NoormError.d.ts +56 -0
  681. package/dist/esm/errors/NoormError.js +150 -0
  682. package/dist/esm/expression/expression-builder.d.ts +920 -0
  683. package/dist/esm/expression/expression-builder.js +125 -0
  684. package/dist/esm/expression/expression-wrapper.d.ts +631 -0
  685. package/dist/esm/expression/expression-wrapper.js +128 -0
  686. package/dist/esm/expression/expression.d.ts +198 -0
  687. package/dist/esm/expression/expression.js +12 -0
  688. package/dist/esm/helpers/sqlite.d.ts +189 -0
  689. package/dist/esm/helpers/sqlite.js +200 -0
  690. package/dist/esm/index.d.ts +211 -0
  691. package/dist/esm/index.js +203 -0
  692. package/dist/esm/kysely.d.ts +848 -0
  693. package/dist/esm/kysely.js +914 -0
  694. package/dist/esm/logging/logger.d.ts +96 -0
  695. package/dist/esm/logging/logger.js +176 -0
  696. package/dist/esm/noormme.d.ts +137 -0
  697. package/dist/esm/noormme.js +518 -0
  698. package/dist/esm/operation-node/add-column-node.d.ts +13 -0
  699. package/dist/esm/operation-node/add-column-node.js +16 -0
  700. package/dist/esm/operation-node/add-constraint-node.d.ts +13 -0
  701. package/dist/esm/operation-node/add-constraint-node.js +16 -0
  702. package/dist/esm/operation-node/add-index-node.d.ts +21 -0
  703. package/dist/esm/operation-node/add-index-node.js +29 -0
  704. package/dist/esm/operation-node/aggregate-function-node.d.ts +27 -0
  705. package/dist/esm/operation-node/aggregate-function-node.js +56 -0
  706. package/dist/esm/operation-node/alias-node.d.ts +13 -0
  707. package/dist/esm/operation-node/alias-node.js +17 -0
  708. package/dist/esm/operation-node/alter-column-node.d.ts +21 -0
  709. package/dist/esm/operation-node/alter-column-node.js +18 -0
  710. package/dist/esm/operation-node/alter-table-node.d.ts +36 -0
  711. package/dist/esm/operation-node/alter-table-node.js +30 -0
  712. package/dist/esm/operation-node/and-node.d.ts +13 -0
  713. package/dist/esm/operation-node/and-node.js +17 -0
  714. package/dist/esm/operation-node/binary-operation-node.d.ts +14 -0
  715. package/dist/esm/operation-node/binary-operation-node.js +18 -0
  716. package/dist/esm/operation-node/case-node.d.ts +19 -0
  717. package/dist/esm/operation-node/case-node.js +40 -0
  718. package/dist/esm/operation-node/cast-node.d.ts +13 -0
  719. package/dist/esm/operation-node/cast-node.js +17 -0
  720. package/dist/esm/operation-node/check-constraint-node.d.ts +14 -0
  721. package/dist/esm/operation-node/check-constraint-node.js +18 -0
  722. package/dist/esm/operation-node/collate-node.d.ts +13 -0
  723. package/dist/esm/operation-node/collate-node.js +17 -0
  724. package/dist/esm/operation-node/column-definition-node.d.ts +36 -0
  725. package/dist/esm/operation-node/column-definition-node.js +40 -0
  726. package/dist/esm/operation-node/column-node.d.ts +13 -0
  727. package/dist/esm/operation-node/column-node.js +17 -0
  728. package/dist/esm/operation-node/column-update-node.d.ts +13 -0
  729. package/dist/esm/operation-node/column-update-node.js +17 -0
  730. package/dist/esm/operation-node/common-table-expression-name-node.d.ts +15 -0
  731. package/dist/esm/operation-node/common-table-expression-name-node.js +21 -0
  732. package/dist/esm/operation-node/common-table-expression-node.d.ts +18 -0
  733. package/dist/esm/operation-node/common-table-expression-node.js +23 -0
  734. package/dist/esm/operation-node/constraint-node.d.ts +5 -0
  735. package/dist/esm/operation-node/constraint-node.js +2 -0
  736. package/dist/esm/operation-node/create-index-node.d.ts +27 -0
  737. package/dist/esm/operation-node/create-index-node.js +29 -0
  738. package/dist/esm/operation-node/create-schema-node.d.ts +16 -0
  739. package/dist/esm/operation-node/create-schema-node.js +24 -0
  740. package/dist/esm/operation-node/create-table-node.d.ts +32 -0
  741. package/dist/esm/operation-node/create-table-node.js +54 -0
  742. package/dist/esm/operation-node/create-type-node.d.ts +17 -0
  743. package/dist/esm/operation-node/create-type-node.js +24 -0
  744. package/dist/esm/operation-node/create-view-node.d.ts +24 -0
  745. package/dist/esm/operation-node/create-view-node.js +23 -0
  746. package/dist/esm/operation-node/data-type-node.d.ts +18 -0
  747. package/dist/esm/operation-node/data-type-node.js +83 -0
  748. package/dist/esm/operation-node/default-insert-value-node.d.ts +11 -0
  749. package/dist/esm/operation-node/default-insert-value-node.js +15 -0
  750. package/dist/esm/operation-node/default-value-node.d.ts +12 -0
  751. package/dist/esm/operation-node/default-value-node.js +16 -0
  752. package/dist/esm/operation-node/delete-query-node.d.ts +46 -0
  753. package/dist/esm/operation-node/delete-query-node.js +50 -0
  754. package/dist/esm/operation-node/drop-column-node.d.ts +13 -0
  755. package/dist/esm/operation-node/drop-column-node.js +17 -0
  756. package/dist/esm/operation-node/drop-constraint-node.d.ts +17 -0
  757. package/dist/esm/operation-node/drop-constraint-node.js +23 -0
  758. package/dist/esm/operation-node/drop-index-node.d.ts +19 -0
  759. package/dist/esm/operation-node/drop-index-node.js +24 -0
  760. package/dist/esm/operation-node/drop-schema-node.d.ts +17 -0
  761. package/dist/esm/operation-node/drop-schema-node.js +24 -0
  762. package/dist/esm/operation-node/drop-table-node.d.ts +17 -0
  763. package/dist/esm/operation-node/drop-table-node.js +23 -0
  764. package/dist/esm/operation-node/drop-type-node.d.ts +16 -0
  765. package/dist/esm/operation-node/drop-type-node.js +22 -0
  766. package/dist/esm/operation-node/drop-view-node.d.ts +18 -0
  767. package/dist/esm/operation-node/drop-view-node.js +23 -0
  768. package/dist/esm/operation-node/explain-node.d.ts +14 -0
  769. package/dist/esm/operation-node/explain-node.js +17 -0
  770. package/dist/esm/operation-node/fetch-node.d.ts +15 -0
  771. package/dist/esm/operation-node/fetch-node.js +17 -0
  772. package/dist/esm/operation-node/foreign-key-constraint-node.d.ts +33 -0
  773. package/dist/esm/operation-node/foreign-key-constraint-node.js +26 -0
  774. package/dist/esm/operation-node/from-node.d.ts +13 -0
  775. package/dist/esm/operation-node/from-node.js +22 -0
  776. package/dist/esm/operation-node/function-node.d.ts +13 -0
  777. package/dist/esm/operation-node/function-node.js +17 -0
  778. package/dist/esm/operation-node/generated-node.d.ts +19 -0
  779. package/dist/esm/operation-node/generated-node.js +29 -0
  780. package/dist/esm/operation-node/group-by-item-node.d.ts +12 -0
  781. package/dist/esm/operation-node/group-by-item-node.js +16 -0
  782. package/dist/esm/operation-node/group-by-node.d.ts +14 -0
  783. package/dist/esm/operation-node/group-by-node.js +22 -0
  784. package/dist/esm/operation-node/having-node.d.ts +13 -0
  785. package/dist/esm/operation-node/having-node.js +26 -0
  786. package/dist/esm/operation-node/identifier-node.d.ts +12 -0
  787. package/dist/esm/operation-node/identifier-node.js +16 -0
  788. package/dist/esm/operation-node/insert-query-node.d.ts +40 -0
  789. package/dist/esm/operation-node/insert-query-node.js +29 -0
  790. package/dist/esm/operation-node/join-node.d.ts +18 -0
  791. package/dist/esm/operation-node/join-node.js +35 -0
  792. package/dist/esm/operation-node/json-operator-chain-node.d.ts +16 -0
  793. package/dist/esm/operation-node/json-operator-chain-node.js +23 -0
  794. package/dist/esm/operation-node/json-path-leg-node.d.ts +14 -0
  795. package/dist/esm/operation-node/json-path-leg-node.js +17 -0
  796. package/dist/esm/operation-node/json-path-node.d.ts +16 -0
  797. package/dist/esm/operation-node/json-path-node.js +23 -0
  798. package/dist/esm/operation-node/json-reference-node.d.ts +17 -0
  799. package/dist/esm/operation-node/json-reference-node.js +23 -0
  800. package/dist/esm/operation-node/limit-node.d.ts +12 -0
  801. package/dist/esm/operation-node/limit-node.js +16 -0
  802. package/dist/esm/operation-node/list-node.d.ts +12 -0
  803. package/dist/esm/operation-node/list-node.js +16 -0
  804. package/dist/esm/operation-node/matched-node.d.ts +13 -0
  805. package/dist/esm/operation-node/matched-node.js +17 -0
  806. package/dist/esm/operation-node/merge-query-node.d.ts +30 -0
  807. package/dist/esm/operation-node/merge-query-node.js +43 -0
  808. package/dist/esm/operation-node/modify-column-node.d.ts +13 -0
  809. package/dist/esm/operation-node/modify-column-node.js +16 -0
  810. package/dist/esm/operation-node/offset-node.d.ts +12 -0
  811. package/dist/esm/operation-node/offset-node.js +16 -0
  812. package/dist/esm/operation-node/on-conflict-node.d.ts +30 -0
  813. package/dist/esm/operation-node/on-conflict-node.js +66 -0
  814. package/dist/esm/operation-node/on-duplicate-key-node.d.ts +14 -0
  815. package/dist/esm/operation-node/on-duplicate-key-node.js +16 -0
  816. package/dist/esm/operation-node/on-node.d.ts +13 -0
  817. package/dist/esm/operation-node/on-node.js +26 -0
  818. package/dist/esm/operation-node/operation-node-source.d.ts +5 -0
  819. package/dist/esm/operation-node/operation-node-source.js +5 -0
  820. package/dist/esm/operation-node/operation-node-transformer.d.ts +238 -0
  821. package/dist/esm/operation-node/operation-node-transformer.js +926 -0
  822. package/dist/esm/operation-node/operation-node-visitor.d.ts +201 -0
  823. package/dist/esm/operation-node/operation-node-visitor.js +112 -0
  824. package/dist/esm/operation-node/operation-node.d.ts +4 -0
  825. package/dist/esm/operation-node/operation-node.js +2 -0
  826. package/dist/esm/operation-node/operator-node.d.ts +32 -0
  827. package/dist/esm/operation-node/operator-node.js +100 -0
  828. package/dist/esm/operation-node/or-action-node.d.ts +12 -0
  829. package/dist/esm/operation-node/or-action-node.js +16 -0
  830. package/dist/esm/operation-node/or-node.d.ts +13 -0
  831. package/dist/esm/operation-node/or-node.js +17 -0
  832. package/dist/esm/operation-node/order-by-item-node.d.ts +18 -0
  833. package/dist/esm/operation-node/order-by-item-node.js +23 -0
  834. package/dist/esm/operation-node/order-by-node.d.ts +14 -0
  835. package/dist/esm/operation-node/order-by-node.js +22 -0
  836. package/dist/esm/operation-node/output-node.d.ts +13 -0
  837. package/dist/esm/operation-node/output-node.js +24 -0
  838. package/dist/esm/operation-node/over-node.d.ts +19 -0
  839. package/dist/esm/operation-node/over-node.js +33 -0
  840. package/dist/esm/operation-node/parens-node.d.ts +12 -0
  841. package/dist/esm/operation-node/parens-node.js +16 -0
  842. package/dist/esm/operation-node/partition-by-item-node.d.ts +13 -0
  843. package/dist/esm/operation-node/partition-by-item-node.js +16 -0
  844. package/dist/esm/operation-node/partition-by-node.d.ts +14 -0
  845. package/dist/esm/operation-node/partition-by-node.js +22 -0
  846. package/dist/esm/operation-node/primary-key-constraint-node.d.ts +29 -0
  847. package/dist/esm/operation-node/primary-key-constraint-node.js +28 -0
  848. package/dist/esm/operation-node/primitive-value-list-node.d.ts +17 -0
  849. package/dist/esm/operation-node/primitive-value-list-node.js +16 -0
  850. package/dist/esm/operation-node/query-node.d.ts +60 -0
  851. package/dist/esm/operation-node/query-node.js +100 -0
  852. package/dist/esm/operation-node/raw-node.d.ts +16 -0
  853. package/dist/esm/operation-node/raw-node.js +26 -0
  854. package/dist/esm/operation-node/reference-node.d.ts +17 -0
  855. package/dist/esm/operation-node/reference-node.js +25 -0
  856. package/dist/esm/operation-node/references-node.d.ts +22 -0
  857. package/dist/esm/operation-node/references-node.js +36 -0
  858. package/dist/esm/operation-node/refresh-materialized-view-node.d.ts +17 -0
  859. package/dist/esm/operation-node/refresh-materialized-view-node.js +23 -0
  860. package/dist/esm/operation-node/rename-column-node.d.ts +14 -0
  861. package/dist/esm/operation-node/rename-column-node.js +18 -0
  862. package/dist/esm/operation-node/rename-constraint-node.d.ts +14 -0
  863. package/dist/esm/operation-node/rename-constraint-node.js +18 -0
  864. package/dist/esm/operation-node/returning-node.d.ts +14 -0
  865. package/dist/esm/operation-node/returning-node.js +24 -0
  866. package/dist/esm/operation-node/schemable-identifier-node.d.ts +15 -0
  867. package/dist/esm/operation-node/schemable-identifier-node.js +24 -0
  868. package/dist/esm/operation-node/select-all-node.d.ts +11 -0
  869. package/dist/esm/operation-node/select-all-node.js +15 -0
  870. package/dist/esm/operation-node/select-modifier-node.d.ts +16 -0
  871. package/dist/esm/operation-node/select-modifier-node.js +23 -0
  872. package/dist/esm/operation-node/select-query-node.d.ts +67 -0
  873. package/dist/esm/operation-node/select-query-node.js +127 -0
  874. package/dist/esm/operation-node/selection-node.d.ts +20 -0
  875. package/dist/esm/operation-node/selection-node.js +30 -0
  876. package/dist/esm/operation-node/set-operation-node.d.ts +15 -0
  877. package/dist/esm/operation-node/set-operation-node.js +18 -0
  878. package/dist/esm/operation-node/simple-reference-expression-node.d.ts +3 -0
  879. package/dist/esm/operation-node/simple-reference-expression-node.js +2 -0
  880. package/dist/esm/operation-node/table-node.d.ts +14 -0
  881. package/dist/esm/operation-node/table-node.js +23 -0
  882. package/dist/esm/operation-node/top-node.d.ts +14 -0
  883. package/dist/esm/operation-node/top-node.js +17 -0
  884. package/dist/esm/operation-node/tuple-node.d.ts +12 -0
  885. package/dist/esm/operation-node/tuple-node.js +16 -0
  886. package/dist/esm/operation-node/unary-operation-node.d.ts +13 -0
  887. package/dist/esm/operation-node/unary-operation-node.js +17 -0
  888. package/dist/esm/operation-node/unique-constraint-node.d.ts +20 -0
  889. package/dist/esm/operation-node/unique-constraint-node.js +26 -0
  890. package/dist/esm/operation-node/update-query-node.d.ts +39 -0
  891. package/dist/esm/operation-node/update-query-node.js +48 -0
  892. package/dist/esm/operation-node/using-node.d.ts +13 -0
  893. package/dist/esm/operation-node/using-node.js +22 -0
  894. package/dist/esm/operation-node/value-list-node.d.ts +12 -0
  895. package/dist/esm/operation-node/value-list-node.js +16 -0
  896. package/dist/esm/operation-node/value-node.d.ts +14 -0
  897. package/dist/esm/operation-node/value-node.js +23 -0
  898. package/dist/esm/operation-node/values-node.d.ts +15 -0
  899. package/dist/esm/operation-node/values-node.js +16 -0
  900. package/dist/esm/operation-node/when-node.d.ts +14 -0
  901. package/dist/esm/operation-node/when-node.js +22 -0
  902. package/dist/esm/operation-node/where-node.d.ts +13 -0
  903. package/dist/esm/operation-node/where-node.js +26 -0
  904. package/dist/esm/operation-node/with-node.d.ts +16 -0
  905. package/dist/esm/operation-node/with-node.js +23 -0
  906. package/dist/esm/package.json +1 -0
  907. package/dist/esm/parser/binary-operation-parser.d.ts +21 -0
  908. package/dist/esm/parser/binary-operation-parser.js +68 -0
  909. package/dist/esm/parser/coalesce-parser.d.ts +12 -0
  910. package/dist/esm/parser/coalesce-parser.js +2 -0
  911. package/dist/esm/parser/collate-parser.d.ts +1 -0
  912. package/dist/esm/parser/collate-parser.js +2 -0
  913. package/dist/esm/parser/data-type-parser.d.ts +5 -0
  914. package/dist/esm/parser/data-type-parser.js +12 -0
  915. package/dist/esm/parser/default-value-parser.d.ts +4 -0
  916. package/dist/esm/parser/default-value-parser.js +8 -0
  917. package/dist/esm/parser/delete-from-parser.d.ts +9 -0
  918. package/dist/esm/parser/delete-from-parser.js +2 -0
  919. package/dist/esm/parser/expression-parser.d.ts +20 -0
  920. package/dist/esm/parser/expression-parser.js +26 -0
  921. package/dist/esm/parser/fetch-parser.d.ts +2 -0
  922. package/dist/esm/parser/fetch-parser.js +15 -0
  923. package/dist/esm/parser/group-by-parser.d.ts +6 -0
  924. package/dist/esm/parser/group-by-parser.js +9 -0
  925. package/dist/esm/parser/identifier-parser.d.ts +2 -0
  926. package/dist/esm/parser/identifier-parser.js +20 -0
  927. package/dist/esm/parser/insert-values-parser.d.ts +14 -0
  928. package/dist/esm/parser/insert-values-parser.js +62 -0
  929. package/dist/esm/parser/join-parser.d.ts +10 -0
  930. package/dist/esm/parser/join-parser.js +28 -0
  931. package/dist/esm/parser/merge-into-parser.d.ts +7 -0
  932. package/dist/esm/parser/merge-into-parser.js +2 -0
  933. package/dist/esm/parser/merge-parser.d.ts +9 -0
  934. package/dist/esm/parser/merge-parser.js +28 -0
  935. package/dist/esm/parser/on-commit-action-parse.d.ts +2 -0
  936. package/dist/esm/parser/on-commit-action-parse.js +8 -0
  937. package/dist/esm/parser/on-modify-action-parser.d.ts +2 -0
  938. package/dist/esm/parser/on-modify-action-parser.js +8 -0
  939. package/dist/esm/parser/order-by-parser.d.ts +25 -0
  940. package/dist/esm/parser/order-by-parser.js +67 -0
  941. package/dist/esm/parser/parse-utils.d.ts +10 -0
  942. package/dist/esm/parser/parse-utils.js +33 -0
  943. package/dist/esm/parser/partition-by-parser.d.ts +6 -0
  944. package/dist/esm/parser/partition-by-parser.js +6 -0
  945. package/dist/esm/parser/reference-parser.d.ts +31 -0
  946. package/dist/esm/parser/reference-parser.js +95 -0
  947. package/dist/esm/parser/returning-parser.d.ts +8 -0
  948. package/dist/esm/parser/returning-parser.js +2 -0
  949. package/dist/esm/parser/savepoint-parser.d.ts +4 -0
  950. package/dist/esm/parser/savepoint-parser.js +9 -0
  951. package/dist/esm/parser/select-from-parser.d.ts +6 -0
  952. package/dist/esm/parser/select-from-parser.js +2 -0
  953. package/dist/esm/parser/select-parser.d.ts +36 -0
  954. package/dist/esm/parser/select-parser.js +47 -0
  955. package/dist/esm/parser/set-operation-parser.d.ts +5 -0
  956. package/dist/esm/parser/set-operation-parser.js +14 -0
  957. package/dist/esm/parser/table-parser.d.ts +24 -0
  958. package/dist/esm/parser/table-parser.js +49 -0
  959. package/dist/esm/parser/top-parser.d.ts +2 -0
  960. package/dist/esm/parser/top-parser.js +17 -0
  961. package/dist/esm/parser/tuple-parser.d.ts +47 -0
  962. package/dist/esm/parser/tuple-parser.js +2 -0
  963. package/dist/esm/parser/unary-operation-parser.d.ts +8 -0
  964. package/dist/esm/parser/unary-operation-parser.js +13 -0
  965. package/dist/esm/parser/update-parser.d.ts +9 -0
  966. package/dist/esm/parser/update-parser.js +2 -0
  967. package/dist/esm/parser/update-set-parser.d.ts +16 -0
  968. package/dist/esm/parser/update-set-parser.js +23 -0
  969. package/dist/esm/parser/value-parser.d.ts +13 -0
  970. package/dist/esm/parser/value-parser.js +33 -0
  971. package/dist/esm/parser/with-parser.d.ts +45 -0
  972. package/dist/esm/parser/with-parser.js +31 -0
  973. package/dist/esm/performance/query-analyzer.d.ts +89 -0
  974. package/dist/esm/performance/query-analyzer.js +260 -0
  975. package/dist/esm/plugin/camel-case/camel-case-plugin.d.ts +170 -0
  976. package/dist/esm/plugin/camel-case/camel-case-plugin.js +119 -0
  977. package/dist/esm/plugin/camel-case/camel-case-transformer.d.ts +9 -0
  978. package/dist/esm/plugin/camel-case/camel-case-transformer.js +16 -0
  979. package/dist/esm/plugin/camel-case/camel-case.d.ts +15 -0
  980. package/dist/esm/plugin/camel-case/camel-case.js +108 -0
  981. package/dist/esm/plugin/deduplicate-joins/deduplicate-joins-plugin.d.ts +70 -0
  982. package/dist/esm/plugin/deduplicate-joins/deduplicate-joins-plugin.js +16 -0
  983. package/dist/esm/plugin/deduplicate-joins/deduplicate-joins-transformer.d.ts +11 -0
  984. package/dist/esm/plugin/deduplicate-joins/deduplicate-joins-transformer.js +39 -0
  985. package/dist/esm/plugin/handle-empty-in-lists/handle-empty-in-lists-plugin.d.ts +211 -0
  986. package/dist/esm/plugin/handle-empty-in-lists/handle-empty-in-lists-plugin.js +159 -0
  987. package/dist/esm/plugin/handle-empty-in-lists/handle-empty-in-lists-transformer.d.ts +8 -0
  988. package/dist/esm/plugin/handle-empty-in-lists/handle-empty-in-lists-transformer.js +26 -0
  989. package/dist/esm/plugin/handle-empty-in-lists/handle-empty-in-lists.d.ts +44 -0
  990. package/dist/esm/plugin/handle-empty-in-lists/handle-empty-in-lists.js +63 -0
  991. package/dist/esm/plugin/immediate-value/immediate-value-plugin.d.ts +73 -0
  992. package/dist/esm/plugin/immediate-value/immediate-value-plugin.js +19 -0
  993. package/dist/esm/plugin/immediate-value/immediate-value-transformer.d.ts +15 -0
  994. package/dist/esm/plugin/immediate-value/immediate-value-transformer.js +20 -0
  995. package/dist/esm/plugin/kysely-plugin.d.ts +72 -0
  996. package/dist/esm/plugin/kysely-plugin.js +2 -0
  997. package/dist/esm/plugin/noop-plugin.d.ts +64 -0
  998. package/dist/esm/plugin/noop-plugin.js +9 -0
  999. package/dist/esm/plugin/parse-json-results/parse-json-results-plugin.d.ts +126 -0
  1000. package/dist/esm/plugin/parse-json-results/parse-json-results-plugin.js +104 -0
  1001. package/dist/esm/plugin/with-schema/with-schema-plugin.d.ts +66 -0
  1002. package/dist/esm/plugin/with-schema/with-schema-plugin.js +14 -0
  1003. package/dist/esm/plugin/with-schema/with-schema-transformer.d.ts +16 -0
  1004. package/dist/esm/plugin/with-schema/with-schema-transformer.js +178 -0
  1005. package/dist/esm/query-builder/aggregate-function-builder.d.ts +379 -0
  1006. package/dist/esm/query-builder/aggregate-function-builder.js +238 -0
  1007. package/dist/esm/query-builder/case-builder.d.ts +112 -0
  1008. package/dist/esm/query-builder/case-builder.js +73 -0
  1009. package/dist/esm/query-builder/cte-builder.d.ts +20 -0
  1010. package/dist/esm/query-builder/cte-builder.js +34 -0
  1011. package/dist/esm/query-builder/delete-query-builder.d.ts +1348 -0
  1012. package/dist/esm/query-builder/delete-query-builder.js +501 -0
  1013. package/dist/esm/query-builder/delete-result.d.ts +4 -0
  1014. package/dist/esm/query-builder/delete-result.js +7 -0
  1015. package/dist/esm/query-builder/function-module.d.ts +592 -0
  1016. package/dist/esm/query-builder/function-module.js +60 -0
  1017. package/dist/esm/query-builder/having-interface.d.ts +15 -0
  1018. package/dist/esm/query-builder/having-interface.js +2 -0
  1019. package/dist/esm/query-builder/insert-query-builder.d.ts +1235 -0
  1020. package/dist/esm/query-builder/insert-query-builder.js +1157 -0
  1021. package/dist/esm/query-builder/insert-result.d.ts +46 -0
  1022. package/dist/esm/query-builder/insert-result.js +50 -0
  1023. package/dist/esm/query-builder/join-builder.d.ts +38 -0
  1024. package/dist/esm/query-builder/join-builder.js +48 -0
  1025. package/dist/esm/query-builder/json-path-builder.d.ts +294 -0
  1026. package/dist/esm/query-builder/json-path-builder.js +195 -0
  1027. package/dist/esm/query-builder/merge-query-builder.d.ts +1001 -0
  1028. package/dist/esm/query-builder/merge-query-builder.js +624 -0
  1029. package/dist/esm/query-builder/merge-result.d.ts +4 -0
  1030. package/dist/esm/query-builder/merge-result.js +7 -0
  1031. package/dist/esm/query-builder/no-result-error.d.ts +10 -0
  1032. package/dist/esm/query-builder/no-result-error.js +14 -0
  1033. package/dist/esm/query-builder/on-conflict-builder.d.ts +872 -0
  1034. package/dist/esm/query-builder/on-conflict-builder.js +254 -0
  1035. package/dist/esm/query-builder/order-by-interface.d.ts +158 -0
  1036. package/dist/esm/query-builder/order-by-interface.js +2 -0
  1037. package/dist/esm/query-builder/order-by-item-builder.d.ts +43 -0
  1038. package/dist/esm/query-builder/order-by-item-builder.js +72 -0
  1039. package/dist/esm/query-builder/output-interface.d.ts +138 -0
  1040. package/dist/esm/query-builder/output-interface.js +2 -0
  1041. package/dist/esm/query-builder/over-builder.d.ts +101 -0
  1042. package/dist/esm/query-builder/over-builder.js +37 -0
  1043. package/dist/esm/query-builder/returning-interface.d.ts +91 -0
  1044. package/dist/esm/query-builder/returning-interface.js +2 -0
  1045. package/dist/esm/query-builder/select-query-builder-expression.d.ts +28 -0
  1046. package/dist/esm/query-builder/select-query-builder-expression.js +2 -0
  1047. package/dist/esm/query-builder/select-query-builder.d.ts +2391 -0
  1048. package/dist/esm/query-builder/select-query-builder.js +374 -0
  1049. package/dist/esm/query-builder/update-query-builder.d.ts +1392 -0
  1050. package/dist/esm/query-builder/update-query-builder.js +510 -0
  1051. package/dist/esm/query-builder/update-result.d.ts +14 -0
  1052. package/dist/esm/query-builder/update-result.js +18 -0
  1053. package/dist/esm/query-builder/where-interface.d.ts +382 -0
  1054. package/dist/esm/query-builder/where-interface.js +2 -0
  1055. package/dist/esm/query-compiler/compiled-query.d.ts +11 -0
  1056. package/dist/esm/query-compiler/compiled-query.js +14 -0
  1057. package/dist/esm/query-compiler/default-query-compiler.d.ts +235 -0
  1058. package/dist/esm/query-compiler/default-query-compiler.js +1387 -0
  1059. package/dist/esm/query-compiler/query-compiler.d.ts +24 -0
  1060. package/dist/esm/query-compiler/query-compiler.js +2 -0
  1061. package/dist/esm/query-creator.d.ts +592 -0
  1062. package/dist/esm/query-creator.js +619 -0
  1063. package/dist/esm/query-executor/default-query-executor.d.ts +50 -0
  1064. package/dist/esm/query-executor/default-query-executor.js +37 -0
  1065. package/dist/esm/query-executor/noop-query-executor.d.ts +50 -0
  1066. package/dist/esm/query-executor/noop-query-executor.js +34 -0
  1067. package/dist/esm/query-executor/query-executor-base.d.ts +68 -0
  1068. package/dist/esm/query-executor/query-executor-base.js +59 -0
  1069. package/dist/esm/query-executor/query-executor-provider.d.ts +8 -0
  1070. package/dist/esm/query-executor/query-executor-provider.js +2 -0
  1071. package/dist/esm/query-executor/query-executor.d.ts +74 -0
  1072. package/dist/esm/query-executor/query-executor.js +2 -0
  1073. package/dist/esm/raw-builder/raw-builder.d.ts +218 -0
  1074. package/dist/esm/raw-builder/raw-builder.js +84 -0
  1075. package/dist/esm/raw-builder/sql.d.ts +366 -0
  1076. package/dist/esm/raw-builder/sql.js +82 -0
  1077. package/dist/esm/relationships/relationship-engine.d.ts +59 -0
  1078. package/dist/esm/relationships/relationship-engine.js +203 -0
  1079. package/dist/esm/repository/repository-factory.d.ts +54 -0
  1080. package/dist/esm/repository/repository-factory.js +446 -0
  1081. package/dist/esm/schema/builders/alter-column-builder.d.ts +53 -0
  1082. package/dist/esm/schema/builders/alter-column-builder.js +70 -0
  1083. package/dist/esm/schema/builders/alter-table-add-foreign-key-constraint-builder.d.ts +32 -0
  1084. package/dist/esm/schema/builders/alter-table-add-foreign-key-constraint-builder.js +64 -0
  1085. package/dist/esm/schema/builders/alter-table-add-index-builder.d.ts +138 -0
  1086. package/dist/esm/schema/builders/alter-table-add-index-builder.js +162 -0
  1087. package/dist/esm/schema/builders/alter-table-builder.d.ts +148 -0
  1088. package/dist/esm/schema/builders/alter-table-builder.js +263 -0
  1089. package/dist/esm/schema/builders/alter-table-drop-constraint-builder.d.ts +26 -0
  1090. package/dist/esm/schema/builders/alter-table-drop-constraint-builder.js +56 -0
  1091. package/dist/esm/schema/builders/alter-table-executor.d.ts +18 -0
  1092. package/dist/esm/schema/builders/alter-table-executor.js +17 -0
  1093. package/dist/esm/schema/builders/check-constraint-builder.d.ts +13 -0
  1094. package/dist/esm/schema/builders/check-constraint-builder.js +17 -0
  1095. package/dist/esm/schema/builders/column-definition-builder.d.ts +514 -0
  1096. package/dist/esm/schema/builders/column-definition-builder.js +597 -0
  1097. package/dist/esm/schema/builders/create-index-builder.d.ts +173 -0
  1098. package/dist/esm/schema/builders/create-index-builder.js +199 -0
  1099. package/dist/esm/schema/builders/create-schema-builder.d.ts +24 -0
  1100. package/dist/esm/schema/builders/create-schema-builder.js +31 -0
  1101. package/dist/esm/schema/builders/create-table-builder.d.ts +331 -0
  1102. package/dist/esm/schema/builders/create-table-builder.js +408 -0
  1103. package/dist/esm/schema/builders/create-type-builder.d.ts +33 -0
  1104. package/dist/esm/schema/builders/create-type-builder.js +40 -0
  1105. package/dist/esm/schema/builders/create-view-builder.d.ts +48 -0
  1106. package/dist/esm/schema/builders/create-view-builder.js +95 -0
  1107. package/dist/esm/schema/builders/drop-index-builder.d.ts +30 -0
  1108. package/dist/esm/schema/builders/drop-index-builder.js +54 -0
  1109. package/dist/esm/schema/builders/drop-schema-builder.d.ts +25 -0
  1110. package/dist/esm/schema/builders/drop-schema-builder.js +41 -0
  1111. package/dist/esm/schema/builders/drop-table-builder.d.ts +25 -0
  1112. package/dist/esm/schema/builders/drop-table-builder.js +41 -0
  1113. package/dist/esm/schema/builders/drop-type-builder.d.ts +24 -0
  1114. package/dist/esm/schema/builders/drop-type-builder.js +33 -0
  1115. package/dist/esm/schema/builders/drop-view-builder.d.ts +26 -0
  1116. package/dist/esm/schema/builders/drop-view-builder.js +49 -0
  1117. package/dist/esm/schema/builders/foreign-key-constraint-builder.d.ts +28 -0
  1118. package/dist/esm/schema/builders/foreign-key-constraint-builder.js +45 -0
  1119. package/dist/esm/schema/builders/index.d.ts +22 -0
  1120. package/dist/esm/schema/builders/index.js +24 -0
  1121. package/dist/esm/schema/builders/primary-key-constraint-builder.d.ts +17 -0
  1122. package/dist/esm/schema/builders/primary-key-constraint-builder.js +34 -0
  1123. package/dist/esm/schema/builders/refresh-materialized-view-builder.d.ts +47 -0
  1124. package/dist/esm/schema/builders/refresh-materialized-view-builder.js +72 -0
  1125. package/dist/esm/schema/builders/unique-constraint-builder.d.ts +23 -0
  1126. package/dist/esm/schema/builders/unique-constraint-builder.js +42 -0
  1127. package/dist/esm/schema/core/coordinators/schema-discovery.coordinator.d.ts +35 -0
  1128. package/dist/esm/schema/core/coordinators/schema-discovery.coordinator.js +60 -0
  1129. package/dist/esm/schema/core/discovery/relationship-discovery.d.ts +36 -0
  1130. package/dist/esm/schema/core/discovery/relationship-discovery.js +159 -0
  1131. package/dist/esm/schema/core/discovery/table-metadata-discovery.d.ts +29 -0
  1132. package/dist/esm/schema/core/discovery/table-metadata-discovery.js +123 -0
  1133. package/dist/esm/schema/core/discovery/view-discovery.d.ts +36 -0
  1134. package/dist/esm/schema/core/discovery/view-discovery.js +134 -0
  1135. package/dist/esm/schema/core/factories/discovery-factory.d.ts +66 -0
  1136. package/dist/esm/schema/core/factories/discovery-factory.js +119 -0
  1137. package/dist/esm/schema/core/types/schema-discovery-types.d.ts +43 -0
  1138. package/dist/esm/schema/core/types/schema-discovery-types.js +3 -0
  1139. package/dist/esm/schema/core/utils/name-generator.d.ts +21 -0
  1140. package/dist/esm/schema/core/utils/name-generator.js +52 -0
  1141. package/dist/esm/schema/core/utils/type-mapper.d.ts +25 -0
  1142. package/dist/esm/schema/core/utils/type-mapper.js +58 -0
  1143. package/dist/esm/schema/dialects/sqlite/discovery/sqlite-constraint-discovery.d.ts +97 -0
  1144. package/dist/esm/schema/dialects/sqlite/discovery/sqlite-constraint-discovery.js +530 -0
  1145. package/dist/esm/schema/dialects/sqlite/discovery/sqlite-index-discovery.d.ts +32 -0
  1146. package/dist/esm/schema/dialects/sqlite/discovery/sqlite-index-discovery.js +130 -0
  1147. package/dist/esm/schema/dialects/sqlite/introspection/sqlite-schema-introspector.d.ts +31 -0
  1148. package/dist/esm/schema/dialects/sqlite/introspection/sqlite-schema-introspector.js +189 -0
  1149. package/dist/esm/schema/dialects/sqlite/sqlite-discovery.coordinator.d.ts +51 -0
  1150. package/dist/esm/schema/dialects/sqlite/sqlite-discovery.coordinator.js +177 -0
  1151. package/dist/esm/schema/index.d.ts +14 -0
  1152. package/dist/esm/schema/index.js +21 -0
  1153. package/dist/esm/schema/schema-discovery.d.ts +23 -0
  1154. package/dist/esm/schema/schema-discovery.js +30 -0
  1155. package/dist/esm/schema/schema.d.ts +230 -0
  1156. package/dist/esm/schema/schema.js +325 -0
  1157. package/dist/esm/schema/test/basic-schema-test.d.ts +8 -0
  1158. package/dist/esm/schema/test/basic-schema-test.js +183 -0
  1159. package/dist/esm/schema/test/dialect-capabilities.test.d.ts +1 -0
  1160. package/dist/esm/schema/test/dialect-capabilities.test.js +152 -0
  1161. package/dist/esm/schema/test/discovery-factory.test.d.ts +1 -0
  1162. package/dist/esm/schema/test/discovery-factory.test.js +150 -0
  1163. package/dist/esm/schema/test/error-handling.test.d.ts +1 -0
  1164. package/dist/esm/schema/test/error-handling.test.js +148 -0
  1165. package/dist/esm/schema/test/integration.test.d.ts +1 -0
  1166. package/dist/esm/schema/test/integration.test.js +134 -0
  1167. package/dist/esm/schema/test/schema-discovery-coordinator.test.d.ts +1 -0
  1168. package/dist/esm/schema/test/schema-discovery-coordinator.test.js +138 -0
  1169. package/dist/esm/schema/test/simple-schema-test.d.ts +5 -0
  1170. package/dist/esm/schema/test/simple-schema-test.js +78 -0
  1171. package/dist/esm/schema/test/sqlite-discovery-coordinator.test.d.ts +1 -0
  1172. package/dist/esm/schema/test/sqlite-discovery-coordinator.test.js +376 -0
  1173. package/dist/esm/schema/test/test-runner.d.ts +66 -0
  1174. package/dist/esm/schema/test/test-runner.js +89 -0
  1175. package/dist/esm/sqlite-migration/index.d.ts +6 -0
  1176. package/dist/esm/sqlite-migration/index.js +14 -0
  1177. package/dist/esm/sqlite-migration/sqlite-migration-manager.d.ts +104 -0
  1178. package/dist/esm/sqlite-migration/sqlite-migration-manager.js +332 -0
  1179. package/dist/esm/sqlite-migration/sqlite-migration-provider.d.ts +77 -0
  1180. package/dist/esm/sqlite-migration/sqlite-migration-provider.js +339 -0
  1181. package/dist/esm/testing/test-utils.d.ts +110 -0
  1182. package/dist/esm/testing/test-utils.js +320 -0
  1183. package/dist/esm/types/index.d.ts +155 -0
  1184. package/dist/esm/types/index.js +5 -0
  1185. package/dist/esm/types/type-generator.d.ts +52 -0
  1186. package/dist/esm/types/type-generator.js +258 -0
  1187. package/dist/esm/util/assert.d.ts +2 -0
  1188. package/dist/esm/util/assert.js +11 -0
  1189. package/dist/esm/util/column-type.d.ts +175 -0
  1190. package/dist/esm/util/column-type.js +2 -0
  1191. package/dist/esm/util/compilable.d.ts +5 -0
  1192. package/dist/esm/util/compilable.js +5 -0
  1193. package/dist/esm/util/deferred.d.ts +7 -0
  1194. package/dist/esm/util/deferred.js +25 -0
  1195. package/dist/esm/util/explainable.d.ts +40 -0
  1196. package/dist/esm/util/explainable.js +2 -0
  1197. package/dist/esm/util/infer-result.d.ts +48 -0
  1198. package/dist/esm/util/infer-result.js +2 -0
  1199. package/dist/esm/util/json-object-args.d.ts +3 -0
  1200. package/dist/esm/util/json-object-args.js +32 -0
  1201. package/dist/esm/util/log-once.d.ts +5 -0
  1202. package/dist/esm/util/log-once.js +13 -0
  1203. package/dist/esm/util/log.d.ts +26 -0
  1204. package/dist/esm/util/log.js +55 -0
  1205. package/dist/esm/util/object-utils.d.ts +23 -0
  1206. package/dist/esm/util/object-utils.js +141 -0
  1207. package/dist/esm/util/performance-now.d.ts +1 -0
  1208. package/dist/esm/util/performance-now.js +10 -0
  1209. package/dist/esm/util/provide-controlled-connection.d.ts +7 -0
  1210. package/dist/esm/util/provide-controlled-connection.js +22 -0
  1211. package/dist/esm/util/query-id.d.ts +4 -0
  1212. package/dist/esm/util/query-id.js +14 -0
  1213. package/dist/esm/util/random-string.d.ts +1 -0
  1214. package/dist/esm/util/random-string.js +75 -0
  1215. package/dist/esm/util/require-all-props.d.ts +45 -0
  1216. package/dist/esm/util/require-all-props.js +39 -0
  1217. package/dist/esm/util/stack-trace-utils.d.ts +1 -0
  1218. package/dist/esm/util/stack-trace-utils.js +14 -0
  1219. package/dist/esm/util/streamable.d.ts +29 -0
  1220. package/dist/esm/util/streamable.js +2 -0
  1221. package/dist/esm/util/type-error.d.ts +3 -0
  1222. package/dist/esm/util/type-error.js +2 -0
  1223. package/dist/esm/util/type-utils.d.ts +189 -0
  1224. package/dist/esm/util/type-utils.js +2 -0
  1225. package/dist/esm/utils/errorHelpers.d.ts +26 -0
  1226. package/dist/esm/utils/errorHelpers.js +180 -0
  1227. package/dist/esm/watch/schema-watcher.d.ts +68 -0
  1228. package/dist/esm/watch/schema-watcher.js +183 -0
  1229. package/outdated-typescript.d.ts +5 -0
  1230. package/package.json +152 -0
@@ -0,0 +1,1160 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InsertQueryBuilder = void 0;
4
+ const select_parser_js_1 = require("../parser/select-parser.js");
5
+ const insert_values_parser_js_1 = require("../parser/insert-values-parser.js");
6
+ const insert_query_node_js_1 = require("../operation-node/insert-query-node.js");
7
+ const query_node_js_1 = require("../operation-node/query-node.js");
8
+ const update_set_parser_js_1 = require("../parser/update-set-parser.js");
9
+ const object_utils_js_1 = require("../util/object-utils.js");
10
+ const on_duplicate_key_node_js_1 = require("../operation-node/on-duplicate-key-node.js");
11
+ const insert_result_js_1 = require("./insert-result.js");
12
+ const no_result_error_js_1 = require("./no-result-error.js");
13
+ const expression_parser_js_1 = require("../parser/expression-parser.js");
14
+ const column_node_js_1 = require("../operation-node/column-node.js");
15
+ const on_conflict_builder_js_1 = require("./on-conflict-builder.js");
16
+ const on_conflict_node_js_1 = require("../operation-node/on-conflict-node.js");
17
+ const top_parser_js_1 = require("../parser/top-parser.js");
18
+ const or_action_node_js_1 = require("../operation-node/or-action-node.js");
19
+ class InsertQueryBuilder {
20
+ #props;
21
+ constructor(props) {
22
+ this.#props = (0, object_utils_js_1.freeze)(props);
23
+ }
24
+ /**
25
+ * Sets the values to insert for an {@link Kysely.insertInto | insert} query.
26
+ *
27
+ * This method takes an object whose keys are column names and values are
28
+ * values to insert. In addition to the column's type, the values can be
29
+ * raw {@link sql} snippets or select queries.
30
+ *
31
+ * You must provide all fields you haven't explicitly marked as nullable
32
+ * or optional using {@link Generated} or {@link ColumnType}.
33
+ *
34
+ * The return value of an `insert` query is an instance of {@link InsertResult}. The
35
+ * {@link InsertResult.insertId | insertId} field holds the auto incremented primary
36
+ * key if the database returned one.
37
+ *
38
+ * On PostgreSQL and some other dialects, you need to call `returning` to get
39
+ * something out of the query.
40
+ *
41
+ * Also see the {@link expression} method for inserting the result of a select
42
+ * query or any other expression.
43
+ *
44
+ * ### Examples
45
+ *
46
+ * <!-- siteExample("insert", "Single row", 10) -->
47
+ *
48
+ * Insert a single row:
49
+ *
50
+ * ```ts
51
+ * const result = await db
52
+ * .insertInto('person')
53
+ * .values({
54
+ * first_name: 'Jennifer',
55
+ * last_name: 'Aniston',
56
+ * age: 40
57
+ * })
58
+ * .executeTakeFirst()
59
+ *
60
+ * // `insertId` is only available on dialects that
61
+ * // automatically return the id of the inserted row
62
+ * // such as MySQL and SQLite. On PostgreSQL, for example,
63
+ * // you need to add a `returning` clause to the query to
64
+ * // get anything out. See the "returning data" example.
65
+ * console.log(result.insertId)
66
+ * ```
67
+ *
68
+ * The generated SQL (MySQL):
69
+ *
70
+ * ```sql
71
+ * insert into `person` (`first_name`, `last_name`, `age`) values (?, ?, ?)
72
+ * ```
73
+ *
74
+ * <!-- siteExample("insert", "Multiple rows", 20) -->
75
+ *
76
+ * On dialects that support it (for example PostgreSQL) you can insert multiple
77
+ * rows by providing an array. Note that the return value is once again very
78
+ * dialect-specific. Some databases may only return the id of the *last* inserted
79
+ * row and some return nothing at all unless you call `returning`.
80
+ *
81
+ * ```ts
82
+ * await db
83
+ * .insertInto('person')
84
+ * .values([{
85
+ * first_name: 'Jennifer',
86
+ * last_name: 'Aniston',
87
+ * age: 40,
88
+ * }, {
89
+ * first_name: 'Arnold',
90
+ * last_name: 'Schwarzenegger',
91
+ * age: 70,
92
+ * }])
93
+ * .execute()
94
+ * ```
95
+ *
96
+ * The generated SQL (PostgreSQL):
97
+ *
98
+ * ```sql
99
+ * insert into "person" ("first_name", "last_name", "age") values (($1, $2, $3), ($4, $5, $6))
100
+ * ```
101
+ *
102
+ * <!-- siteExample("insert", "Returning data", 30) -->
103
+ *
104
+ * On supported dialects like PostgreSQL you need to chain `returning` to the query to get
105
+ * the inserted row's columns (or any other expression) as the return value. `returning`
106
+ * works just like `select`. Refer to `select` method's examples and documentation for
107
+ * more info.
108
+ *
109
+ * ```ts
110
+ * const result = await db
111
+ * .insertInto('person')
112
+ * .values({
113
+ * first_name: 'Jennifer',
114
+ * last_name: 'Aniston',
115
+ * age: 40,
116
+ * })
117
+ * .returning(['id', 'first_name as name'])
118
+ * .executeTakeFirstOrThrow()
119
+ * ```
120
+ *
121
+ * The generated SQL (PostgreSQL):
122
+ *
123
+ * ```sql
124
+ * insert into "person" ("first_name", "last_name", "age") values ($1, $2, $3) returning "id", "first_name" as "name"
125
+ * ```
126
+ *
127
+ * <!-- siteExample("insert", "Complex values", 40) -->
128
+ *
129
+ * In addition to primitives, the values can also be arbitrary expressions.
130
+ * You can build the expressions by using a callback and calling the methods
131
+ * on the expression builder passed to it:
132
+ *
133
+ * ```ts
134
+ * import { sql } from 'kysely'
135
+ *
136
+ * const ani = "Ani"
137
+ * const ston = "ston"
138
+ *
139
+ * const result = await db
140
+ * .insertInto('person')
141
+ * .values(({ ref, selectFrom, fn }) => ({
142
+ * first_name: 'Jennifer',
143
+ * last_name: sql<string>`concat(${ani}, ${ston})`,
144
+ * middle_name: ref('first_name'),
145
+ * age: selectFrom('person')
146
+ * .select(fn.avg<number>('age').as('avg_age')),
147
+ * }))
148
+ * .executeTakeFirst()
149
+ * ```
150
+ *
151
+ * The generated SQL (PostgreSQL):
152
+ *
153
+ * ```sql
154
+ * insert into "person" (
155
+ * "first_name",
156
+ * "last_name",
157
+ * "middle_name",
158
+ * "age"
159
+ * )
160
+ * values (
161
+ * $1,
162
+ * concat($2, $3),
163
+ * "first_name",
164
+ * (select avg("age") as "avg_age" from "person")
165
+ * )
166
+ * ```
167
+ *
168
+ * You can also use the callback version of subqueries or raw expressions:
169
+ *
170
+ * ```ts
171
+ * await db.with('jennifer', (db) => db
172
+ * .selectFrom('person')
173
+ * .where('first_name', '=', 'Jennifer')
174
+ * .select(['id', 'first_name', 'gender'])
175
+ * .limit(1)
176
+ * ).insertInto('pet').values((eb) => ({
177
+ * owner_id: eb.selectFrom('jennifer').select('id'),
178
+ * name: eb.selectFrom('jennifer').select('first_name'),
179
+ * species: 'cat',
180
+ * }))
181
+ * .execute()
182
+ * ```
183
+ *
184
+ * The generated SQL (PostgreSQL):
185
+ *
186
+ * ```sql
187
+ * with "jennifer" as (
188
+ * select "id", "first_name", "gender"
189
+ * from "person"
190
+ * where "first_name" = $1
191
+ * limit $2
192
+ * )
193
+ * insert into "pet" ("owner_id", "name", "species")
194
+ * values (
195
+ * (select "id" from "jennifer"),
196
+ * (select "first_name" from "jennifer"),
197
+ * $3
198
+ * )
199
+ * ```
200
+ */
201
+ values(insert) {
202
+ const [columns, values] = (0, insert_values_parser_js_1.parseInsertExpression)(insert);
203
+ return new InsertQueryBuilder({
204
+ ...this.#props,
205
+ queryNode: insert_query_node_js_1.InsertQueryNode.cloneWith(this.#props.queryNode, {
206
+ columns,
207
+ values,
208
+ }),
209
+ });
210
+ }
211
+ /**
212
+ * Sets the columns to insert.
213
+ *
214
+ * The {@link values} method sets both the columns and the values and this method
215
+ * is not needed. But if you are using the {@link expression} method, you can use
216
+ * this method to set the columns to insert.
217
+ *
218
+ * ### Examples
219
+ *
220
+ * ```ts
221
+ * await db.insertInto('person')
222
+ * .columns(['first_name'])
223
+ * .expression((eb) => eb.selectFrom('pet').select('pet.name'))
224
+ * .execute()
225
+ * ```
226
+ *
227
+ * The generated SQL (PostgreSQL):
228
+ *
229
+ * ```sql
230
+ * insert into "person" ("first_name")
231
+ * select "pet"."name" from "pet"
232
+ * ```
233
+ */
234
+ columns(columns) {
235
+ return new InsertQueryBuilder({
236
+ ...this.#props,
237
+ queryNode: insert_query_node_js_1.InsertQueryNode.cloneWith(this.#props.queryNode, {
238
+ columns: (0, object_utils_js_1.freeze)(columns.map(column_node_js_1.ColumnNode.create)),
239
+ }),
240
+ });
241
+ }
242
+ /**
243
+ * Insert an arbitrary expression. For example the result of a select query.
244
+ *
245
+ * ### Examples
246
+ *
247
+ * <!-- siteExample("insert", "Insert subquery", 50) -->
248
+ *
249
+ * You can create an `INSERT INTO SELECT FROM` query using the `expression` method.
250
+ * This API doesn't follow our WYSIWYG principles and might be a bit difficult to
251
+ * remember. The reasons for this design stem from implementation difficulties.
252
+ *
253
+ * ```ts
254
+ * const result = await db.insertInto('person')
255
+ * .columns(['first_name', 'last_name', 'age'])
256
+ * .expression((eb) => eb
257
+ * .selectFrom('pet')
258
+ * .select((eb) => [
259
+ * 'pet.name',
260
+ * eb.val('Petson').as('last_name'),
261
+ * eb.lit(7).as('age'),
262
+ * ])
263
+ * )
264
+ * .execute()
265
+ * ```
266
+ *
267
+ * The generated SQL (PostgreSQL):
268
+ *
269
+ * ```sql
270
+ * insert into "person" ("first_name", "last_name", "age")
271
+ * select "pet"."name", $1 as "last_name", 7 as "age from "pet"
272
+ * ```
273
+ */
274
+ expression(expression) {
275
+ return new InsertQueryBuilder({
276
+ ...this.#props,
277
+ queryNode: insert_query_node_js_1.InsertQueryNode.cloneWith(this.#props.queryNode, {
278
+ values: (0, expression_parser_js_1.parseExpression)(expression),
279
+ }),
280
+ });
281
+ }
282
+ /**
283
+ * Creates an `insert into "person" default values` query.
284
+ *
285
+ * ### Examples
286
+ *
287
+ * ```ts
288
+ * await db.insertInto('person')
289
+ * .defaultValues()
290
+ * .execute()
291
+ * ```
292
+ *
293
+ * The generated SQL (PostgreSQL):
294
+ *
295
+ * ```sql
296
+ * insert into "person" default values
297
+ * ```
298
+ */
299
+ defaultValues() {
300
+ return new InsertQueryBuilder({
301
+ ...this.#props,
302
+ queryNode: insert_query_node_js_1.InsertQueryNode.cloneWith(this.#props.queryNode, {
303
+ defaultValues: true,
304
+ }),
305
+ });
306
+ }
307
+ /**
308
+ * This can be used to add any additional SQL to the end of the query.
309
+ *
310
+ * ### Examples
311
+ *
312
+ * ```ts
313
+ * import { sql } from 'kysely'
314
+ *
315
+ * await db.insertInto('person')
316
+ * .values({
317
+ * first_name: 'John',
318
+ * last_name: 'Doe',
319
+ * gender: 'male',
320
+ * })
321
+ * .modifyEnd(sql`-- This is a comment`)
322
+ * .execute()
323
+ * ```
324
+ *
325
+ * The generated SQL (MySQL):
326
+ *
327
+ * ```sql
328
+ * insert into `person` ("first_name", "last_name", "gender")
329
+ * values (?, ?, ?) -- This is a comment
330
+ * ```
331
+ */
332
+ modifyEnd(modifier) {
333
+ return new InsertQueryBuilder({
334
+ ...this.#props,
335
+ queryNode: query_node_js_1.QueryNode.cloneWithEndModifier(this.#props.queryNode, modifier.toOperationNode()),
336
+ });
337
+ }
338
+ /**
339
+ * Changes an `insert into` query to an `insert ignore into` query.
340
+ *
341
+ * This is only supported by some dialects like MySQL.
342
+ *
343
+ * To avoid a footgun, when invoked with the SQLite dialect, this method will
344
+ * be handled like {@link orIgnore}. See also, {@link orAbort}, {@link orFail},
345
+ * {@link orReplace}, and {@link orRollback}.
346
+ *
347
+ * If you use the ignore modifier, ignorable errors that occur while executing the
348
+ * insert statement are ignored. For example, without ignore, a row that duplicates
349
+ * an existing unique index or primary key value in the table causes a duplicate-key
350
+ * error and the statement is aborted. With ignore, the row is discarded and no error
351
+ * occurs.
352
+ *
353
+ * ### Examples
354
+ *
355
+ * ```ts
356
+ * await db.insertInto('person')
357
+ * .ignore()
358
+ * .values({
359
+ * first_name: 'John',
360
+ * last_name: 'Doe',
361
+ * gender: 'female',
362
+ * })
363
+ * .execute()
364
+ * ```
365
+ *
366
+ * The generated SQL (MySQL):
367
+ *
368
+ * ```sql
369
+ * insert ignore into `person` (`first_name`, `last_name`, `gender`) values (?, ?, ?)
370
+ * ```
371
+ *
372
+ * The generated SQL (SQLite):
373
+ *
374
+ * ```sql
375
+ * insert or ignore into "person" ("first_name", "last_name", "gender") values (?, ?, ?)
376
+ * ```
377
+ */
378
+ ignore() {
379
+ return new InsertQueryBuilder({
380
+ ...this.#props,
381
+ queryNode: insert_query_node_js_1.InsertQueryNode.cloneWith(this.#props.queryNode, {
382
+ orAction: or_action_node_js_1.OrActionNode.create('ignore'),
383
+ }),
384
+ });
385
+ }
386
+ /**
387
+ * Changes an `insert into` query to an `insert or ignore into` query.
388
+ *
389
+ * This is only supported by some dialects like SQLite.
390
+ *
391
+ * To avoid a footgun, when invoked with the MySQL dialect, this method will
392
+ * be handled like {@link ignore}.
393
+ *
394
+ * See also, {@link orAbort}, {@link orFail}, {@link orReplace}, and {@link orRollback}.
395
+ *
396
+ * ### Examples
397
+ *
398
+ * ```ts
399
+ * await db.insertInto('person')
400
+ * .orIgnore()
401
+ * .values({
402
+ * first_name: 'John',
403
+ * last_name: 'Doe',
404
+ * gender: 'female',
405
+ * })
406
+ * .execute()
407
+ * ```
408
+ *
409
+ * The generated SQL (SQLite):
410
+ *
411
+ * ```sql
412
+ * insert or ignore into "person" ("first_name", "last_name", "gender") values (?, ?, ?)
413
+ * ```
414
+ *
415
+ * The generated SQL (MySQL):
416
+ *
417
+ * ```sql
418
+ * insert ignore into `person` (`first_name`, `last_name`, `gender`) values (?, ?, ?)
419
+ * ```
420
+ */
421
+ orIgnore() {
422
+ return new InsertQueryBuilder({
423
+ ...this.#props,
424
+ queryNode: insert_query_node_js_1.InsertQueryNode.cloneWith(this.#props.queryNode, {
425
+ orAction: or_action_node_js_1.OrActionNode.create('ignore'),
426
+ }),
427
+ });
428
+ }
429
+ /**
430
+ * Changes an `insert into` query to an `insert or abort into` query.
431
+ *
432
+ * This is only supported by some dialects like SQLite.
433
+ *
434
+ * See also, {@link orIgnore}, {@link orFail}, {@link orReplace}, and {@link orRollback}.
435
+ *
436
+ * ### Examples
437
+ *
438
+ * ```ts
439
+ * await db.insertInto('person')
440
+ * .orAbort()
441
+ * .values({
442
+ * first_name: 'John',
443
+ * last_name: 'Doe',
444
+ * gender: 'female',
445
+ * })
446
+ * .execute()
447
+ * ```
448
+ *
449
+ * The generated SQL (SQLite):
450
+ *
451
+ * ```sql
452
+ * insert or abort into "person" ("first_name", "last_name", "gender") values (?, ?, ?)
453
+ * ```
454
+ */
455
+ orAbort() {
456
+ return new InsertQueryBuilder({
457
+ ...this.#props,
458
+ queryNode: insert_query_node_js_1.InsertQueryNode.cloneWith(this.#props.queryNode, {
459
+ orAction: or_action_node_js_1.OrActionNode.create('abort'),
460
+ }),
461
+ });
462
+ }
463
+ /**
464
+ * Changes an `insert into` query to an `insert or fail into` query.
465
+ *
466
+ * This is only supported by some dialects like SQLite.
467
+ *
468
+ * See also, {@link orIgnore}, {@link orAbort}, {@link orReplace}, and {@link orRollback}.
469
+ *
470
+ * ### Examples
471
+ *
472
+ * ```ts
473
+ * await db.insertInto('person')
474
+ * .orFail()
475
+ * .values({
476
+ * first_name: 'John',
477
+ * last_name: 'Doe',
478
+ * gender: 'female',
479
+ * })
480
+ * .execute()
481
+ * ```
482
+ *
483
+ * The generated SQL (SQLite):
484
+ *
485
+ * ```sql
486
+ * insert or fail into "person" ("first_name", "last_name", "gender") values (?, ?, ?)
487
+ * ```
488
+ */
489
+ orFail() {
490
+ return new InsertQueryBuilder({
491
+ ...this.#props,
492
+ queryNode: insert_query_node_js_1.InsertQueryNode.cloneWith(this.#props.queryNode, {
493
+ orAction: or_action_node_js_1.OrActionNode.create('fail'),
494
+ }),
495
+ });
496
+ }
497
+ /**
498
+ * Changes an `insert into` query to an `insert or replace into` query.
499
+ *
500
+ * This is only supported by some dialects like SQLite.
501
+ *
502
+ * You can also use {@link Kysely.replaceInto} to achieve the same result.
503
+ *
504
+ * See also, {@link orIgnore}, {@link orAbort}, {@link orFail}, and {@link orRollback}.
505
+ *
506
+ * ### Examples
507
+ *
508
+ * ```ts
509
+ * await db.insertInto('person')
510
+ * .orReplace()
511
+ * .values({
512
+ * first_name: 'John',
513
+ * last_name: 'Doe',
514
+ * gender: 'female',
515
+ * })
516
+ * .execute()
517
+ * ```
518
+ *
519
+ * The generated SQL (SQLite):
520
+ *
521
+ * ```sql
522
+ * insert or replace into "person" ("first_name", "last_name", "gender") values (?, ?, ?)
523
+ * ```
524
+ */
525
+ orReplace() {
526
+ return new InsertQueryBuilder({
527
+ ...this.#props,
528
+ queryNode: insert_query_node_js_1.InsertQueryNode.cloneWith(this.#props.queryNode, {
529
+ orAction: or_action_node_js_1.OrActionNode.create('replace'),
530
+ }),
531
+ });
532
+ }
533
+ /**
534
+ * Changes an `insert into` query to an `insert or rollback into` query.
535
+ *
536
+ * This is only supported by some dialects like SQLite.
537
+ *
538
+ * See also, {@link orIgnore}, {@link orAbort}, {@link orFail}, and {@link orReplace}.
539
+ *
540
+ * ### Examples
541
+ *
542
+ * ```ts
543
+ * await db.insertInto('person')
544
+ * .orRollback()
545
+ * .values({
546
+ * first_name: 'John',
547
+ * last_name: 'Doe',
548
+ * gender: 'female',
549
+ * })
550
+ * .execute()
551
+ * ```
552
+ *
553
+ * The generated SQL (SQLite):
554
+ *
555
+ * ```sql
556
+ * insert or rollback into "person" ("first_name", "last_name", "gender") values (?, ?, ?)
557
+ * ```
558
+ */
559
+ orRollback() {
560
+ return new InsertQueryBuilder({
561
+ ...this.#props,
562
+ queryNode: insert_query_node_js_1.InsertQueryNode.cloneWith(this.#props.queryNode, {
563
+ orAction: or_action_node_js_1.OrActionNode.create('rollback'),
564
+ }),
565
+ });
566
+ }
567
+ /**
568
+ * Changes an `insert into` query to an `insert top into` query.
569
+ *
570
+ * `top` clause is only supported by some dialects like MS SQL Server.
571
+ *
572
+ * ### Examples
573
+ *
574
+ * Insert the first 5 rows:
575
+ *
576
+ * ```ts
577
+ * import { sql } from 'kysely'
578
+ *
579
+ * await db.insertInto('person')
580
+ * .top(5)
581
+ * .columns(['first_name', 'gender'])
582
+ * .expression(
583
+ * (eb) => eb.selectFrom('pet').select(['name', sql.lit('other').as('gender')])
584
+ * )
585
+ * .execute()
586
+ * ```
587
+ *
588
+ * The generated SQL (MS SQL Server):
589
+ *
590
+ * ```sql
591
+ * insert top(5) into "person" ("first_name", "gender") select "name", 'other' as "gender" from "pet"
592
+ * ```
593
+ *
594
+ * Insert the first 50 percent of rows:
595
+ *
596
+ * ```ts
597
+ * import { sql } from 'kysely'
598
+ *
599
+ * await db.insertInto('person')
600
+ * .top(50, 'percent')
601
+ * .columns(['first_name', 'gender'])
602
+ * .expression(
603
+ * (eb) => eb.selectFrom('pet').select(['name', sql.lit('other').as('gender')])
604
+ * )
605
+ * .execute()
606
+ * ```
607
+ *
608
+ * The generated SQL (MS SQL Server):
609
+ *
610
+ * ```sql
611
+ * insert top(50) percent into "person" ("first_name", "gender") select "name", 'other' as "gender" from "pet"
612
+ * ```
613
+ */
614
+ top(expression, modifiers) {
615
+ return new InsertQueryBuilder({
616
+ ...this.#props,
617
+ queryNode: query_node_js_1.QueryNode.cloneWithTop(this.#props.queryNode, (0, top_parser_js_1.parseTop)(expression, modifiers)),
618
+ });
619
+ }
620
+ /**
621
+ * Adds an `on conflict` clause to the query.
622
+ *
623
+ * `on conflict` is only supported by some dialects like PostgreSQL and SQLite. On MySQL
624
+ * you can use {@link ignore} and {@link onDuplicateKeyUpdate} to achieve similar results.
625
+ *
626
+ * ### Examples
627
+ *
628
+ * ```ts
629
+ * await db
630
+ * .insertInto('pet')
631
+ * .values({
632
+ * name: 'Catto',
633
+ * species: 'cat',
634
+ * owner_id: 3,
635
+ * })
636
+ * .onConflict((oc) => oc
637
+ * .column('name')
638
+ * .doUpdateSet({ species: 'hamster' })
639
+ * )
640
+ * .execute()
641
+ * ```
642
+ *
643
+ * The generated SQL (PostgreSQL):
644
+ *
645
+ * ```sql
646
+ * insert into "pet" ("name", "species", "owner_id")
647
+ * values ($1, $2, $3)
648
+ * on conflict ("name")
649
+ * do update set "species" = $4
650
+ * ```
651
+ *
652
+ * You can provide the name of the constraint instead of a column name:
653
+ *
654
+ * ```ts
655
+ * await db
656
+ * .insertInto('pet')
657
+ * .values({
658
+ * name: 'Catto',
659
+ * species: 'cat',
660
+ * owner_id: 3,
661
+ * })
662
+ * .onConflict((oc) => oc
663
+ * .constraint('pet_name_key')
664
+ * .doUpdateSet({ species: 'hamster' })
665
+ * )
666
+ * .execute()
667
+ * ```
668
+ *
669
+ * The generated SQL (PostgreSQL):
670
+ *
671
+ * ```sql
672
+ * insert into "pet" ("name", "species", "owner_id")
673
+ * values ($1, $2, $3)
674
+ * on conflict on constraint "pet_name_key"
675
+ * do update set "species" = $4
676
+ * ```
677
+ *
678
+ * You can also specify an expression as the conflict target in case
679
+ * the unique index is an expression index:
680
+ *
681
+ * ```ts
682
+ * import { sql } from 'kysely'
683
+ *
684
+ * await db
685
+ * .insertInto('pet')
686
+ * .values({
687
+ * name: 'Catto',
688
+ * species: 'cat',
689
+ * owner_id: 3,
690
+ * })
691
+ * .onConflict((oc) => oc
692
+ * .expression(sql<string>`lower(name)`)
693
+ * .doUpdateSet({ species: 'hamster' })
694
+ * )
695
+ * .execute()
696
+ * ```
697
+ *
698
+ * The generated SQL (PostgreSQL):
699
+ *
700
+ * ```sql
701
+ * insert into "pet" ("name", "species", "owner_id")
702
+ * values ($1, $2, $3)
703
+ * on conflict (lower(name))
704
+ * do update set "species" = $4
705
+ * ```
706
+ *
707
+ * You can add a filter for the update statement like this:
708
+ *
709
+ * ```ts
710
+ * await db
711
+ * .insertInto('pet')
712
+ * .values({
713
+ * name: 'Catto',
714
+ * species: 'cat',
715
+ * owner_id: 3,
716
+ * })
717
+ * .onConflict((oc) => oc
718
+ * .column('name')
719
+ * .doUpdateSet({ species: 'hamster' })
720
+ * .where('excluded.name', '!=', 'Catto')
721
+ * )
722
+ * .execute()
723
+ * ```
724
+ *
725
+ * The generated SQL (PostgreSQL):
726
+ *
727
+ * ```sql
728
+ * insert into "pet" ("name", "species", "owner_id")
729
+ * values ($1, $2, $3)
730
+ * on conflict ("name")
731
+ * do update set "species" = $4
732
+ * where "excluded"."name" != $5
733
+ * ```
734
+ *
735
+ * You can create an `on conflict do nothing` clauses like this:
736
+ *
737
+ * ```ts
738
+ * await db
739
+ * .insertInto('pet')
740
+ * .values({
741
+ * name: 'Catto',
742
+ * species: 'cat',
743
+ * owner_id: 3,
744
+ * })
745
+ * .onConflict((oc) => oc
746
+ * .column('name')
747
+ * .doNothing()
748
+ * )
749
+ * .execute()
750
+ * ```
751
+ *
752
+ * The generated SQL (PostgreSQL):
753
+ *
754
+ * ```sql
755
+ * insert into "pet" ("name", "species", "owner_id")
756
+ * values ($1, $2, $3)
757
+ * on conflict ("name") do nothing
758
+ * ```
759
+ *
760
+ * You can refer to the columns of the virtual `excluded` table
761
+ * in a type-safe way using a callback and the `ref` method of
762
+ * `ExpressionBuilder`:
763
+ *
764
+ * ```ts
765
+ * await db.insertInto('person')
766
+ * .values({
767
+ * id: 1,
768
+ * first_name: 'John',
769
+ * last_name: 'Doe',
770
+ * gender: 'male',
771
+ * })
772
+ * .onConflict(oc => oc
773
+ * .column('id')
774
+ * .doUpdateSet({
775
+ * first_name: (eb) => eb.ref('excluded.first_name'),
776
+ * last_name: (eb) => eb.ref('excluded.last_name')
777
+ * })
778
+ * )
779
+ * .execute()
780
+ * ```
781
+ *
782
+ * The generated SQL (PostgreSQL):
783
+ *
784
+ * ```sql
785
+ * insert into "person" ("id", "first_name", "last_name", "gender")
786
+ * values ($1, $2, $3, $4)
787
+ * on conflict ("id")
788
+ * do update set
789
+ * "first_name" = "excluded"."first_name",
790
+ * "last_name" = "excluded"."last_name"
791
+ * ```
792
+ */
793
+ onConflict(callback) {
794
+ return new InsertQueryBuilder({
795
+ ...this.#props,
796
+ queryNode: insert_query_node_js_1.InsertQueryNode.cloneWith(this.#props.queryNode, {
797
+ onConflict: callback(new on_conflict_builder_js_1.OnConflictBuilder({
798
+ onConflictNode: on_conflict_node_js_1.OnConflictNode.create(),
799
+ })).toOperationNode(),
800
+ }),
801
+ });
802
+ }
803
+ /**
804
+ * Adds `on duplicate key update` to the query.
805
+ *
806
+ * If you specify `on duplicate key update`, and a row is inserted that would cause
807
+ * a duplicate value in a unique index or primary key, an update of the old row occurs.
808
+ *
809
+ * This is only implemented by some dialects like MySQL. On most dialects you should
810
+ * use {@link onConflict} instead.
811
+ *
812
+ * ### Examples
813
+ *
814
+ * ```ts
815
+ * await db
816
+ * .insertInto('person')
817
+ * .values({
818
+ * id: 1,
819
+ * first_name: 'John',
820
+ * last_name: 'Doe',
821
+ * gender: 'male',
822
+ * })
823
+ * .onDuplicateKeyUpdate({ updated_at: new Date().toISOString() })
824
+ * .execute()
825
+ * ```
826
+ *
827
+ * The generated SQL (MySQL):
828
+ *
829
+ * ```sql
830
+ * insert into `person` (`id`, `first_name`, `last_name`, `gender`)
831
+ * values (?, ?, ?, ?)
832
+ * on duplicate key update `updated_at` = ?
833
+ * ```
834
+ */
835
+ onDuplicateKeyUpdate(update) {
836
+ return new InsertQueryBuilder({
837
+ ...this.#props,
838
+ queryNode: insert_query_node_js_1.InsertQueryNode.cloneWith(this.#props.queryNode, {
839
+ onDuplicateKey: on_duplicate_key_node_js_1.OnDuplicateKeyNode.create((0, update_set_parser_js_1.parseUpdateObjectExpression)(update)),
840
+ }),
841
+ });
842
+ }
843
+ returning(selection) {
844
+ return new InsertQueryBuilder({
845
+ ...this.#props,
846
+ queryNode: query_node_js_1.QueryNode.cloneWithReturning(this.#props.queryNode, (0, select_parser_js_1.parseSelectArg)(selection)),
847
+ });
848
+ }
849
+ returningAll() {
850
+ return new InsertQueryBuilder({
851
+ ...this.#props,
852
+ queryNode: query_node_js_1.QueryNode.cloneWithReturning(this.#props.queryNode, (0, select_parser_js_1.parseSelectAll)()),
853
+ });
854
+ }
855
+ output(args) {
856
+ return new InsertQueryBuilder({
857
+ ...this.#props,
858
+ queryNode: query_node_js_1.QueryNode.cloneWithOutput(this.#props.queryNode, (0, select_parser_js_1.parseSelectArg)(args)),
859
+ });
860
+ }
861
+ outputAll(table) {
862
+ return new InsertQueryBuilder({
863
+ ...this.#props,
864
+ queryNode: query_node_js_1.QueryNode.cloneWithOutput(this.#props.queryNode, (0, select_parser_js_1.parseSelectAll)(table)),
865
+ });
866
+ }
867
+ /**
868
+ * Clears all `returning` clauses from the query.
869
+ *
870
+ * ### Examples
871
+ *
872
+ * ```ts
873
+ * await db.insertInto('person')
874
+ * .values({ first_name: 'James', last_name: 'Smith', gender: 'male' })
875
+ * .returning(['first_name'])
876
+ * .clearReturning()
877
+ * .execute()
878
+ * ```
879
+ *
880
+ * The generated SQL(PostgreSQL):
881
+ *
882
+ * ```sql
883
+ * insert into "person" ("first_name", "last_name", "gender") values ($1, $2, $3)
884
+ * ```
885
+ */
886
+ clearReturning() {
887
+ return new InsertQueryBuilder({
888
+ ...this.#props,
889
+ queryNode: query_node_js_1.QueryNode.cloneWithoutReturning(this.#props.queryNode),
890
+ });
891
+ }
892
+ /**
893
+ * Simply calls the provided function passing `this` as the only argument. `$call` returns
894
+ * what the provided function returns.
895
+ *
896
+ * If you want to conditionally call a method on `this`, see
897
+ * the {@link $if} method.
898
+ *
899
+ * ### Examples
900
+ *
901
+ * The next example uses a helper function `log` to log a query:
902
+ *
903
+ * ```ts
904
+ * import type { Compilable } from 'kysely'
905
+ *
906
+ * function log<T extends Compilable>(qb: T): T {
907
+ * console.log(qb.compile())
908
+ * return qb
909
+ * }
910
+ *
911
+ * await db.insertInto('person')
912
+ * .values({ first_name: 'John', last_name: 'Doe', gender: 'male' })
913
+ * .$call(log)
914
+ * .execute()
915
+ * ```
916
+ */
917
+ $call(func) {
918
+ return func(this);
919
+ }
920
+ /**
921
+ * Call `func(this)` if `condition` is true.
922
+ *
923
+ * This method is especially handy with optional selects. Any `returning` or `returningAll`
924
+ * method calls add columns as optional fields to the output type when called inside
925
+ * the `func` callback. This is because we can't know if those selections were actually
926
+ * made before running the code.
927
+ *
928
+ * You can also call any other methods inside the callback.
929
+ *
930
+ * ### Examples
931
+ *
932
+ * ```ts
933
+ * import type { NewPerson } from 'type-editor' // imaginary module
934
+ *
935
+ * async function insertPerson(values: NewPerson, returnLastName: boolean) {
936
+ * return await db
937
+ * .insertInto('person')
938
+ * .values(values)
939
+ * .returning(['id', 'first_name'])
940
+ * .$if(returnLastName, (qb) => qb.returning('last_name'))
941
+ * .executeTakeFirstOrThrow()
942
+ * }
943
+ * ```
944
+ *
945
+ * Any selections added inside the `if` callback will be added as optional fields to the
946
+ * output type since we can't know if the selections were actually made before running
947
+ * the code. In the example above the return type of the `insertPerson` function is:
948
+ *
949
+ * ```ts
950
+ * Promise<{
951
+ * id: number
952
+ * first_name: string
953
+ * last_name?: string
954
+ * }>
955
+ * ```
956
+ */
957
+ $if(condition, func) {
958
+ if (condition) {
959
+ return func(this);
960
+ }
961
+ return new InsertQueryBuilder({
962
+ ...this.#props,
963
+ });
964
+ }
965
+ /**
966
+ * Change the output type of the query.
967
+ *
968
+ * This method call doesn't change the SQL in any way. This methods simply
969
+ * returns a copy of this `InsertQueryBuilder` with a new output type.
970
+ */
971
+ $castTo() {
972
+ return new InsertQueryBuilder(this.#props);
973
+ }
974
+ /**
975
+ * Narrows (parts of) the output type of the query.
976
+ *
977
+ * Kysely tries to be as type-safe as possible, but in some cases we have to make
978
+ * compromises for better maintainability and compilation performance. At present,
979
+ * Kysely doesn't narrow the output type of the query based on {@link values} input
980
+ * when using {@link returning} or {@link returningAll}.
981
+ *
982
+ * This utility method is very useful for these situations, as it removes unncessary
983
+ * runtime assertion/guard code. Its input type is limited to the output type
984
+ * of the query, so you can't add a column that doesn't exist, or change a column's
985
+ * type to something that doesn't exist in its union type.
986
+ *
987
+ * ### Examples
988
+ *
989
+ * Turn this code:
990
+ *
991
+ * ```ts
992
+ * import type { Person } from 'type-editor' // imaginary module
993
+ *
994
+ * const person = await db.insertInto('person')
995
+ * .values({
996
+ * first_name: 'John',
997
+ * last_name: 'Doe',
998
+ * gender: 'male',
999
+ * nullable_column: 'hell yeah!'
1000
+ * })
1001
+ * .returningAll()
1002
+ * .executeTakeFirstOrThrow()
1003
+ *
1004
+ * if (isWithNoNullValue(person)) {
1005
+ * functionThatExpectsPersonWithNonNullValue(person)
1006
+ * }
1007
+ *
1008
+ * function isWithNoNullValue(person: Person): person is Person & { nullable_column: string } {
1009
+ * return person.nullable_column != null
1010
+ * }
1011
+ * ```
1012
+ *
1013
+ * Into this:
1014
+ *
1015
+ * ```ts
1016
+ * import type { NotNull } from 'kysely'
1017
+ *
1018
+ * const person = await db.insertInto('person')
1019
+ * .values({
1020
+ * first_name: 'John',
1021
+ * last_name: 'Doe',
1022
+ * gender: 'male',
1023
+ * nullable_column: 'hell yeah!'
1024
+ * })
1025
+ * .returningAll()
1026
+ * .$narrowType<{ nullable_column: NotNull }>()
1027
+ * .executeTakeFirstOrThrow()
1028
+ *
1029
+ * functionThatExpectsPersonWithNonNullValue(person)
1030
+ * ```
1031
+ */
1032
+ $narrowType() {
1033
+ return new InsertQueryBuilder(this.#props);
1034
+ }
1035
+ /**
1036
+ * Asserts that query's output row type equals the given type `T`.
1037
+ *
1038
+ * This method can be used to simplify excessively complex types to make TypeScript happy
1039
+ * and much faster.
1040
+ *
1041
+ * Kysely uses complex type magic to achieve its type safety. This complexity is sometimes too much
1042
+ * for TypeScript and you get errors like this:
1043
+ *
1044
+ * ```
1045
+ * error TS2589: Type instantiation is excessively deep and possibly infinite.
1046
+ * ```
1047
+ *
1048
+ * In these case you can often use this method to help TypeScript a little bit. When you use this
1049
+ * method to assert the output type of a query, Kysely can drop the complex output type that
1050
+ * consists of multiple nested helper types and replace it with the simple asserted type.
1051
+ *
1052
+ * Using this method doesn't reduce type safety at all. You have to pass in a type that is
1053
+ * structurally equal to the current type.
1054
+ *
1055
+ * ### Examples
1056
+ *
1057
+ * ```ts
1058
+ * import type { NewPerson, NewPet, Species } from 'type-editor' // imaginary module
1059
+ *
1060
+ * async function insertPersonAndPet(person: NewPerson, pet: Omit<NewPet, 'owner_id'>) {
1061
+ * return await db
1062
+ * .with('new_person', (qb) => qb
1063
+ * .insertInto('person')
1064
+ * .values(person)
1065
+ * .returning('id')
1066
+ * .$assertType<{ id: number }>()
1067
+ * )
1068
+ * .with('new_pet', (qb) => qb
1069
+ * .insertInto('pet')
1070
+ * .values((eb) => ({
1071
+ * owner_id: eb.selectFrom('new_person').select('id'),
1072
+ * ...pet
1073
+ * }))
1074
+ * .returning(['name as pet_name', 'species'])
1075
+ * .$assertType<{ pet_name: string, species: Species }>()
1076
+ * )
1077
+ * .selectFrom(['new_person', 'new_pet'])
1078
+ * .selectAll()
1079
+ * .executeTakeFirstOrThrow()
1080
+ * }
1081
+ * ```
1082
+ */
1083
+ $assertType() {
1084
+ return new InsertQueryBuilder(this.#props);
1085
+ }
1086
+ /**
1087
+ * Returns a copy of this InsertQueryBuilder instance with the given plugin installed.
1088
+ */
1089
+ withPlugin(plugin) {
1090
+ return new InsertQueryBuilder({
1091
+ ...this.#props,
1092
+ executor: this.#props.executor.withPlugin(plugin),
1093
+ });
1094
+ }
1095
+ toOperationNode() {
1096
+ return this.#props.executor.transformQuery(this.#props.queryNode, this.#props.queryId);
1097
+ }
1098
+ compile() {
1099
+ return this.#props.executor.compileQuery(this.toOperationNode(), this.#props.queryId);
1100
+ }
1101
+ /**
1102
+ * Executes the query and returns an array of rows.
1103
+ *
1104
+ * Also see the {@link executeTakeFirst} and {@link executeTakeFirstOrThrow} methods.
1105
+ */
1106
+ async execute() {
1107
+ const compiledQuery = this.compile();
1108
+ const result = await this.#props.executor.executeQuery(compiledQuery);
1109
+ const { adapter } = this.#props.executor;
1110
+ const query = compiledQuery.query;
1111
+ if ((query.returning && adapter.supportsReturning) ||
1112
+ (query.output && adapter.supportsOutput)) {
1113
+ return result.rows;
1114
+ }
1115
+ return [
1116
+ new insert_result_js_1.InsertResult(result.insertId, result.numAffectedRows ?? BigInt(0)),
1117
+ ];
1118
+ }
1119
+ /**
1120
+ * Executes the query and returns the first result or undefined if
1121
+ * the query returned no result.
1122
+ */
1123
+ async executeTakeFirst() {
1124
+ const [result] = await this.execute();
1125
+ return result;
1126
+ }
1127
+ /**
1128
+ * Executes the query and returns the first result or throws if
1129
+ * the query returned no result.
1130
+ *
1131
+ * By default an instance of {@link NoResultError} is thrown, but you can
1132
+ * provide a custom error class, or callback as the only argument to throw a different
1133
+ * error.
1134
+ */
1135
+ async executeTakeFirstOrThrow(errorConstructor = no_result_error_js_1.NoResultError) {
1136
+ const result = await this.executeTakeFirst();
1137
+ if (result === undefined) {
1138
+ const error = (0, no_result_error_js_1.isNoResultErrorConstructor)(errorConstructor)
1139
+ ? new errorConstructor(this.toOperationNode())
1140
+ : errorConstructor(this.toOperationNode());
1141
+ throw error;
1142
+ }
1143
+ return result;
1144
+ }
1145
+ async *stream(chunkSize = 100) {
1146
+ const compiledQuery = this.compile();
1147
+ const stream = this.#props.executor.stream(compiledQuery, chunkSize);
1148
+ for await (const item of stream) {
1149
+ yield* item.rows;
1150
+ }
1151
+ }
1152
+ async explain(format, options) {
1153
+ const builder = new InsertQueryBuilder({
1154
+ ...this.#props,
1155
+ queryNode: query_node_js_1.QueryNode.cloneWithExplain(this.#props.queryNode, format, options),
1156
+ });
1157
+ return await builder.execute();
1158
+ }
1159
+ }
1160
+ exports.InsertQueryBuilder = InsertQueryBuilder;