drizzle-orm 0.43.0 → 0.43.1-08e3953

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 (345) hide show
  1. package/column-builder.cjs.map +1 -1
  2. package/column-builder.d.cts +4 -3
  3. package/column-builder.d.ts +4 -3
  4. package/column-builder.js.map +1 -1
  5. package/mssql-core/alias.cjs +32 -0
  6. package/mssql-core/alias.cjs.map +1 -0
  7. package/mssql-core/alias.d.cts +4 -0
  8. package/mssql-core/alias.d.ts +4 -0
  9. package/mssql-core/alias.js +8 -0
  10. package/mssql-core/alias.js.map +1 -0
  11. package/mssql-core/checks.cjs +58 -0
  12. package/mssql-core/checks.cjs.map +1 -0
  13. package/mssql-core/checks.d.cts +18 -0
  14. package/mssql-core/checks.d.ts +18 -0
  15. package/mssql-core/checks.js +32 -0
  16. package/mssql-core/checks.js.map +1 -0
  17. package/mssql-core/columns/all.cjs +72 -0
  18. package/mssql-core/columns/all.cjs.map +1 -0
  19. package/mssql-core/columns/all.d.cts +43 -0
  20. package/mssql-core/columns/all.d.ts +43 -0
  21. package/mssql-core/columns/all.js +48 -0
  22. package/mssql-core/columns/all.js.map +1 -0
  23. package/mssql-core/columns/bigint.cjs +67 -0
  24. package/mssql-core/columns/bigint.cjs.map +1 -0
  25. package/mssql-core/columns/bigint.d.cts +33 -0
  26. package/mssql-core/columns/bigint.d.ts +33 -0
  27. package/mssql-core/columns/bigint.js +41 -0
  28. package/mssql-core/columns/bigint.js.map +1 -0
  29. package/mssql-core/columns/binary.cjs +57 -0
  30. package/mssql-core/columns/binary.cjs.map +1 -0
  31. package/mssql-core/columns/binary.d.cts +28 -0
  32. package/mssql-core/columns/binary.d.ts +28 -0
  33. package/mssql-core/columns/binary.js +31 -0
  34. package/mssql-core/columns/binary.js.map +1 -0
  35. package/mssql-core/columns/bit.cjs +54 -0
  36. package/mssql-core/columns/bit.cjs.map +1 -0
  37. package/mssql-core/columns/bit.d.cts +24 -0
  38. package/mssql-core/columns/bit.d.ts +24 -0
  39. package/mssql-core/columns/bit.js +28 -0
  40. package/mssql-core/columns/bit.js.map +1 -0
  41. package/mssql-core/columns/char.cjs +74 -0
  42. package/mssql-core/columns/char.cjs.map +1 -0
  43. package/mssql-core/columns/char.d.cts +37 -0
  44. package/mssql-core/columns/char.d.ts +37 -0
  45. package/mssql-core/columns/char.js +47 -0
  46. package/mssql-core/columns/char.js.map +1 -0
  47. package/mssql-core/columns/common.cjs +117 -0
  48. package/mssql-core/columns/common.cjs.map +1 -0
  49. package/mssql-core/columns/common.d.cts +67 -0
  50. package/mssql-core/columns/common.d.ts +67 -0
  51. package/mssql-core/columns/common.js +90 -0
  52. package/mssql-core/columns/common.js.map +1 -0
  53. package/mssql-core/columns/custom.cjs +75 -0
  54. package/mssql-core/columns/custom.cjs.map +1 -0
  55. package/mssql-core/columns/custom.d.cts +149 -0
  56. package/mssql-core/columns/custom.d.ts +149 -0
  57. package/mssql-core/columns/custom.js +49 -0
  58. package/mssql-core/columns/custom.js.map +1 -0
  59. package/mssql-core/columns/date.cjs +94 -0
  60. package/mssql-core/columns/date.cjs.map +1 -0
  61. package/mssql-core/columns/date.common.cjs +37 -0
  62. package/mssql-core/columns/date.common.cjs.map +1 -0
  63. package/mssql-core/columns/date.common.d.cts +12 -0
  64. package/mssql-core/columns/date.common.d.ts +12 -0
  65. package/mssql-core/columns/date.common.js +13 -0
  66. package/mssql-core/columns/date.common.js.map +1 -0
  67. package/mssql-core/columns/date.d.cts +55 -0
  68. package/mssql-core/columns/date.d.ts +55 -0
  69. package/mssql-core/columns/date.js +66 -0
  70. package/mssql-core/columns/date.js.map +1 -0
  71. package/mssql-core/columns/datetime.cjs +94 -0
  72. package/mssql-core/columns/datetime.cjs.map +1 -0
  73. package/mssql-core/columns/datetime.d.cts +54 -0
  74. package/mssql-core/columns/datetime.d.ts +54 -0
  75. package/mssql-core/columns/datetime.js +66 -0
  76. package/mssql-core/columns/datetime.js.map +1 -0
  77. package/mssql-core/columns/datetime2.cjs +102 -0
  78. package/mssql-core/columns/datetime2.cjs.map +1 -0
  79. package/mssql-core/columns/datetime2.d.cts +54 -0
  80. package/mssql-core/columns/datetime2.d.ts +54 -0
  81. package/mssql-core/columns/datetime2.js +74 -0
  82. package/mssql-core/columns/datetime2.js.map +1 -0
  83. package/mssql-core/columns/datetimeoffset.cjs +102 -0
  84. package/mssql-core/columns/datetimeoffset.cjs.map +1 -0
  85. package/mssql-core/columns/datetimeoffset.d.cts +54 -0
  86. package/mssql-core/columns/datetimeoffset.d.ts +54 -0
  87. package/mssql-core/columns/datetimeoffset.js +74 -0
  88. package/mssql-core/columns/datetimeoffset.js.map +1 -0
  89. package/mssql-core/columns/decimal.cjs +68 -0
  90. package/mssql-core/columns/decimal.cjs.map +1 -0
  91. package/mssql-core/columns/decimal.d.cts +30 -0
  92. package/mssql-core/columns/decimal.d.ts +30 -0
  93. package/mssql-core/columns/decimal.js +42 -0
  94. package/mssql-core/columns/decimal.js.map +1 -0
  95. package/mssql-core/columns/float.cjs +58 -0
  96. package/mssql-core/columns/float.cjs.map +1 -0
  97. package/mssql-core/columns/float.d.cts +28 -0
  98. package/mssql-core/columns/float.d.ts +28 -0
  99. package/mssql-core/columns/float.js +32 -0
  100. package/mssql-core/columns/float.js.map +1 -0
  101. package/mssql-core/columns/index.cjs +63 -0
  102. package/mssql-core/columns/index.cjs.map +1 -0
  103. package/mssql-core/columns/index.d.cts +21 -0
  104. package/mssql-core/columns/index.d.ts +21 -0
  105. package/mssql-core/columns/index.js +22 -0
  106. package/mssql-core/columns/index.js.map +1 -0
  107. package/mssql-core/columns/int.cjs +53 -0
  108. package/mssql-core/columns/int.cjs.map +1 -0
  109. package/mssql-core/columns/int.d.cts +23 -0
  110. package/mssql-core/columns/int.d.ts +23 -0
  111. package/mssql-core/columns/int.js +27 -0
  112. package/mssql-core/columns/int.js.map +1 -0
  113. package/mssql-core/columns/numeric.cjs +68 -0
  114. package/mssql-core/columns/numeric.cjs.map +1 -0
  115. package/mssql-core/columns/numeric.d.cts +27 -0
  116. package/mssql-core/columns/numeric.d.ts +27 -0
  117. package/mssql-core/columns/numeric.js +42 -0
  118. package/mssql-core/columns/numeric.js.map +1 -0
  119. package/mssql-core/columns/real.cjs +53 -0
  120. package/mssql-core/columns/real.cjs.map +1 -0
  121. package/mssql-core/columns/real.d.cts +23 -0
  122. package/mssql-core/columns/real.d.ts +23 -0
  123. package/mssql-core/columns/real.js +27 -0
  124. package/mssql-core/columns/real.js.map +1 -0
  125. package/mssql-core/columns/smallint.cjs +62 -0
  126. package/mssql-core/columns/smallint.cjs.map +1 -0
  127. package/mssql-core/columns/smallint.d.cts +24 -0
  128. package/mssql-core/columns/smallint.d.ts +24 -0
  129. package/mssql-core/columns/smallint.js +36 -0
  130. package/mssql-core/columns/smallint.js.map +1 -0
  131. package/mssql-core/columns/text.cjs +68 -0
  132. package/mssql-core/columns/text.cjs.map +1 -0
  133. package/mssql-core/columns/text.d.cts +45 -0
  134. package/mssql-core/columns/text.d.ts +45 -0
  135. package/mssql-core/columns/text.js +41 -0
  136. package/mssql-core/columns/text.js.map +1 -0
  137. package/mssql-core/columns/time.cjs +90 -0
  138. package/mssql-core/columns/time.cjs.map +1 -0
  139. package/mssql-core/columns/time.d.cts +49 -0
  140. package/mssql-core/columns/time.d.ts +49 -0
  141. package/mssql-core/columns/time.js +62 -0
  142. package/mssql-core/columns/time.js.map +1 -0
  143. package/mssql-core/columns/tinyint.cjs +62 -0
  144. package/mssql-core/columns/tinyint.cjs.map +1 -0
  145. package/mssql-core/columns/tinyint.d.cts +24 -0
  146. package/mssql-core/columns/tinyint.d.ts +24 -0
  147. package/mssql-core/columns/tinyint.js +36 -0
  148. package/mssql-core/columns/tinyint.js.map +1 -0
  149. package/mssql-core/columns/varbinary.cjs +61 -0
  150. package/mssql-core/columns/varbinary.cjs.map +1 -0
  151. package/mssql-core/columns/varbinary.d.cts +27 -0
  152. package/mssql-core/columns/varbinary.d.ts +27 -0
  153. package/mssql-core/columns/varbinary.js +35 -0
  154. package/mssql-core/columns/varbinary.js.map +1 -0
  155. package/mssql-core/columns/varchar.cjs +117 -0
  156. package/mssql-core/columns/varchar.cjs.map +1 -0
  157. package/mssql-core/columns/varchar.d.cts +66 -0
  158. package/mssql-core/columns/varchar.d.ts +66 -0
  159. package/mssql-core/columns/varchar.js +88 -0
  160. package/mssql-core/columns/varchar.js.map +1 -0
  161. package/mssql-core/db.cjs +254 -0
  162. package/mssql-core/db.cjs.map +1 -0
  163. package/mssql-core/db.d.cts +228 -0
  164. package/mssql-core/db.d.ts +228 -0
  165. package/mssql-core/db.js +235 -0
  166. package/mssql-core/db.js.map +1 -0
  167. package/mssql-core/dialect.cjs +611 -0
  168. package/mssql-core/dialect.cjs.map +1 -0
  169. package/mssql-core/dialect.d.cts +58 -0
  170. package/mssql-core/dialect.d.ts +58 -0
  171. package/mssql-core/dialect.js +593 -0
  172. package/mssql-core/dialect.js.map +1 -0
  173. package/mssql-core/expressions.cjs +49 -0
  174. package/mssql-core/expressions.cjs.map +1 -0
  175. package/mssql-core/expressions.d.cts +8 -0
  176. package/mssql-core/expressions.d.ts +8 -0
  177. package/mssql-core/expressions.js +22 -0
  178. package/mssql-core/expressions.js.map +1 -0
  179. package/mssql-core/foreign-keys.cjs +91 -0
  180. package/mssql-core/foreign-keys.cjs.map +1 -0
  181. package/mssql-core/foreign-keys.d.cts +51 -0
  182. package/mssql-core/foreign-keys.d.ts +51 -0
  183. package/mssql-core/foreign-keys.js +65 -0
  184. package/mssql-core/foreign-keys.js.map +1 -0
  185. package/mssql-core/index.cjs +55 -0
  186. package/mssql-core/index.cjs.map +1 -0
  187. package/mssql-core/index.d.cts +17 -0
  188. package/mssql-core/index.d.ts +17 -0
  189. package/mssql-core/index.js +18 -0
  190. package/mssql-core/index.js.map +1 -0
  191. package/mssql-core/indexes.cjs +80 -0
  192. package/mssql-core/indexes.cjs.map +1 -0
  193. package/mssql-core/indexes.d.cts +49 -0
  194. package/mssql-core/indexes.d.ts +49 -0
  195. package/mssql-core/indexes.js +52 -0
  196. package/mssql-core/indexes.js.map +1 -0
  197. package/mssql-core/primary-keys.cjs +64 -0
  198. package/mssql-core/primary-keys.cjs.map +1 -0
  199. package/mssql-core/primary-keys.d.cts +23 -0
  200. package/mssql-core/primary-keys.d.ts +23 -0
  201. package/mssql-core/primary-keys.js +38 -0
  202. package/mssql-core/primary-keys.js.map +1 -0
  203. package/mssql-core/query-builders/delete.cjs +107 -0
  204. package/mssql-core/query-builders/delete.cjs.map +1 -0
  205. package/mssql-core/query-builders/delete.d.cts +80 -0
  206. package/mssql-core/query-builders/delete.d.ts +80 -0
  207. package/mssql-core/query-builders/delete.js +83 -0
  208. package/mssql-core/query-builders/delete.js.map +1 -0
  209. package/mssql-core/query-builders/index.cjs +33 -0
  210. package/mssql-core/query-builders/index.cjs.map +1 -0
  211. package/mssql-core/query-builders/index.d.cts +6 -0
  212. package/mssql-core/query-builders/index.d.ts +6 -0
  213. package/mssql-core/query-builders/index.js +7 -0
  214. package/mssql-core/query-builders/index.js.map +1 -0
  215. package/mssql-core/query-builders/insert.cjs +105 -0
  216. package/mssql-core/query-builders/insert.cjs.map +1 -0
  217. package/mssql-core/query-builders/insert.d.cts +60 -0
  218. package/mssql-core/query-builders/insert.d.ts +60 -0
  219. package/mssql-core/query-builders/insert.js +80 -0
  220. package/mssql-core/query-builders/insert.js.map +1 -0
  221. package/mssql-core/query-builders/query-builder.cjs +95 -0
  222. package/mssql-core/query-builders/query-builder.cjs.map +1 -0
  223. package/mssql-core/query-builders/query-builder.d.cts +32 -0
  224. package/mssql-core/query-builders/query-builder.d.ts +32 -0
  225. package/mssql-core/query-builders/query-builder.js +71 -0
  226. package/mssql-core/query-builders/query-builder.js.map +1 -0
  227. package/mssql-core/query-builders/query.cjs +126 -0
  228. package/mssql-core/query-builders/query.cjs.map +1 -0
  229. package/mssql-core/query-builders/query.d.cts +42 -0
  230. package/mssql-core/query-builders/query.d.ts +42 -0
  231. package/mssql-core/query-builders/query.js +103 -0
  232. package/mssql-core/query-builders/query.js.map +1 -0
  233. package/mssql-core/query-builders/select.cjs +679 -0
  234. package/mssql-core/query-builders/select.cjs.map +1 -0
  235. package/mssql-core/query-builders/select.d.cts +549 -0
  236. package/mssql-core/query-builders/select.d.ts +549 -0
  237. package/mssql-core/query-builders/select.js +649 -0
  238. package/mssql-core/query-builders/select.js.map +1 -0
  239. package/mssql-core/query-builders/select.types.cjs +17 -0
  240. package/mssql-core/query-builders/select.types.cjs.map +1 -0
  241. package/mssql-core/query-builders/select.types.d.cts +142 -0
  242. package/mssql-core/query-builders/select.types.d.ts +142 -0
  243. package/mssql-core/query-builders/select.types.js +1 -0
  244. package/mssql-core/query-builders/select.types.js.map +1 -0
  245. package/mssql-core/query-builders/update.cjs +138 -0
  246. package/mssql-core/query-builders/update.cjs.map +1 -0
  247. package/mssql-core/query-builders/update.d.cts +109 -0
  248. package/mssql-core/query-builders/update.d.ts +109 -0
  249. package/mssql-core/query-builders/update.js +113 -0
  250. package/mssql-core/query-builders/update.js.map +1 -0
  251. package/mssql-core/schema.cjs +51 -0
  252. package/mssql-core/schema.cjs.map +1 -0
  253. package/mssql-core/schema.d.cts +22 -0
  254. package/mssql-core/schema.d.ts +22 -0
  255. package/mssql-core/schema.js +25 -0
  256. package/mssql-core/schema.js.map +1 -0
  257. package/mssql-core/session.cjs +74 -0
  258. package/mssql-core/session.cjs.map +1 -0
  259. package/mssql-core/session.d.cts +63 -0
  260. package/mssql-core/session.d.ts +63 -0
  261. package/mssql-core/session.js +48 -0
  262. package/mssql-core/session.js.map +1 -0
  263. package/mssql-core/subquery.cjs +17 -0
  264. package/mssql-core/subquery.cjs.map +1 -0
  265. package/mssql-core/subquery.d.cts +18 -0
  266. package/mssql-core/subquery.d.ts +18 -0
  267. package/mssql-core/subquery.js +1 -0
  268. package/mssql-core/subquery.js.map +1 -0
  269. package/mssql-core/table.cjs +81 -0
  270. package/mssql-core/table.cjs.map +1 -0
  271. package/mssql-core/table.d.cts +43 -0
  272. package/mssql-core/table.d.ts +43 -0
  273. package/mssql-core/table.js +53 -0
  274. package/mssql-core/table.js.map +1 -0
  275. package/mssql-core/unique-constraint.cjs +76 -0
  276. package/mssql-core/unique-constraint.cjs.map +1 -0
  277. package/mssql-core/unique-constraint.d.cts +23 -0
  278. package/mssql-core/unique-constraint.d.ts +23 -0
  279. package/mssql-core/unique-constraint.js +49 -0
  280. package/mssql-core/unique-constraint.js.map +1 -0
  281. package/mssql-core/utils.cjs +85 -0
  282. package/mssql-core/utils.cjs.map +1 -0
  283. package/mssql-core/utils.d.cts +31 -0
  284. package/mssql-core/utils.d.ts +31 -0
  285. package/mssql-core/utils.js +60 -0
  286. package/mssql-core/utils.js.map +1 -0
  287. package/mssql-core/view-base.cjs +33 -0
  288. package/mssql-core/view-base.cjs.map +1 -0
  289. package/mssql-core/view-base.d.cts +9 -0
  290. package/mssql-core/view-base.d.ts +9 -0
  291. package/mssql-core/view-base.js +9 -0
  292. package/mssql-core/view-base.js.map +1 -0
  293. package/mssql-core/view-common.cjs +29 -0
  294. package/mssql-core/view-common.cjs.map +1 -0
  295. package/mssql-core/view-common.d.cts +1 -0
  296. package/mssql-core/view-common.d.ts +1 -0
  297. package/mssql-core/view-common.js +5 -0
  298. package/mssql-core/view-common.js.map +1 -0
  299. package/mssql-core/view.cjs +154 -0
  300. package/mssql-core/view.cjs.map +1 -0
  301. package/mssql-core/view.d.cts +64 -0
  302. package/mssql-core/view.d.ts +64 -0
  303. package/mssql-core/view.js +125 -0
  304. package/mssql-core/view.js.map +1 -0
  305. package/node-mssql/driver.cjs +88 -0
  306. package/node-mssql/driver.cjs.map +1 -0
  307. package/node-mssql/driver.d.cts +34 -0
  308. package/node-mssql/driver.d.ts +34 -0
  309. package/node-mssql/driver.js +65 -0
  310. package/node-mssql/driver.js.map +1 -0
  311. package/node-mssql/index.cjs +25 -0
  312. package/node-mssql/index.cjs.map +1 -0
  313. package/node-mssql/index.d.cts +2 -0
  314. package/node-mssql/index.d.ts +2 -0
  315. package/node-mssql/index.js +3 -0
  316. package/node-mssql/index.js.map +1 -0
  317. package/node-mssql/migrator.cjs +33 -0
  318. package/node-mssql/migrator.cjs.map +1 -0
  319. package/node-mssql/migrator.d.cts +3 -0
  320. package/node-mssql/migrator.d.ts +3 -0
  321. package/node-mssql/migrator.js +9 -0
  322. package/node-mssql/migrator.js.map +1 -0
  323. package/node-mssql/session.cjs +243 -0
  324. package/node-mssql/session.cjs.map +1 -0
  325. package/node-mssql/session.d.cts +47 -0
  326. package/node-mssql/session.d.ts +47 -0
  327. package/node-mssql/session.js +211 -0
  328. package/node-mssql/session.js.map +1 -0
  329. package/package.json +653 -1
  330. package/pg-core/schema.cjs +2 -2
  331. package/pg-core/schema.cjs.map +1 -1
  332. package/pg-core/schema.d.cts +4 -1
  333. package/pg-core/schema.d.ts +4 -1
  334. package/pg-core/schema.js +2 -2
  335. package/pg-core/schema.js.map +1 -1
  336. package/relations.cjs +48 -0
  337. package/relations.cjs.map +1 -1
  338. package/relations.d.cts +1 -0
  339. package/relations.d.ts +1 -0
  340. package/relations.js +47 -0
  341. package/relations.js.map +1 -1
  342. package/version.cjs +1 -1
  343. package/version.d.cts +1 -1
  344. package/version.d.ts +1 -1
  345. package/version.js +1 -1
@@ -0,0 +1,593 @@
1
+ import { aliasedTable, aliasedTableColumn, mapColumnsInAliasedSQLToAlias, mapColumnsInSQLToAlias } from "../alias.js";
2
+ import { CasingCache } from "../casing.js";
3
+ import { Column } from "../column.js";
4
+ import { entityKind, is } from "../entity.js";
5
+ import {
6
+ getOperators,
7
+ getOrderByOperators,
8
+ Many,
9
+ normalizeRelation,
10
+ One
11
+ } from "../relations.js";
12
+ import { Param, SQL, sql, View } from "../sql/sql.js";
13
+ import { Subquery } from "../subquery.js";
14
+ import { getTableName, getTableUniqueName, Table } from "../table.js";
15
+ import { orderSelectedFields } from "../utils.js";
16
+ import { and, DrizzleError, eq, ViewBaseConfig } from "../index.js";
17
+ import { MsSqlColumn } from "./columns/common.js";
18
+ import { MsSqlTable } from "./table.js";
19
+ import { MsSqlViewBase } from "./view-base.js";
20
+ class MsSqlDialect {
21
+ static [entityKind] = "MsSqlDialect";
22
+ /** @internal */
23
+ casing;
24
+ constructor(config) {
25
+ this.casing = new CasingCache(config?.casing);
26
+ }
27
+ async migrate(migrations, session, config) {
28
+ const migrationsTable = config.migrationsTable ?? "__drizzle_migrations";
29
+ const migrationTableCreate = sql`
30
+ create table ${sql.identifier(migrationsTable)} (
31
+ id bigint identity primary key,
32
+ hash text not null,
33
+ created_at bigint
34
+ )
35
+ `;
36
+ await session.execute(migrationTableCreate);
37
+ const dbMigrations = await session.all(
38
+ sql`select id, hash, created_at from ${sql.identifier(migrationsTable)} order by created_at desc offset 0 rows fetch next 1 rows only`
39
+ );
40
+ const lastDbMigration = dbMigrations[0];
41
+ await session.transaction(async (tx) => {
42
+ for (const migration of migrations) {
43
+ if (!lastDbMigration || Number(lastDbMigration.created_at) < migration.folderMillis) {
44
+ for (const stmt of migration.sql) {
45
+ await tx.execute(sql.raw(stmt));
46
+ }
47
+ await tx.execute(
48
+ sql`insert into ${sql.identifier(migrationsTable)} ([hash], [created_at]) values(${migration.hash}, ${migration.folderMillis})`
49
+ );
50
+ }
51
+ }
52
+ });
53
+ }
54
+ escapeName(name) {
55
+ return `[${name}]`;
56
+ }
57
+ escapeParam(_num) {
58
+ return `@par${_num}`;
59
+ }
60
+ escapeString(str) {
61
+ return `'${str.replace(/'/g, "''")}'`;
62
+ }
63
+ buildDeleteQuery({ table, where, output }) {
64
+ const outputSql = output ? sql` output ${this.buildSelectionOutput(output, { type: "DELETED" })}` : void 0;
65
+ const whereSql = where ? sql` where ${where}` : void 0;
66
+ return sql`delete from ${table}${outputSql}${whereSql}`;
67
+ }
68
+ buildUpdateSet(table, set) {
69
+ const tableColumns = table[Table.Symbol.Columns];
70
+ const columnNames = Object.keys(tableColumns).filter(
71
+ (colName) => set[colName] !== void 0 || tableColumns[colName]?.onUpdateFn !== void 0
72
+ );
73
+ const setSize = columnNames.length;
74
+ return sql.join(columnNames.flatMap((colName, i) => {
75
+ const col = tableColumns[colName];
76
+ const value = set[colName] ?? sql.param(col.onUpdateFn(), col);
77
+ const res = sql`${sql.identifier(this.casing.getColumnCasing(col))} = ${value}`;
78
+ if (i < setSize - 1) {
79
+ return [res, sql.raw(", ")];
80
+ }
81
+ return [res];
82
+ }));
83
+ }
84
+ buildUpdateQuery({ table, set, where, output }) {
85
+ const setSql = this.buildUpdateSet(table, set);
86
+ const outputSql = sql``;
87
+ if (output) {
88
+ outputSql.append(sql` output `);
89
+ if (output.inserted) {
90
+ outputSql.append(this.buildSelectionOutput(output.inserted, { type: "INSERTED" }));
91
+ }
92
+ if (output.deleted) {
93
+ if (output.inserted)
94
+ outputSql.append(sql`, `);
95
+ outputSql.append(this.buildSelectionOutput(output.deleted, { type: "DELETED" }));
96
+ }
97
+ }
98
+ const whereSql = where ? sql` where ${where}` : void 0;
99
+ return sql`update ${table} set ${setSql}${outputSql}${whereSql}`;
100
+ }
101
+ /**
102
+ * Builds selection SQL with provided fields/expressions
103
+ *
104
+ * Examples:
105
+ *
106
+ * `select <selection> from`
107
+ *
108
+ * `insert ... returning <selection>`
109
+ *
110
+ * If `isSingleTable` is true, then columns won't be prefixed with table name
111
+ */
112
+ buildSelection(fields, { isSingleTable = false } = {}) {
113
+ const columnsLen = fields.length;
114
+ const chunks = fields.flatMap(({ field }, i) => {
115
+ const chunk = [];
116
+ if (is(field, SQL.Aliased) && field.isSelectionField) {
117
+ chunk.push(sql.identifier(field.fieldAlias));
118
+ } else if (is(field, SQL.Aliased) || is(field, SQL)) {
119
+ const query = is(field, SQL.Aliased) ? field.sql : field;
120
+ if (isSingleTable) {
121
+ chunk.push(
122
+ new SQL(
123
+ query.queryChunks.map((c) => {
124
+ if (is(c, MsSqlColumn)) {
125
+ return sql.identifier(this.casing.getColumnCasing(c));
126
+ }
127
+ return c;
128
+ })
129
+ )
130
+ );
131
+ } else {
132
+ chunk.push(query);
133
+ }
134
+ if (is(field, SQL.Aliased)) {
135
+ chunk.push(sql` as ${sql.identifier(field.fieldAlias)}`);
136
+ }
137
+ } else if (is(field, Column)) {
138
+ if (isSingleTable) {
139
+ chunk.push(sql.identifier(this.casing.getColumnCasing(field)));
140
+ } else {
141
+ chunk.push(field);
142
+ }
143
+ }
144
+ if (i < columnsLen - 1) {
145
+ chunk.push(sql`, `);
146
+ }
147
+ return chunk;
148
+ });
149
+ return sql.join(chunks);
150
+ }
151
+ buildSelectionOutput(fields, { type }) {
152
+ const columnsLen = fields.length;
153
+ const chunks = fields.flatMap(({ field }, i) => {
154
+ const chunk = [];
155
+ if (is(field, SQL.Aliased) && field.isSelectionField) {
156
+ chunk.push(sql.join([sql.raw(`${type}.`), sql.identifier(field.fieldAlias)]));
157
+ } else if (is(field, SQL.Aliased) || is(field, SQL)) {
158
+ const query = is(field, SQL.Aliased) ? field.sql : field;
159
+ chunk.push(
160
+ new SQL(
161
+ query.queryChunks.map((c) => {
162
+ if (is(c, MsSqlColumn)) {
163
+ return sql.join([sql.raw(`${type}.`), sql.identifier(this.casing.getColumnCasing(c))]);
164
+ }
165
+ return c;
166
+ })
167
+ )
168
+ );
169
+ if (is(field, SQL.Aliased)) {
170
+ chunk.push(sql` as ${sql.identifier(field.fieldAlias)}`);
171
+ }
172
+ } else if (is(field, Column)) {
173
+ chunk.push(sql.join([sql.raw(`${type}.`), sql.identifier(this.casing.getColumnCasing(field))]));
174
+ }
175
+ if (i < columnsLen - 1) {
176
+ chunk.push(sql`, `);
177
+ }
178
+ return chunk;
179
+ });
180
+ return sql.join(chunks);
181
+ }
182
+ buildSelectQuery({
183
+ withList,
184
+ fields,
185
+ fieldsFlat,
186
+ where,
187
+ having,
188
+ table,
189
+ joins,
190
+ orderBy,
191
+ groupBy,
192
+ fetch,
193
+ for: _for,
194
+ top,
195
+ offset,
196
+ distinct,
197
+ setOperators
198
+ }) {
199
+ const fieldsList = fieldsFlat ?? orderSelectedFields(fields);
200
+ for (const f of fieldsList) {
201
+ if (is(f.field, Column) && getTableName(f.field.table) !== (is(table, Subquery) ? table._.alias : is(table, MsSqlViewBase) ? table[ViewBaseConfig].name : is(table, SQL) ? void 0 : getTableName(table)) && !((table2) => joins?.some(
202
+ ({ alias }) => alias === (table2[Table.Symbol.IsAlias] ? getTableName(table2) : table2[Table.Symbol.BaseName])
203
+ ))(f.field.table)) {
204
+ const tableName = getTableName(f.field.table);
205
+ throw new Error(
206
+ `Your "${f.path.join("->")}" field references a column "${tableName}"."${f.field.name}", but the table "${tableName}" is not part of the query! Did you forget to join it?`
207
+ );
208
+ }
209
+ }
210
+ const isSingleTable = !joins || joins.length === 0;
211
+ let withSql;
212
+ if (withList?.length) {
213
+ const withSqlChunks = [sql`with `];
214
+ for (const [i, w] of withList.entries()) {
215
+ withSqlChunks.push(sql`${sql.identifier(w._.alias)} as (${w._.sql})`);
216
+ if (i < withList.length - 1) {
217
+ withSqlChunks.push(sql`, `);
218
+ }
219
+ }
220
+ withSqlChunks.push(sql` `);
221
+ withSql = sql.join(withSqlChunks);
222
+ }
223
+ const distinctSql = distinct ? sql` distinct` : void 0;
224
+ const topSql = top ? sql` top(${top})` : void 0;
225
+ const selection = this.buildSelection(fieldsList, { isSingleTable });
226
+ const tableSql = (() => {
227
+ if (is(table, Table) && table[Table.Symbol.OriginalName] !== table[Table.Symbol.Name]) {
228
+ let fullName = sql`${sql.identifier(table[Table.Symbol.OriginalName])} ${sql.identifier(table[Table.Symbol.Name])}`;
229
+ if (table[Table.Symbol.Schema]) {
230
+ fullName = sql`${sql.identifier(table[Table.Symbol.Schema])}.${fullName}`;
231
+ }
232
+ return fullName;
233
+ }
234
+ return table;
235
+ })();
236
+ const joinsArray = [];
237
+ if (joins) {
238
+ for (const [index, joinMeta] of joins.entries()) {
239
+ if (index === 0) {
240
+ joinsArray.push(sql` `);
241
+ }
242
+ const table2 = joinMeta.table;
243
+ const lateralSql = joinMeta.lateral ? sql` lateral` : void 0;
244
+ if (is(table2, MsSqlTable)) {
245
+ const tableName = table2[MsSqlTable.Symbol.Name];
246
+ const tableSchema = table2[MsSqlTable.Symbol.Schema];
247
+ const origTableName = table2[MsSqlTable.Symbol.OriginalName];
248
+ const alias = tableName === origTableName ? void 0 : joinMeta.alias;
249
+ joinsArray.push(
250
+ sql`${sql.raw(joinMeta.joinType)} join${lateralSql} ${tableSchema ? sql`${sql.identifier(tableSchema)}.` : void 0}${sql.identifier(origTableName)}${alias && sql` ${sql.identifier(alias)}`} on ${joinMeta.on}`
251
+ );
252
+ } else if (is(table2, View)) {
253
+ const viewName = table2[ViewBaseConfig].name;
254
+ const viewSchema = table2[ViewBaseConfig].schema;
255
+ const origViewName = table2[ViewBaseConfig].originalName;
256
+ const alias = viewName === origViewName ? void 0 : joinMeta.alias;
257
+ joinsArray.push(
258
+ sql`${sql.raw(joinMeta.joinType)} join${lateralSql} ${viewSchema ? sql`${sql.identifier(viewSchema)}.` : void 0}${sql.identifier(origViewName)}${alias && sql` ${sql.identifier(alias)}`} on ${joinMeta.on}`
259
+ );
260
+ } else {
261
+ joinsArray.push(
262
+ sql`${sql.raw(joinMeta.joinType)} join${lateralSql} ${table2} on ${joinMeta.on}`
263
+ );
264
+ }
265
+ if (index < joins.length - 1) {
266
+ joinsArray.push(sql` `);
267
+ }
268
+ }
269
+ }
270
+ const joinsSql = sql.join(joinsArray);
271
+ const whereSql = where ? sql` where ${where}` : void 0;
272
+ const havingSql = having ? sql` having ${having}` : void 0;
273
+ let orderBySql;
274
+ if (orderBy && orderBy.length > 0) {
275
+ orderBySql = sql` order by ${sql.join(orderBy, sql`, `)}`;
276
+ }
277
+ let groupBySql;
278
+ if (groupBy && groupBy.length > 0) {
279
+ groupBySql = sql` group by ${sql.join(groupBy, sql`, `)}`;
280
+ }
281
+ const offsetSql = offset === void 0 ? void 0 : sql` offset ${offset} rows`;
282
+ const fetchSql = fetch === void 0 ? void 0 : sql` fetch next ${fetch} rows only`;
283
+ let forSQL;
284
+ if (_for && _for.mode === "json") {
285
+ forSQL = sql` for json ${sql.raw(_for.type)}${_for.options?.root ? sql` root(${sql.identifier(_for.options.root)})` : void 0}${_for.options?.includeNullValues ? sql` include_null_values` : void 0}${_for.options?.withoutArrayWrapper ? sql` without_array_wrapper` : void 0}`;
286
+ }
287
+ const finalQuery = sql`${withSql}select${distinctSql}${topSql} ${selection} from ${tableSql}${joinsSql}${whereSql}${groupBySql}${havingSql}${orderBySql}${offsetSql}${fetchSql}${forSQL}`;
288
+ if (setOperators.length > 0) {
289
+ return this.buildSetOperations(finalQuery, setOperators);
290
+ }
291
+ return finalQuery;
292
+ }
293
+ buildSetOperations(leftSelect, setOperators) {
294
+ const [setOperator, ...rest] = setOperators;
295
+ if (!setOperator) {
296
+ throw new Error("Cannot pass undefined values to any set operator");
297
+ }
298
+ if (rest.length === 0) {
299
+ return this.buildSetOperationQuery({ leftSelect, setOperator });
300
+ }
301
+ return this.buildSetOperations(
302
+ this.buildSetOperationQuery({ leftSelect, setOperator }),
303
+ rest
304
+ );
305
+ }
306
+ buildSetOperationQuery({
307
+ leftSelect,
308
+ setOperator: { type, isAll, rightSelect, fetch, orderBy, offset }
309
+ }) {
310
+ const leftChunk = sql`(${leftSelect.getSQL()}) `;
311
+ const rightChunk = sql`(${rightSelect.getSQL()})`;
312
+ let orderBySql;
313
+ if (orderBy && orderBy.length > 0) {
314
+ const orderByValues = [];
315
+ for (const orderByUnit of orderBy) {
316
+ if (is(orderByUnit, MsSqlColumn)) {
317
+ orderByValues.push(sql.identifier(orderByUnit.name));
318
+ } else if (is(orderByUnit, SQL)) {
319
+ for (let i = 0; i < orderByUnit.queryChunks.length; i++) {
320
+ const chunk = orderByUnit.queryChunks[i];
321
+ if (is(chunk, MsSqlColumn)) {
322
+ orderByUnit.queryChunks[i] = sql.identifier(chunk.name);
323
+ }
324
+ }
325
+ orderByValues.push(sql`${orderByUnit}`);
326
+ } else {
327
+ orderByValues.push(sql`${orderByUnit}`);
328
+ }
329
+ }
330
+ orderBySql = sql` order by ${sql.join(orderByValues, sql`, `)} `;
331
+ }
332
+ const offsetSql = offset === void 0 ? void 0 : sql` offset ${offset} rows`;
333
+ const fetchSql = fetch === void 0 ? void 0 : sql` fetch next ${fetch} rows only`;
334
+ const operatorChunk = sql.raw(`${type} ${isAll ? "all " : ""}`);
335
+ return sql`${leftChunk}${operatorChunk}${rightChunk}${orderBySql}${offsetSql}${fetchSql}`;
336
+ }
337
+ buildInsertQuery({ table, values, output }) {
338
+ const valuesSqlList = [];
339
+ const columns = table[Table.Symbol.Columns];
340
+ const colEntries = Object.entries(columns).filter(
341
+ ([_, col]) => !col.shouldDisableInsert()
342
+ );
343
+ const insertOrder = colEntries.map(([, column]) => sql.identifier(this.casing.getColumnCasing(column)));
344
+ for (const [valueIndex, value] of values.entries()) {
345
+ const valueList = [];
346
+ for (const [fieldName, col] of colEntries) {
347
+ const colValue = value[fieldName];
348
+ if (colValue === void 0 || is(colValue, Param) && colValue.value === void 0) {
349
+ if (col.defaultFn !== void 0) {
350
+ const defaultFnResult = col.defaultFn();
351
+ const defaultValue = is(defaultFnResult, SQL) ? defaultFnResult : sql.param(defaultFnResult, col);
352
+ valueList.push(defaultValue);
353
+ } else if (!col.default && col.onUpdateFn !== void 0) {
354
+ const onUpdateFnResult = col.onUpdateFn();
355
+ const newValue = is(onUpdateFnResult, SQL) ? onUpdateFnResult : sql.param(onUpdateFnResult, col);
356
+ valueList.push(newValue);
357
+ } else {
358
+ valueList.push(sql`default`);
359
+ }
360
+ } else {
361
+ valueList.push(colValue);
362
+ }
363
+ }
364
+ valuesSqlList.push(valueList);
365
+ if (valueIndex < values.length - 1) {
366
+ valuesSqlList.push(sql`, `);
367
+ }
368
+ }
369
+ const valuesSql = insertOrder.length === 0 ? void 0 : sql.join(valuesSqlList);
370
+ const outputSql = output ? sql` output ${this.buildSelectionOutput(output, { type: "INSERTED" })}` : void 0;
371
+ return sql`insert into ${table} ${insertOrder.length === 0 ? sql`default` : insertOrder}${outputSql} values ${valuesSql}`;
372
+ }
373
+ sqlToQuery(sql2, invokeSource) {
374
+ return sql2.toQuery({
375
+ casing: this.casing,
376
+ escapeName: this.escapeName,
377
+ escapeParam: this.escapeParam,
378
+ escapeString: this.escapeString,
379
+ invokeSource
380
+ });
381
+ }
382
+ buildRelationalQuery({
383
+ fullSchema,
384
+ schema,
385
+ tableNamesMap,
386
+ table,
387
+ tableConfig,
388
+ queryConfig: config,
389
+ tableAlias,
390
+ nestedQueryRelation,
391
+ joinOn
392
+ }) {
393
+ let selection = [];
394
+ let limit, offset, orderBy = [], where;
395
+ if (config === true) {
396
+ const selectionEntries = Object.entries(tableConfig.columns);
397
+ selection = selectionEntries.map(([key, value]) => ({
398
+ dbKey: value.name,
399
+ tsKey: key,
400
+ field: aliasedTableColumn(value, tableAlias),
401
+ relationTableTsKey: void 0,
402
+ isJson: false,
403
+ selection: []
404
+ }));
405
+ } else {
406
+ const aliasedColumns = Object.fromEntries(
407
+ Object.entries(tableConfig.columns).map(([key, value]) => [key, aliasedTableColumn(value, tableAlias)])
408
+ );
409
+ if (config.where) {
410
+ const whereSql = typeof config.where === "function" ? config.where(aliasedColumns, getOperators()) : config.where;
411
+ where = whereSql && mapColumnsInSQLToAlias(whereSql, tableAlias);
412
+ }
413
+ const fieldsSelection = [];
414
+ let selectedColumns = [];
415
+ if (config.columns) {
416
+ let isIncludeMode = false;
417
+ for (const [field, value] of Object.entries(config.columns)) {
418
+ if (value === void 0) {
419
+ continue;
420
+ }
421
+ if (field in tableConfig.columns) {
422
+ if (!isIncludeMode && value === true) {
423
+ isIncludeMode = true;
424
+ }
425
+ selectedColumns.push(field);
426
+ }
427
+ }
428
+ if (selectedColumns.length > 0) {
429
+ selectedColumns = isIncludeMode ? selectedColumns.filter((c) => config.columns?.[c] === true) : Object.keys(tableConfig.columns).filter((key) => !selectedColumns.includes(key));
430
+ }
431
+ } else {
432
+ selectedColumns = Object.keys(tableConfig.columns);
433
+ }
434
+ for (const field of selectedColumns) {
435
+ const column = tableConfig.columns[field];
436
+ fieldsSelection.push({ tsKey: field, value: column });
437
+ }
438
+ let selectedRelations = [];
439
+ if (config.with) {
440
+ selectedRelations = Object.entries(config.with).filter((entry) => !!entry[1]).map(([tsKey, queryConfig]) => ({ tsKey, queryConfig, relation: tableConfig.relations[tsKey] }));
441
+ }
442
+ let extras;
443
+ if (config.extras) {
444
+ extras = typeof config.extras === "function" ? config.extras(aliasedColumns, { sql }) : config.extras;
445
+ for (const [tsKey, value] of Object.entries(extras)) {
446
+ fieldsSelection.push({
447
+ tsKey,
448
+ value: mapColumnsInAliasedSQLToAlias(value, tableAlias)
449
+ });
450
+ }
451
+ }
452
+ for (const { tsKey, value } of fieldsSelection) {
453
+ selection.push({
454
+ dbKey: is(value, SQL.Aliased) ? value.fieldAlias : tableConfig.columns[tsKey].name,
455
+ tsKey,
456
+ field: is(value, Column) ? aliasedTableColumn(value, tableAlias) : value,
457
+ relationTableTsKey: void 0,
458
+ isJson: false,
459
+ selection: []
460
+ });
461
+ }
462
+ let orderByOrig = typeof config.orderBy === "function" ? config.orderBy(aliasedColumns, getOrderByOperators()) : config.orderBy ?? [];
463
+ if (!Array.isArray(orderByOrig)) {
464
+ orderByOrig = [orderByOrig];
465
+ }
466
+ orderBy = orderByOrig.map((orderByValue) => {
467
+ if (is(orderByValue, Column)) {
468
+ return aliasedTableColumn(orderByValue, tableAlias);
469
+ }
470
+ return mapColumnsInSQLToAlias(orderByValue, tableAlias);
471
+ });
472
+ limit = config.limit;
473
+ offset = config.offset;
474
+ for (const {
475
+ tsKey: selectedRelationTsKey,
476
+ queryConfig: selectedRelationConfigValue,
477
+ relation
478
+ } of selectedRelations) {
479
+ const normalizedRelation = normalizeRelation(schema, tableNamesMap, relation);
480
+ const relationTableName = getTableUniqueName(relation.referencedTable);
481
+ const relationTableTsName = tableNamesMap[relationTableName];
482
+ const relationTableAlias = `${tableAlias}_${selectedRelationTsKey}`;
483
+ const joinOn2 = and(
484
+ ...normalizedRelation.fields.map(
485
+ (field2, i) => eq(
486
+ aliasedTableColumn(normalizedRelation.references[i], relationTableAlias),
487
+ aliasedTableColumn(field2, tableAlias)
488
+ )
489
+ )
490
+ );
491
+ const builtRelation = this.buildRelationalQuery({
492
+ fullSchema,
493
+ schema,
494
+ tableNamesMap,
495
+ table: fullSchema[relationTableTsName],
496
+ tableConfig: schema[relationTableTsName],
497
+ queryConfig: is(relation, One) ? selectedRelationConfigValue === true ? { limit: 1 } : { ...selectedRelationConfigValue, limit: 1 } : selectedRelationConfigValue,
498
+ tableAlias: relationTableAlias,
499
+ joinOn: joinOn2,
500
+ nestedQueryRelation: relation
501
+ });
502
+ let fieldSql = sql`(${builtRelation.sql} for json auto, include_null_values)${nestedQueryRelation ? sql` as ${sql.identifier(relationTableAlias)}` : void 0}`;
503
+ if (is(relation, Many)) {
504
+ fieldSql = sql`${fieldSql}`;
505
+ }
506
+ const field = fieldSql.as(selectedRelationTsKey);
507
+ selection.push({
508
+ dbKey: selectedRelationTsKey,
509
+ tsKey: selectedRelationTsKey,
510
+ field,
511
+ relationTableTsKey: relationTableTsName,
512
+ isJson: true,
513
+ selection: builtRelation.selection
514
+ });
515
+ }
516
+ }
517
+ if (selection.length === 0) {
518
+ throw new DrizzleError({
519
+ message: `No fields selected for table "${tableConfig.tsName}" ("${tableAlias}"). You need to have at least one item in "columns", "with" or "extras". If you need to select all columns, omit the "columns" key or set it to undefined.`
520
+ });
521
+ }
522
+ let result;
523
+ where = and(joinOn, where);
524
+ if (nestedQueryRelation) {
525
+ let field = sql`${sql.join(
526
+ selection.map((sel) => {
527
+ return is(sel.field, MsSqlColumn) ? sql.identifier(sel.field.name) : is(sel.field, SQL.Aliased) ? sel.isJson ? sel.field.sql : sql`${sel.field.sql} as ${sql.identifier(sel.field.fieldAlias)}` : sel.field;
528
+ }),
529
+ sql`, `
530
+ )}`;
531
+ if (is(nestedQueryRelation, Many)) {
532
+ field = sql`${field}`;
533
+ }
534
+ const nestedSelection = [{
535
+ dbKey: "data",
536
+ tsKey: "data",
537
+ field,
538
+ isJson: true,
539
+ relationTableTsKey: tableConfig.tsName,
540
+ selection
541
+ }];
542
+ result = aliasedTable(table, tableAlias);
543
+ const top = offset ? void 0 : limit ?? void 0;
544
+ const fetch = offset && limit ? limit : void 0;
545
+ if (orderBy.length === 0 && offset !== void 0 && fetch !== void 0) {
546
+ orderBy = [sql`1`];
547
+ }
548
+ result = this.buildSelectQuery({
549
+ table: is(result, MsSqlTable) ? result : new Subquery(result, {}, tableAlias),
550
+ fields: {},
551
+ fieldsFlat: nestedSelection.map(({ field: field2 }) => ({
552
+ path: [],
553
+ field: is(field2, Column) ? aliasedTableColumn(field2, tableAlias) : field2
554
+ })),
555
+ where,
556
+ top,
557
+ offset,
558
+ fetch,
559
+ orderBy,
560
+ setOperators: []
561
+ });
562
+ } else {
563
+ const top = offset ? void 0 : limit ?? void 0;
564
+ const fetch = offset && limit ? limit : void 0;
565
+ if (orderBy.length === 0 && offset !== void 0 && fetch !== void 0) {
566
+ orderBy = [sql`1`];
567
+ }
568
+ result = this.buildSelectQuery({
569
+ table: aliasedTable(table, tableAlias),
570
+ fields: {},
571
+ fieldsFlat: selection.map(({ field }) => ({
572
+ path: [],
573
+ field: is(field, Column) ? aliasedTableColumn(field, tableAlias) : field
574
+ })),
575
+ where,
576
+ top,
577
+ offset,
578
+ fetch,
579
+ orderBy,
580
+ setOperators: []
581
+ });
582
+ }
583
+ return {
584
+ tableTsKey: tableConfig.tsName,
585
+ sql: result,
586
+ selection
587
+ };
588
+ }
589
+ }
590
+ export {
591
+ MsSqlDialect
592
+ };
593
+ //# sourceMappingURL=dialect.js.map