drizzle-orm 0.43.0 → 0.43.1-47c6ad4

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