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,649 @@
1
+ import { entityKind, is } from "../../entity.js";
2
+ import { TypedQueryBuilder } from "../../query-builders/query-builder.js";
3
+ import { QueryPromise } from "../../query-promise.js";
4
+ import { SelectionProxyHandler } from "../../selection-proxy.js";
5
+ import { SQL, View } from "../../sql/sql.js";
6
+ import { Subquery } from "../../subquery.js";
7
+ import { Table } from "../../table.js";
8
+ import { applyMixins, getTableColumns, getTableLikeName, haveSameKeys } from "../../utils.js";
9
+ import { orderSelectedFields } from "../../utils.js";
10
+ import { ViewBaseConfig } from "../../view-common.js";
11
+ import { MsSqlViewBase } from "../view-base.js";
12
+ class MsSqlSelectFromBuilderBase {
13
+ static [entityKind] = "MsSqlSelectFromBuilderBase";
14
+ fields;
15
+ session;
16
+ dialect;
17
+ withList = [];
18
+ distinct;
19
+ topValue;
20
+ constructor(config) {
21
+ this.fields = config.fields;
22
+ this.session = config.session;
23
+ this.dialect = config.dialect;
24
+ if (config.withList) {
25
+ this.withList = config.withList;
26
+ }
27
+ this.distinct = config.distinct;
28
+ this.topValue = config.topValue;
29
+ }
30
+ from(source) {
31
+ const isPartialSelect = !!this.fields;
32
+ let fields;
33
+ if (this.fields) {
34
+ fields = this.fields;
35
+ } else if (is(source, Subquery)) {
36
+ fields = Object.fromEntries(
37
+ Object.keys(source._.selectedFields).map((key) => [key, source[key]])
38
+ );
39
+ } else if (is(source, MsSqlViewBase)) {
40
+ fields = source[ViewBaseConfig].selectedFields;
41
+ } else if (is(source, SQL)) {
42
+ fields = {};
43
+ } else {
44
+ fields = getTableColumns(source);
45
+ }
46
+ return new MsSqlSelectBase({
47
+ table: source,
48
+ fields,
49
+ isPartialSelect,
50
+ session: this.session,
51
+ dialect: this.dialect,
52
+ withList: this.withList,
53
+ distinct: this.distinct,
54
+ topValue: this.topValue
55
+ });
56
+ }
57
+ }
58
+ class MsSqlSelectBuilder extends MsSqlSelectFromBuilderBase {
59
+ static [entityKind] = "MsSqlSelectFromBuilderBase";
60
+ top(top) {
61
+ return new MsSqlSelectFromBuilderBase({
62
+ fields: this.fields,
63
+ session: this.session,
64
+ dialect: this.dialect,
65
+ withList: this.withList,
66
+ distinct: this.distinct,
67
+ topValue: top
68
+ });
69
+ }
70
+ }
71
+ class MsSqlSelectQueryBuilderBase extends TypedQueryBuilder {
72
+ static [entityKind] = "MsSqlSelectQueryBuilderBase";
73
+ _;
74
+ config;
75
+ joinsNotNullableMap;
76
+ tableName;
77
+ isPartialSelect;
78
+ /** @internal */
79
+ session;
80
+ dialect;
81
+ constructor({ table, fields, isPartialSelect, session, dialect, withList, distinct, topValue }) {
82
+ super();
83
+ this.config = {
84
+ withList,
85
+ table,
86
+ fields: { ...fields },
87
+ distinct,
88
+ setOperators: [],
89
+ top: topValue
90
+ };
91
+ this.isPartialSelect = isPartialSelect;
92
+ this.session = session;
93
+ this.dialect = dialect;
94
+ this._ = {
95
+ selectedFields: fields
96
+ };
97
+ this.tableName = getTableLikeName(table);
98
+ this.joinsNotNullableMap = typeof this.tableName === "string" ? { [this.tableName]: true } : {};
99
+ }
100
+ createJoin(joinType) {
101
+ return (table, on) => {
102
+ const baseTableName = this.tableName;
103
+ const tableName = getTableLikeName(table);
104
+ if (typeof tableName === "string" && this.config.joins?.some((join) => join.alias === tableName)) {
105
+ throw new Error(`Alias "${tableName}" is already used in this query`);
106
+ }
107
+ if (!this.isPartialSelect) {
108
+ if (Object.keys(this.joinsNotNullableMap).length === 1 && typeof baseTableName === "string") {
109
+ this.config.fields = {
110
+ [baseTableName]: this.config.fields
111
+ };
112
+ }
113
+ if (typeof tableName === "string" && !is(table, SQL)) {
114
+ const selection = is(table, Subquery) ? table._.selectedFields : is(table, View) ? table[ViewBaseConfig].selectedFields : table[Table.Symbol.Columns];
115
+ this.config.fields[tableName] = selection;
116
+ }
117
+ }
118
+ if (typeof on === "function") {
119
+ on = on(
120
+ new Proxy(
121
+ this.config.fields,
122
+ new SelectionProxyHandler({ sqlAliasedBehavior: "sql", sqlBehavior: "sql" })
123
+ )
124
+ );
125
+ }
126
+ if (!this.config.joins) {
127
+ this.config.joins = [];
128
+ }
129
+ this.config.joins.push({ on, table, joinType, alias: tableName });
130
+ if (typeof tableName === "string") {
131
+ switch (joinType) {
132
+ case "left": {
133
+ this.joinsNotNullableMap[tableName] = false;
134
+ break;
135
+ }
136
+ case "right": {
137
+ this.joinsNotNullableMap = Object.fromEntries(
138
+ Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false])
139
+ );
140
+ this.joinsNotNullableMap[tableName] = true;
141
+ break;
142
+ }
143
+ case "inner": {
144
+ this.joinsNotNullableMap[tableName] = true;
145
+ break;
146
+ }
147
+ case "full": {
148
+ this.joinsNotNullableMap = Object.fromEntries(
149
+ Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false])
150
+ );
151
+ this.joinsNotNullableMap[tableName] = false;
152
+ break;
153
+ }
154
+ }
155
+ }
156
+ return this;
157
+ };
158
+ }
159
+ /**
160
+ * Executes a `left join` operation by adding another table to the current query.
161
+ *
162
+ * Calling this method associates each row of the table with the corresponding row from the joined table, if a match is found. If no matching row exists, it sets all columns of the joined table to null.
163
+ *
164
+ * See docs: {@link https://orm.drizzle.team/docs/joins#left-join}
165
+ *
166
+ * @param table the table to join.
167
+ * @param on the `on` clause.
168
+ *
169
+ * @example
170
+ *
171
+ * ```ts
172
+ * // Select all users and their pets
173
+ * const usersWithPets: { user: User; pets: Pet | null }[] = await db.select()
174
+ * .from(users)
175
+ * .leftJoin(pets, eq(users.id, pets.ownerId))
176
+ *
177
+ * // Select userId and petId
178
+ * const usersIdsAndPetIds: { userId: number; petId: number | null }[] = await db.select({
179
+ * userId: users.id,
180
+ * petId: pets.id,
181
+ * })
182
+ * .from(users)
183
+ * .leftJoin(pets, eq(users.id, pets.ownerId))
184
+ * ```
185
+ */
186
+ leftJoin = this.createJoin("left");
187
+ /**
188
+ * Executes a `right join` operation by adding another table to the current query.
189
+ *
190
+ * Calling this method associates each row of the joined table with the corresponding row from the main table, if a match is found. If no matching row exists, it sets all columns of the main table to null.
191
+ *
192
+ * See docs: {@link https://orm.drizzle.team/docs/joins#right-join}
193
+ *
194
+ * @param table the table to join.
195
+ * @param on the `on` clause.
196
+ *
197
+ * @example
198
+ *
199
+ * ```ts
200
+ * // Select all users and their pets
201
+ * const usersWithPets: { user: User | null; pets: Pet }[] = await db.select()
202
+ * .from(users)
203
+ * .rightJoin(pets, eq(users.id, pets.ownerId))
204
+ *
205
+ * // Select userId and petId
206
+ * const usersIdsAndPetIds: { userId: number | null; petId: number }[] = await db.select({
207
+ * userId: users.id,
208
+ * petId: pets.id,
209
+ * })
210
+ * .from(users)
211
+ * .rightJoin(pets, eq(users.id, pets.ownerId))
212
+ * ```
213
+ */
214
+ rightJoin = this.createJoin("right");
215
+ /**
216
+ * Executes an `inner join` operation, creating a new table by combining rows from two tables that have matching values.
217
+ *
218
+ * Calling this method retrieves rows that have corresponding entries in both joined tables. Rows without matching entries in either table are excluded, resulting in a table that includes only matching pairs.
219
+ *
220
+ * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join}
221
+ *
222
+ * @param table the table to join.
223
+ * @param on the `on` clause.
224
+ *
225
+ * @example
226
+ *
227
+ * ```ts
228
+ * // Select all users and their pets
229
+ * const usersWithPets: { user: User; pets: Pet }[] = await db.select()
230
+ * .from(users)
231
+ * .innerJoin(pets, eq(users.id, pets.ownerId))
232
+ *
233
+ * // Select userId and petId
234
+ * const usersIdsAndPetIds: { userId: number; petId: number }[] = await db.select({
235
+ * userId: users.id,
236
+ * petId: pets.id,
237
+ * })
238
+ * .from(users)
239
+ * .innerJoin(pets, eq(users.id, pets.ownerId))
240
+ * ```
241
+ */
242
+ innerJoin = this.createJoin("inner");
243
+ /**
244
+ * Executes a `full join` operation by combining rows from two tables into a new table.
245
+ *
246
+ * Calling this method retrieves all rows from both main and joined tables, merging rows with matching values and filling in `null` for non-matching columns.
247
+ *
248
+ * See docs: {@link https://orm.drizzle.team/docs/joins#full-join}
249
+ *
250
+ * @param table the table to join.
251
+ * @param on the `on` clause.
252
+ *
253
+ * @example
254
+ *
255
+ * ```ts
256
+ * // Select all users and their pets
257
+ * const usersWithPets: { user: User | null; pets: Pet | null }[] = await db.select()
258
+ * .from(users)
259
+ * .fullJoin(pets, eq(users.id, pets.ownerId))
260
+ *
261
+ * // Select userId and petId
262
+ * const usersIdsAndPetIds: { userId: number | null; petId: number | null }[] = await db.select({
263
+ * userId: users.id,
264
+ * petId: pets.id,
265
+ * })
266
+ * .from(users)
267
+ * .fullJoin(pets, eq(users.id, pets.ownerId))
268
+ * ```
269
+ */
270
+ fullJoin = this.createJoin("full");
271
+ createSetOperator(type, isAll) {
272
+ return (rightSelection) => {
273
+ const rightSelect = typeof rightSelection === "function" ? rightSelection(getMsSqlSetOperators()) : rightSelection;
274
+ if (!haveSameKeys(this.getSelectedFields(), rightSelect.getSelectedFields())) {
275
+ throw new Error(
276
+ "Set operator error (union / intersect / except): selected fields are not the same or are in a different order"
277
+ );
278
+ }
279
+ this.config.setOperators.push({ type, isAll, rightSelect });
280
+ return this;
281
+ };
282
+ }
283
+ /**
284
+ * Adds `union` set operator to the query.
285
+ *
286
+ * Calling this method will combine the result sets of the `select` statements and remove any duplicate rows that appear across them.
287
+ *
288
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#union}
289
+ *
290
+ * @example
291
+ *
292
+ * ```ts
293
+ * // Select all unique names from customers and users tables
294
+ * await db.select({ name: users.name })
295
+ * .from(users)
296
+ * .union(
297
+ * db.select({ name: customers.name }).from(customers)
298
+ * );
299
+ * // or
300
+ * import { union } from 'drizzle-orm/mssql-core'
301
+ *
302
+ * await union(
303
+ * db.select({ name: users.name }).from(users),
304
+ * db.select({ name: customers.name }).from(customers)
305
+ * );
306
+ * ```
307
+ */
308
+ union = this.createSetOperator("union", false);
309
+ /**
310
+ * Adds `union all` set operator to the query.
311
+ *
312
+ * Calling this method will combine the result-set of the `select` statements and keep all duplicate rows that appear across them.
313
+ *
314
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#union-all}
315
+ *
316
+ * @example
317
+ *
318
+ * ```ts
319
+ * // Select all transaction ids from both online and in-store sales
320
+ * await db.select({ transaction: onlineSales.transactionId })
321
+ * .from(onlineSales)
322
+ * .unionAll(
323
+ * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)
324
+ * );
325
+ * // or
326
+ * import { unionAll } from 'drizzle-orm/mssql-core'
327
+ *
328
+ * await unionAll(
329
+ * db.select({ transaction: onlineSales.transactionId }).from(onlineSales),
330
+ * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)
331
+ * );
332
+ * ```
333
+ */
334
+ unionAll = this.createSetOperator("union", true);
335
+ /**
336
+ * Adds `intersect` set operator to the query.
337
+ *
338
+ * Calling this method will retain only the rows that are present in both result sets and eliminate duplicates.
339
+ *
340
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect}
341
+ *
342
+ * @example
343
+ *
344
+ * ```ts
345
+ * // Select course names that are offered in both departments A and B
346
+ * await db.select({ courseName: depA.courseName })
347
+ * .from(depA)
348
+ * .intersect(
349
+ * db.select({ courseName: depB.courseName }).from(depB)
350
+ * );
351
+ * // or
352
+ * import { intersect } from 'drizzle-orm/mssql-core'
353
+ *
354
+ * await intersect(
355
+ * db.select({ courseName: depA.courseName }).from(depA),
356
+ * db.select({ courseName: depB.courseName }).from(depB)
357
+ * );
358
+ * ```
359
+ */
360
+ intersect = this.createSetOperator("intersect", false);
361
+ /**
362
+ * Adds `except` set operator to the query.
363
+ *
364
+ * Calling this method will retrieve all unique rows from the left query, except for the rows that are present in the result set of the right query.
365
+ *
366
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#except}
367
+ *
368
+ * @example
369
+ *
370
+ * ```ts
371
+ * // Select all courses offered in department A but not in department B
372
+ * await db.select({ courseName: depA.courseName })
373
+ * .from(depA)
374
+ * .except(
375
+ * db.select({ courseName: depB.courseName }).from(depB)
376
+ * );
377
+ * // or
378
+ * import { except } from 'drizzle-orm/mssql-core'
379
+ *
380
+ * await except(
381
+ * db.select({ courseName: depA.courseName }).from(depA),
382
+ * db.select({ courseName: depB.courseName }).from(depB)
383
+ * );
384
+ * ```
385
+ */
386
+ except = this.createSetOperator("except", false);
387
+ /** @internal */
388
+ addSetOperators(setOperators) {
389
+ this.config.setOperators.push(...setOperators);
390
+ return this;
391
+ }
392
+ /**
393
+ * Adds a `where` clause to the query.
394
+ *
395
+ * Calling this method will select only those rows that fulfill a specified condition.
396
+ *
397
+ * See docs: {@link https://orm.drizzle.team/docs/select#filtering}
398
+ *
399
+ * @param where the `where` clause.
400
+ *
401
+ * @example
402
+ * You can use conditional operators and `sql function` to filter the rows to be selected.
403
+ *
404
+ * ```ts
405
+ * // Select all cars with green color
406
+ * await db.select().from(cars).where(eq(cars.color, 'green'));
407
+ * // or
408
+ * await db.select().from(cars).where(sql`${cars.color} = 'green'`)
409
+ * ```
410
+ *
411
+ * You can logically combine conditional operators with `and()` and `or()` operators:
412
+ *
413
+ * ```ts
414
+ * // Select all BMW cars with a green color
415
+ * await db.select().from(cars).where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));
416
+ *
417
+ * // Select all cars with the green or blue color
418
+ * await db.select().from(cars).where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));
419
+ * ```
420
+ */
421
+ where(where) {
422
+ if (typeof where === "function") {
423
+ where = where(
424
+ new Proxy(
425
+ this.config.fields,
426
+ new SelectionProxyHandler({ sqlAliasedBehavior: "sql", sqlBehavior: "sql" })
427
+ )
428
+ );
429
+ }
430
+ this.config.where = where;
431
+ return this;
432
+ }
433
+ /**
434
+ * Adds a `having` clause to the query.
435
+ *
436
+ * Calling this method will select only those rows that fulfill a specified condition. It is typically used with aggregate functions to filter the aggregated data based on a specified condition.
437
+ *
438
+ * See docs: {@link https://orm.drizzle.team/docs/select#aggregations}
439
+ *
440
+ * @param having the `having` clause.
441
+ *
442
+ * @example
443
+ *
444
+ * ```ts
445
+ * // Select all brands with more than one car
446
+ * await db.select({
447
+ * brand: cars.brand,
448
+ * count: sql<number>`cast(count(${cars.id}) as int)`,
449
+ * })
450
+ * .from(cars)
451
+ * .groupBy(cars.brand)
452
+ * .having(({ count }) => gt(count, 1));
453
+ * ```
454
+ */
455
+ having(having) {
456
+ if (typeof having === "function") {
457
+ having = having(
458
+ new Proxy(
459
+ this.config.fields,
460
+ new SelectionProxyHandler({ sqlAliasedBehavior: "sql", sqlBehavior: "sql" })
461
+ )
462
+ );
463
+ }
464
+ this.config.having = having;
465
+ return this;
466
+ }
467
+ groupBy(...columns) {
468
+ if (typeof columns[0] === "function") {
469
+ const groupBy = columns[0](
470
+ new Proxy(
471
+ this.config.fields,
472
+ new SelectionProxyHandler({ sqlAliasedBehavior: "alias", sqlBehavior: "sql" })
473
+ )
474
+ );
475
+ this.config.groupBy = Array.isArray(groupBy) ? groupBy : [groupBy];
476
+ } else {
477
+ this.config.groupBy = columns;
478
+ }
479
+ return this;
480
+ }
481
+ orderBy(...columns) {
482
+ if (typeof columns[0] === "function") {
483
+ const orderBy = columns[0](
484
+ new Proxy(
485
+ this.config.fields,
486
+ new SelectionProxyHandler({ sqlAliasedBehavior: "alias", sqlBehavior: "sql" })
487
+ )
488
+ );
489
+ const orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];
490
+ if (this.config.setOperators.length > 0) {
491
+ this.config.setOperators.at(-1).orderBy = orderByArray;
492
+ } else {
493
+ this.config.orderBy = orderByArray;
494
+ }
495
+ } else {
496
+ const orderByArray = columns;
497
+ if (this.config.setOperators.length > 0) {
498
+ this.config.setOperators.at(-1).orderBy = orderByArray;
499
+ } else {
500
+ this.config.orderBy = orderByArray;
501
+ }
502
+ }
503
+ return this;
504
+ }
505
+ /**
506
+ * Adds an `OFFSET` clause to the query.
507
+ *
508
+ * Calling this method will skip the first N rows of the result set. This is commonly used for pagination, often in combination with `FETCH NEXT` (e.g., `.fetch()`).
509
+ *
510
+ * * ⚠️ **Note:** This method can only be used after calling `.orderBy()`, as SQL Server requires `ORDER BY` to be present with `OFFSET`.
511
+ *
512
+ * @example
513
+ *
514
+ * ```ts
515
+ * // Skip the first 10 results
516
+ * await db.select().from(cars).orderBy(cars.year).offset(10);
517
+ * ```
518
+ *
519
+ * `OFFSET` is zero-based — `offset(0)` will include all rows, while `offset(10)` will skip the first 10.
520
+ *
521
+ * Typically used with `.fetch()` to implement pagination:
522
+ *
523
+ * ```ts
524
+ * // Get 10 cars, skipping the first 20
525
+ * await db.select().from(cars).orderBy(cars.year).offset(20).fetch(10);
526
+ * ```
527
+ *
528
+ * @param offset The number of rows to skip
529
+ */
530
+ offset(offset) {
531
+ if (this.config.setOperators.length > 0) {
532
+ this.config.setOperators.at(-1).offset = offset;
533
+ } else {
534
+ this.config.offset = offset;
535
+ }
536
+ return this;
537
+ }
538
+ /**
539
+ * Adds a `FETCH NEXT` clause to the query (commonly known as `LIMIT`).
540
+ *
541
+ * Limits the number of rows returned — used after `.offset()`.
542
+ *
543
+ * @example
544
+ * ```ts
545
+ * // Get only 10 rows, skipping 5 rows
546
+ * await db.select().from(cars).orderBy(cars.year).offset(5).fetch(10);
547
+ * ```
548
+ *
549
+ * @example
550
+ * ```ts
551
+ * // Pagination: skip 20 cars, then fetch 10
552
+ * await db.select().from(cars).orderBy(cars.year).offset(20).fetch(10);
553
+ * ```
554
+ *
555
+ * @param fetch The number of rows to fetch
556
+ */
557
+ fetch(fetch) {
558
+ if (this.config.setOperators.length > 0) {
559
+ this.config.setOperators.at(-1).fetch = fetch;
560
+ } else {
561
+ this.config.fetch = fetch;
562
+ }
563
+ return this;
564
+ }
565
+ /** @internal */
566
+ getSQL() {
567
+ return this.dialect.buildSelectQuery(this.config);
568
+ }
569
+ toSQL() {
570
+ const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());
571
+ return rest;
572
+ }
573
+ as(alias) {
574
+ return new Proxy(
575
+ new Subquery(this.getSQL(), this.config.fields, alias),
576
+ new SelectionProxyHandler({ alias, sqlAliasedBehavior: "alias", sqlBehavior: "error" })
577
+ );
578
+ }
579
+ /** @internal */
580
+ getSelectedFields() {
581
+ return new Proxy(
582
+ this.config.fields,
583
+ new SelectionProxyHandler({ alias: this.tableName, sqlAliasedBehavior: "alias", sqlBehavior: "error" })
584
+ );
585
+ }
586
+ $dynamic() {
587
+ return this;
588
+ }
589
+ }
590
+ class MsSqlSelectBase extends MsSqlSelectQueryBuilderBase {
591
+ static [entityKind] = "MsSqlSelect";
592
+ prepare() {
593
+ if (!this.session) {
594
+ throw new Error("Cannot execute a query on a query builder. Please use a database instance instead.");
595
+ }
596
+ const fieldsList = orderSelectedFields(this.config.fields);
597
+ const query = this.session.prepareQuery(this.dialect.sqlToQuery(this.getSQL()), fieldsList);
598
+ query.joinsNotNullableMap = this.joinsNotNullableMap;
599
+ return query;
600
+ }
601
+ execute = (placeholderValues) => {
602
+ return this.prepare().execute(placeholderValues);
603
+ };
604
+ createIterator = () => {
605
+ const self = this;
606
+ return async function* (placeholderValues) {
607
+ yield* self.prepare().iterator(placeholderValues);
608
+ };
609
+ };
610
+ iterator = this.createIterator();
611
+ }
612
+ applyMixins(MsSqlSelectBase, [QueryPromise]);
613
+ function createSetOperator(type, isAll) {
614
+ return (leftSelect, rightSelect, ...restSelects) => {
615
+ const setOperators = [rightSelect, ...restSelects].map((select) => ({
616
+ type,
617
+ isAll,
618
+ rightSelect: select
619
+ }));
620
+ for (const setOperator of setOperators) {
621
+ if (!haveSameKeys(leftSelect.getSelectedFields(), setOperator.rightSelect.getSelectedFields())) {
622
+ throw new Error(
623
+ "Set operator error (union / intersect / except): selected fields are not the same or are in a different order"
624
+ );
625
+ }
626
+ }
627
+ return leftSelect.addSetOperators(setOperators);
628
+ };
629
+ }
630
+ const getMsSqlSetOperators = () => ({
631
+ union,
632
+ unionAll,
633
+ intersect,
634
+ except
635
+ });
636
+ const union = createSetOperator("union", false);
637
+ const unionAll = createSetOperator("union", true);
638
+ const intersect = createSetOperator("intersect", false);
639
+ const except = createSetOperator("except", false);
640
+ export {
641
+ MsSqlSelectBase,
642
+ MsSqlSelectBuilder,
643
+ MsSqlSelectQueryBuilderBase,
644
+ except,
645
+ intersect,
646
+ union,
647
+ unionAll
648
+ };
649
+ //# sourceMappingURL=select.js.map