drizzle-orm 1.0.0-beta.1-7722e6a → 1.0.0-beta.2-e93475f

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 (1777) hide show
  1. package/_relations.cjs +50 -6
  2. package/_relations.cjs.map +1 -1
  3. package/_relations.d.cts +1 -0
  4. package/_relations.d.ts +1 -0
  5. package/_relations.js +49 -6
  6. package/_relations.js.map +1 -1
  7. package/alias.cjs +56 -8
  8. package/alias.cjs.map +1 -1
  9. package/alias.d.cts +13 -3
  10. package/alias.d.ts +13 -3
  11. package/alias.js +53 -8
  12. package/alias.js.map +1 -1
  13. package/aws-data-api/common/index.cjs +18 -9
  14. package/aws-data-api/common/index.cjs.map +1 -1
  15. package/aws-data-api/common/index.d.cts +4 -1
  16. package/aws-data-api/common/index.d.ts +4 -1
  17. package/aws-data-api/common/index.js +17 -9
  18. package/aws-data-api/common/index.js.map +1 -1
  19. package/aws-data-api/pg/driver.cjs +0 -3
  20. package/aws-data-api/pg/driver.cjs.map +1 -1
  21. package/aws-data-api/pg/driver.d.cts +0 -3
  22. package/aws-data-api/pg/driver.d.ts +0 -3
  23. package/aws-data-api/pg/driver.js +0 -3
  24. package/aws-data-api/pg/driver.js.map +1 -1
  25. package/better-sqlite3/driver.cjs +10 -14
  26. package/better-sqlite3/driver.cjs.map +1 -1
  27. package/better-sqlite3/driver.d.cts +3 -3
  28. package/better-sqlite3/driver.d.ts +3 -3
  29. package/better-sqlite3/driver.js +10 -14
  30. package/better-sqlite3/driver.js.map +1 -1
  31. package/bun-sql/driver.cjs.map +1 -1
  32. package/bun-sql/driver.d.cts +8 -8
  33. package/bun-sql/driver.d.ts +8 -8
  34. package/bun-sql/driver.js.map +1 -1
  35. package/bun-sql/mysql/driver.cjs +10 -14
  36. package/bun-sql/mysql/driver.cjs.map +1 -1
  37. package/bun-sql/mysql/driver.d.cts +3 -3
  38. package/bun-sql/mysql/driver.d.ts +3 -3
  39. package/bun-sql/mysql/driver.js +10 -14
  40. package/bun-sql/mysql/driver.js.map +1 -1
  41. package/bun-sql/postgres/driver.cjs +10 -14
  42. package/bun-sql/postgres/driver.cjs.map +1 -1
  43. package/bun-sql/postgres/driver.d.cts +3 -3
  44. package/bun-sql/postgres/driver.d.ts +3 -3
  45. package/bun-sql/postgres/driver.js +10 -14
  46. package/bun-sql/postgres/driver.js.map +1 -1
  47. package/bun-sql/sqlite/driver.cjs +10 -14
  48. package/bun-sql/sqlite/driver.cjs.map +1 -1
  49. package/bun-sql/sqlite/driver.d.cts +3 -3
  50. package/bun-sql/sqlite/driver.d.ts +3 -3
  51. package/bun-sql/sqlite/driver.js +10 -14
  52. package/bun-sql/sqlite/driver.js.map +1 -1
  53. package/bun-sql/sqlite/session.cjs +0 -2
  54. package/bun-sql/sqlite/session.cjs.map +1 -1
  55. package/bun-sql/sqlite/session.js +0 -2
  56. package/bun-sql/sqlite/session.js.map +1 -1
  57. package/bun-sqlite/driver.cjs +11 -15
  58. package/bun-sqlite/driver.cjs.map +1 -1
  59. package/bun-sqlite/driver.d.cts +3 -3
  60. package/bun-sqlite/driver.d.ts +3 -3
  61. package/bun-sqlite/driver.js +11 -15
  62. package/bun-sqlite/driver.js.map +1 -1
  63. package/cockroach/driver.cjs +109 -0
  64. package/cockroach/driver.cjs.map +1 -0
  65. package/cockroach/driver.d.cts +42 -0
  66. package/cockroach/driver.d.ts +42 -0
  67. package/cockroach/driver.js +73 -0
  68. package/cockroach/driver.js.map +1 -0
  69. package/cockroach/index.cjs +25 -0
  70. package/cockroach/index.cjs.map +1 -0
  71. package/cockroach/index.d.cts +2 -0
  72. package/cockroach/index.d.ts +2 -0
  73. package/cockroach/index.js +3 -0
  74. package/cockroach/index.js.map +1 -0
  75. package/cockroach/migrator.cjs +33 -0
  76. package/cockroach/migrator.cjs.map +1 -0
  77. package/cockroach/migrator.d.cts +3 -0
  78. package/cockroach/migrator.d.ts +3 -0
  79. package/cockroach/migrator.js +9 -0
  80. package/cockroach/migrator.js.map +1 -0
  81. package/cockroach/session.cjs +253 -0
  82. package/cockroach/session.cjs.map +1 -0
  83. package/cockroach/session.d.cts +48 -0
  84. package/cockroach/session.d.ts +48 -0
  85. package/cockroach/session.js +217 -0
  86. package/cockroach/session.js.map +1 -0
  87. package/cockroach-core/alias.cjs +32 -0
  88. package/cockroach-core/alias.cjs.map +1 -0
  89. package/cockroach-core/alias.d.cts +4 -0
  90. package/cockroach-core/alias.d.ts +4 -0
  91. package/cockroach-core/alias.js +8 -0
  92. package/cockroach-core/alias.js.map +1 -0
  93. package/cockroach-core/checks.cjs +58 -0
  94. package/cockroach-core/checks.cjs.map +1 -0
  95. package/cockroach-core/checks.d.cts +18 -0
  96. package/cockroach-core/checks.d.ts +18 -0
  97. package/cockroach-core/checks.js +32 -0
  98. package/cockroach-core/checks.js.map +1 -0
  99. package/cockroach-core/columns/all.cjs +81 -0
  100. package/cockroach-core/columns/all.cjs.map +1 -0
  101. package/cockroach-core/columns/all.d.cts +52 -0
  102. package/cockroach-core/columns/all.d.ts +52 -0
  103. package/cockroach-core/columns/all.js +57 -0
  104. package/cockroach-core/columns/all.js.map +1 -0
  105. package/cockroach-core/columns/bigint.cjs +104 -0
  106. package/cockroach-core/columns/bigint.cjs.map +1 -0
  107. package/cockroach-core/columns/bigint.d.cts +37 -0
  108. package/cockroach-core/columns/bigint.d.ts +37 -0
  109. package/cockroach-core/columns/bigint.js +75 -0
  110. package/cockroach-core/columns/bigint.js.map +1 -0
  111. package/cockroach-core/columns/bit.cjs +61 -0
  112. package/cockroach-core/columns/bit.cjs.map +1 -0
  113. package/cockroach-core/columns/bit.d.cts +29 -0
  114. package/cockroach-core/columns/bit.d.ts +29 -0
  115. package/cockroach-core/columns/bit.js +35 -0
  116. package/cockroach-core/columns/bit.js.map +1 -0
  117. package/cockroach-core/columns/bool.cjs +59 -0
  118. package/cockroach-core/columns/bool.cjs.map +1 -0
  119. package/cockroach-core/columns/bool.d.cts +17 -0
  120. package/cockroach-core/columns/bool.d.ts +17 -0
  121. package/cockroach-core/columns/bool.js +32 -0
  122. package/cockroach-core/columns/bool.js.map +1 -0
  123. package/cockroach-core/columns/char.cjs +62 -0
  124. package/cockroach-core/columns/char.cjs.map +1 -0
  125. package/cockroach-core/columns/char.d.cts +31 -0
  126. package/cockroach-core/columns/char.d.ts +31 -0
  127. package/cockroach-core/columns/char.js +36 -0
  128. package/cockroach-core/columns/char.js.map +1 -0
  129. package/cockroach-core/columns/common.cjs +198 -0
  130. package/cockroach-core/columns/common.cjs.map +1 -0
  131. package/cockroach-core/columns/common.d.cts +98 -0
  132. package/cockroach-core/columns/common.d.ts +98 -0
  133. package/cockroach-core/columns/common.js +168 -0
  134. package/cockroach-core/columns/common.js.map +1 -0
  135. package/cockroach-core/columns/custom.cjs +102 -0
  136. package/cockroach-core/columns/custom.cjs.map +1 -0
  137. package/cockroach-core/columns/custom.d.cts +261 -0
  138. package/cockroach-core/columns/custom.d.ts +261 -0
  139. package/cockroach-core/columns/custom.js +76 -0
  140. package/cockroach-core/columns/custom.js.map +1 -0
  141. package/cockroach-core/columns/date.cjs +91 -0
  142. package/cockroach-core/columns/date.cjs.map +1 -0
  143. package/cockroach-core/columns/date.common.cjs +37 -0
  144. package/cockroach-core/columns/date.common.cjs.map +1 -0
  145. package/cockroach-core/columns/date.common.d.cts +7 -0
  146. package/cockroach-core/columns/date.common.d.ts +7 -0
  147. package/cockroach-core/columns/date.common.js +13 -0
  148. package/cockroach-core/columns/date.common.js.map +1 -0
  149. package/cockroach-core/columns/date.d.cts +36 -0
  150. package/cockroach-core/columns/date.d.ts +36 -0
  151. package/cockroach-core/columns/date.js +63 -0
  152. package/cockroach-core/columns/date.js.map +1 -0
  153. package/cockroach-core/columns/decimal.cjs +164 -0
  154. package/cockroach-core/columns/decimal.cjs.map +1 -0
  155. package/cockroach-core/columns/decimal.d.cts +80 -0
  156. package/cockroach-core/columns/decimal.d.ts +80 -0
  157. package/cockroach-core/columns/decimal.js +133 -0
  158. package/cockroach-core/columns/decimal.js.map +1 -0
  159. package/cockroach-core/columns/enum.cjs +127 -0
  160. package/cockroach-core/columns/enum.cjs.map +1 -0
  161. package/cockroach-core/columns/enum.d.cts +64 -0
  162. package/cockroach-core/columns/enum.d.ts +64 -0
  163. package/cockroach-core/columns/enum.js +96 -0
  164. package/cockroach-core/columns/enum.js.map +1 -0
  165. package/cockroach-core/columns/float.cjs +65 -0
  166. package/cockroach-core/columns/float.cjs.map +1 -0
  167. package/cockroach-core/columns/float.d.cts +18 -0
  168. package/cockroach-core/columns/float.d.ts +18 -0
  169. package/cockroach-core/columns/float.js +38 -0
  170. package/cockroach-core/columns/float.js.map +1 -0
  171. package/cockroach-core/columns/geometry.cjs +105 -0
  172. package/cockroach-core/columns/geometry.cjs.map +1 -0
  173. package/cockroach-core/columns/geometry.d.cts +60 -0
  174. package/cockroach-core/columns/geometry.d.ts +60 -0
  175. package/cockroach-core/columns/geometry.js +77 -0
  176. package/cockroach-core/columns/geometry.js.map +1 -0
  177. package/cockroach-core/columns/index.cjs +71 -0
  178. package/cockroach-core/columns/index.cjs.map +1 -0
  179. package/cockroach-core/columns/index.d.cts +25 -0
  180. package/cockroach-core/columns/index.d.ts +25 -0
  181. package/cockroach-core/columns/index.js +26 -0
  182. package/cockroach-core/columns/index.js.map +1 -0
  183. package/cockroach-core/columns/inet.cjs +56 -0
  184. package/cockroach-core/columns/inet.cjs.map +1 -0
  185. package/cockroach-core/columns/inet.d.cts +16 -0
  186. package/cockroach-core/columns/inet.d.ts +16 -0
  187. package/cockroach-core/columns/inet.js +30 -0
  188. package/cockroach-core/columns/inet.js.map +1 -0
  189. package/cockroach-core/columns/int.common.cjs +55 -0
  190. package/cockroach-core/columns/int.common.cjs.map +1 -0
  191. package/cockroach-core/columns/int.common.d.cts +11 -0
  192. package/cockroach-core/columns/int.common.d.ts +11 -0
  193. package/cockroach-core/columns/int.common.js +31 -0
  194. package/cockroach-core/columns/int.common.js.map +1 -0
  195. package/cockroach-core/columns/integer.cjs +63 -0
  196. package/cockroach-core/columns/integer.cjs.map +1 -0
  197. package/cockroach-core/columns/integer.d.cts +18 -0
  198. package/cockroach-core/columns/integer.d.ts +18 -0
  199. package/cockroach-core/columns/integer.js +37 -0
  200. package/cockroach-core/columns/integer.js.map +1 -0
  201. package/cockroach-core/columns/interval.cjs +63 -0
  202. package/cockroach-core/columns/interval.cjs.map +1 -0
  203. package/cockroach-core/columns/interval.d.cts +28 -0
  204. package/cockroach-core/columns/interval.d.ts +28 -0
  205. package/cockroach-core/columns/interval.js +37 -0
  206. package/cockroach-core/columns/interval.js.map +1 -0
  207. package/cockroach-core/columns/jsonb.cjs +72 -0
  208. package/cockroach-core/columns/jsonb.cjs.map +1 -0
  209. package/cockroach-core/columns/jsonb.d.cts +20 -0
  210. package/cockroach-core/columns/jsonb.d.ts +20 -0
  211. package/cockroach-core/columns/jsonb.js +46 -0
  212. package/cockroach-core/columns/jsonb.js.map +1 -0
  213. package/cockroach-core/columns/real.cjs +66 -0
  214. package/cockroach-core/columns/real.cjs.map +1 -0
  215. package/cockroach-core/columns/real.d.cts +21 -0
  216. package/cockroach-core/columns/real.d.ts +21 -0
  217. package/cockroach-core/columns/real.js +40 -0
  218. package/cockroach-core/columns/real.js.map +1 -0
  219. package/cockroach-core/columns/smallint.cjs +68 -0
  220. package/cockroach-core/columns/smallint.cjs.map +1 -0
  221. package/cockroach-core/columns/smallint.d.cts +19 -0
  222. package/cockroach-core/columns/smallint.d.ts +19 -0
  223. package/cockroach-core/columns/smallint.js +41 -0
  224. package/cockroach-core/columns/smallint.js.map +1 -0
  225. package/cockroach-core/columns/string.cjs +67 -0
  226. package/cockroach-core/columns/string.cjs.map +1 -0
  227. package/cockroach-core/columns/string.d.cts +36 -0
  228. package/cockroach-core/columns/string.d.ts +36 -0
  229. package/cockroach-core/columns/string.js +40 -0
  230. package/cockroach-core/columns/string.js.map +1 -0
  231. package/cockroach-core/columns/time.cjs +70 -0
  232. package/cockroach-core/columns/time.cjs.map +1 -0
  233. package/cockroach-core/columns/time.d.cts +31 -0
  234. package/cockroach-core/columns/time.d.ts +31 -0
  235. package/cockroach-core/columns/time.js +44 -0
  236. package/cockroach-core/columns/time.js.map +1 -0
  237. package/cockroach-core/columns/timestamp.cjs +111 -0
  238. package/cockroach-core/columns/timestamp.cjs.map +1 -0
  239. package/cockroach-core/columns/timestamp.d.cts +52 -0
  240. package/cockroach-core/columns/timestamp.d.ts +52 -0
  241. package/cockroach-core/columns/timestamp.js +83 -0
  242. package/cockroach-core/columns/timestamp.js.map +1 -0
  243. package/cockroach-core/columns/utils.cjs +65 -0
  244. package/cockroach-core/columns/utils.cjs.map +1 -0
  245. package/cockroach-core/columns/utils.d.cts +4 -0
  246. package/cockroach-core/columns/utils.d.ts +4 -0
  247. package/cockroach-core/columns/utils.js +41 -0
  248. package/cockroach-core/columns/utils.js.map +1 -0
  249. package/cockroach-core/columns/uuid.cjs +63 -0
  250. package/cockroach-core/columns/uuid.cjs.map +1 -0
  251. package/cockroach-core/columns/uuid.d.cts +20 -0
  252. package/cockroach-core/columns/uuid.d.ts +20 -0
  253. package/cockroach-core/columns/uuid.js +37 -0
  254. package/cockroach-core/columns/uuid.js.map +1 -0
  255. package/cockroach-core/columns/varbit.cjs +59 -0
  256. package/cockroach-core/columns/varbit.cjs.map +1 -0
  257. package/cockroach-core/columns/varbit.d.cts +24 -0
  258. package/cockroach-core/columns/varbit.d.ts +24 -0
  259. package/cockroach-core/columns/varbit.js +33 -0
  260. package/cockroach-core/columns/varbit.js.map +1 -0
  261. package/cockroach-core/columns/varchar.cjs +61 -0
  262. package/cockroach-core/columns/varchar.cjs.map +1 -0
  263. package/cockroach-core/columns/varchar.d.cts +30 -0
  264. package/cockroach-core/columns/varchar.d.ts +30 -0
  265. package/cockroach-core/columns/varchar.js +35 -0
  266. package/cockroach-core/columns/varchar.js.map +1 -0
  267. package/cockroach-core/columns/vector.cjs +65 -0
  268. package/cockroach-core/columns/vector.cjs.map +1 -0
  269. package/cockroach-core/columns/vector.d.cts +26 -0
  270. package/cockroach-core/columns/vector.d.ts +26 -0
  271. package/cockroach-core/columns/vector.js +39 -0
  272. package/cockroach-core/columns/vector.js.map +1 -0
  273. package/cockroach-core/db.cjs +347 -0
  274. package/cockroach-core/db.cjs.map +1 -0
  275. package/cockroach-core/db.d.cts +282 -0
  276. package/cockroach-core/db.d.ts +282 -0
  277. package/cockroach-core/db.js +328 -0
  278. package/cockroach-core/db.js.map +1 -0
  279. package/cockroach-core/dialect.cjs +1155 -0
  280. package/cockroach-core/dialect.cjs.map +1 -0
  281. package/cockroach-core/dialect.d.cts +64 -0
  282. package/cockroach-core/dialect.d.ts +64 -0
  283. package/cockroach-core/dialect.js +1127 -0
  284. package/cockroach-core/dialect.js.map +1 -0
  285. package/cockroach-core/expressions.cjs +49 -0
  286. package/cockroach-core/expressions.cjs.map +1 -0
  287. package/cockroach-core/expressions.d.cts +8 -0
  288. package/cockroach-core/expressions.d.ts +8 -0
  289. package/cockroach-core/expressions.js +22 -0
  290. package/cockroach-core/expressions.js.map +1 -0
  291. package/cockroach-core/foreign-keys.cjs +95 -0
  292. package/cockroach-core/foreign-keys.cjs.map +1 -0
  293. package/cockroach-core/foreign-keys.d.cts +53 -0
  294. package/cockroach-core/foreign-keys.d.ts +53 -0
  295. package/cockroach-core/foreign-keys.js +69 -0
  296. package/cockroach-core/foreign-keys.js.map +1 -0
  297. package/cockroach-core/index.cjs +61 -0
  298. package/cockroach-core/index.cjs.map +1 -0
  299. package/cockroach-core/index.d.cts +20 -0
  300. package/cockroach-core/index.d.ts +20 -0
  301. package/cockroach-core/index.js +21 -0
  302. package/cockroach-core/index.js.map +1 -0
  303. package/cockroach-core/indexes.cjs +139 -0
  304. package/cockroach-core/indexes.cjs.map +1 -0
  305. package/cockroach-core/indexes.d.cts +65 -0
  306. package/cockroach-core/indexes.d.ts +65 -0
  307. package/cockroach-core/indexes.js +111 -0
  308. package/cockroach-core/indexes.js.map +1 -0
  309. package/cockroach-core/policies.cjs +58 -0
  310. package/cockroach-core/policies.cjs.map +1 -0
  311. package/cockroach-core/policies.d.cts +24 -0
  312. package/cockroach-core/policies.d.ts +24 -0
  313. package/cockroach-core/policies.js +33 -0
  314. package/cockroach-core/policies.js.map +1 -0
  315. package/cockroach-core/primary-keys.cjs +66 -0
  316. package/cockroach-core/primary-keys.cjs.map +1 -0
  317. package/cockroach-core/primary-keys.d.cts +24 -0
  318. package/cockroach-core/primary-keys.d.ts +24 -0
  319. package/cockroach-core/primary-keys.js +40 -0
  320. package/cockroach-core/primary-keys.js.map +1 -0
  321. package/cockroach-core/query-builders/count.cjs +79 -0
  322. package/cockroach-core/query-builders/count.cjs.map +1 -0
  323. package/cockroach-core/query-builders/count.d.cts +30 -0
  324. package/cockroach-core/query-builders/count.d.ts +30 -0
  325. package/cockroach-core/query-builders/count.js +55 -0
  326. package/cockroach-core/query-builders/count.js.map +1 -0
  327. package/cockroach-core/query-builders/delete.cjs +124 -0
  328. package/cockroach-core/query-builders/delete.cjs.map +1 -0
  329. package/cockroach-core/query-builders/delete.d.cts +103 -0
  330. package/cockroach-core/query-builders/delete.d.ts +103 -0
  331. package/cockroach-core/query-builders/delete.js +100 -0
  332. package/cockroach-core/query-builders/delete.js.map +1 -0
  333. package/cockroach-core/query-builders/index.cjs +35 -0
  334. package/cockroach-core/query-builders/index.cjs.map +1 -0
  335. package/cockroach-core/query-builders/index.d.cts +7 -0
  336. package/cockroach-core/query-builders/index.d.ts +7 -0
  337. package/cockroach-core/query-builders/index.js +8 -0
  338. package/cockroach-core/query-builders/index.js.map +1 -0
  339. package/cockroach-core/query-builders/insert.cjs +213 -0
  340. package/cockroach-core/query-builders/insert.cjs.map +1 -0
  341. package/cockroach-core/query-builders/insert.d.cts +168 -0
  342. package/cockroach-core/query-builders/insert.d.ts +168 -0
  343. package/cockroach-core/query-builders/insert.js +188 -0
  344. package/cockroach-core/query-builders/insert.js.map +1 -0
  345. package/cockroach-core/query-builders/query-builder.cjs +118 -0
  346. package/cockroach-core/query-builders/query-builder.cjs.map +1 -0
  347. package/cockroach-core/query-builders/query-builder.d.cts +37 -0
  348. package/cockroach-core/query-builders/query-builder.d.ts +37 -0
  349. package/cockroach-core/query-builders/query-builder.js +94 -0
  350. package/cockroach-core/query-builders/query-builder.js.map +1 -0
  351. package/cockroach-core/query-builders/query.cjs +145 -0
  352. package/cockroach-core/query-builders/query.cjs.map +1 -0
  353. package/cockroach-core/query-builders/query.d.cts +47 -0
  354. package/cockroach-core/query-builders/query.d.ts +47 -0
  355. package/cockroach-core/query-builders/query.js +122 -0
  356. package/cockroach-core/query-builders/query.js.map +1 -0
  357. package/cockroach-core/query-builders/raw.cjs +57 -0
  358. package/cockroach-core/query-builders/raw.cjs.map +1 -0
  359. package/cockroach-core/query-builders/raw.d.cts +22 -0
  360. package/cockroach-core/query-builders/raw.d.ts +22 -0
  361. package/cockroach-core/query-builders/raw.js +33 -0
  362. package/cockroach-core/query-builders/raw.js.map +1 -0
  363. package/cockroach-core/query-builders/refresh-materialized-view.cjs +83 -0
  364. package/cockroach-core/query-builders/refresh-materialized-view.cjs.map +1 -0
  365. package/cockroach-core/query-builders/refresh-materialized-view.d.cts +28 -0
  366. package/cockroach-core/query-builders/refresh-materialized-view.d.ts +28 -0
  367. package/cockroach-core/query-builders/refresh-materialized-view.js +59 -0
  368. package/cockroach-core/query-builders/refresh-materialized-view.js.map +1 -0
  369. package/cockroach-core/query-builders/select.cjs +847 -0
  370. package/cockroach-core/query-builders/select.cjs.map +1 -0
  371. package/cockroach-core/query-builders/select.d.cts +787 -0
  372. package/cockroach-core/query-builders/select.d.ts +787 -0
  373. package/cockroach-core/query-builders/select.js +821 -0
  374. package/cockroach-core/query-builders/select.js.map +1 -0
  375. package/cockroach-core/query-builders/select.types.cjs +17 -0
  376. package/cockroach-core/query-builders/select.types.cjs.map +1 -0
  377. package/cockroach-core/query-builders/select.types.d.cts +140 -0
  378. package/cockroach-core/query-builders/select.types.d.ts +140 -0
  379. package/cockroach-core/query-builders/select.types.js +1 -0
  380. package/cockroach-core/query-builders/select.types.js.map +1 -0
  381. package/cockroach-core/query-builders/update.cjs +240 -0
  382. package/cockroach-core/query-builders/update.cjs.map +1 -0
  383. package/cockroach-core/query-builders/update.d.cts +170 -0
  384. package/cockroach-core/query-builders/update.d.ts +170 -0
  385. package/cockroach-core/query-builders/update.js +219 -0
  386. package/cockroach-core/query-builders/update.js.map +1 -0
  387. package/cockroach-core/roles.cjs +54 -0
  388. package/cockroach-core/roles.cjs.map +1 -0
  389. package/cockroach-core/roles.d.cts +12 -0
  390. package/cockroach-core/roles.d.ts +12 -0
  391. package/cockroach-core/roles.js +29 -0
  392. package/cockroach-core/roles.js.map +1 -0
  393. package/cockroach-core/schema.cjs +92 -0
  394. package/cockroach-core/schema.cjs.map +1 -0
  395. package/cockroach-core/schema.d.cts +24 -0
  396. package/cockroach-core/schema.d.ts +24 -0
  397. package/cockroach-core/schema.js +72 -0
  398. package/cockroach-core/schema.js.map +1 -0
  399. package/cockroach-core/sequence.cjs +52 -0
  400. package/cockroach-core/sequence.cjs.map +1 -0
  401. package/cockroach-core/sequence.d.cts +17 -0
  402. package/cockroach-core/sequence.d.ts +17 -0
  403. package/cockroach-core/sequence.js +25 -0
  404. package/cockroach-core/sequence.js.map +1 -0
  405. package/cockroach-core/session.cjs +120 -0
  406. package/cockroach-core/session.cjs.map +1 -0
  407. package/cockroach-core/session.d.cts +62 -0
  408. package/cockroach-core/session.d.ts +62 -0
  409. package/cockroach-core/session.js +94 -0
  410. package/cockroach-core/session.js.map +1 -0
  411. package/cockroach-core/subquery.cjs +17 -0
  412. package/cockroach-core/subquery.cjs.map +1 -0
  413. package/cockroach-core/subquery.d.cts +18 -0
  414. package/cockroach-core/subquery.d.ts +18 -0
  415. package/cockroach-core/subquery.js +1 -0
  416. package/cockroach-core/subquery.js.map +1 -0
  417. package/cockroach-core/table.cjs +121 -0
  418. package/cockroach-core/table.cjs.map +1 -0
  419. package/cockroach-core/table.d.cts +41 -0
  420. package/cockroach-core/table.d.ts +41 -0
  421. package/cockroach-core/table.js +94 -0
  422. package/cockroach-core/table.js.map +1 -0
  423. package/cockroach-core/unique-constraint.cjs +77 -0
  424. package/cockroach-core/unique-constraint.cjs.map +1 -0
  425. package/cockroach-core/unique-constraint.d.cts +23 -0
  426. package/cockroach-core/unique-constraint.d.ts +23 -0
  427. package/cockroach-core/unique-constraint.js +50 -0
  428. package/cockroach-core/unique-constraint.js.map +1 -0
  429. package/cockroach-core/utils/array.cjs +106 -0
  430. package/cockroach-core/utils/array.cjs.map +1 -0
  431. package/cockroach-core/utils/array.d.cts +3 -0
  432. package/cockroach-core/utils/array.d.ts +3 -0
  433. package/cockroach-core/utils/array.js +80 -0
  434. package/cockroach-core/utils/array.js.map +1 -0
  435. package/cockroach-core/utils/index.cjs +23 -0
  436. package/cockroach-core/utils/index.cjs.map +1 -0
  437. package/cockroach-core/utils/index.d.cts +1 -0
  438. package/cockroach-core/utils/index.d.ts +1 -0
  439. package/cockroach-core/utils/index.js +2 -0
  440. package/cockroach-core/utils/index.js.map +1 -0
  441. package/cockroach-core/utils.cjs +98 -0
  442. package/cockroach-core/utils.cjs.map +1 -0
  443. package/cockroach-core/utils.d.cts +47 -0
  444. package/cockroach-core/utils.d.ts +47 -0
  445. package/cockroach-core/utils.js +72 -0
  446. package/cockroach-core/utils.js.map +1 -0
  447. package/cockroach-core/view-base.cjs +33 -0
  448. package/cockroach-core/view-base.cjs.map +1 -0
  449. package/cockroach-core/view-base.d.cts +8 -0
  450. package/cockroach-core/view-base.d.ts +8 -0
  451. package/cockroach-core/view-base.js +9 -0
  452. package/cockroach-core/view-base.js.map +1 -0
  453. package/cockroach-core/view.cjs +271 -0
  454. package/cockroach-core/view.cjs.map +1 -0
  455. package/cockroach-core/view.d.cts +106 -0
  456. package/cockroach-core/view.d.ts +106 -0
  457. package/cockroach-core/view.js +233 -0
  458. package/cockroach-core/view.js.map +1 -0
  459. package/column-builder.cjs.map +1 -1
  460. package/column-builder.d.cts +9 -8
  461. package/column-builder.d.ts +9 -8
  462. package/column-builder.js.map +1 -1
  463. package/column-common.cjs +29 -0
  464. package/column-common.cjs.map +1 -0
  465. package/column-common.d.cts +1 -0
  466. package/column-common.d.ts +1 -0
  467. package/column-common.js +5 -0
  468. package/column-common.js.map +1 -0
  469. package/column.cjs +7 -0
  470. package/column.cjs.map +1 -1
  471. package/column.d.cts +2 -0
  472. package/column.d.ts +2 -0
  473. package/column.js +7 -0
  474. package/column.js.map +1 -1
  475. package/durable-sqlite/migrator.cjs +10 -7
  476. package/durable-sqlite/migrator.cjs.map +1 -1
  477. package/durable-sqlite/migrator.d.cts +1 -9
  478. package/durable-sqlite/migrator.d.ts +1 -9
  479. package/durable-sqlite/migrator.js +10 -7
  480. package/durable-sqlite/migrator.js.map +1 -1
  481. package/durable-sqlite/session.cjs +6 -3
  482. package/durable-sqlite/session.cjs.map +1 -1
  483. package/durable-sqlite/session.d.cts +1 -2
  484. package/durable-sqlite/session.d.ts +1 -2
  485. package/durable-sqlite/session.js +6 -2
  486. package/durable-sqlite/session.js.map +1 -1
  487. package/entity.cjs.map +1 -1
  488. package/entity.js.map +1 -1
  489. package/expo-sqlite/migrator.cjs +10 -7
  490. package/expo-sqlite/migrator.cjs.map +1 -1
  491. package/expo-sqlite/migrator.d.cts +0 -8
  492. package/expo-sqlite/migrator.d.ts +0 -8
  493. package/expo-sqlite/migrator.js +10 -7
  494. package/expo-sqlite/migrator.js.map +1 -1
  495. package/gel/driver.cjs +6 -10
  496. package/gel/driver.cjs.map +1 -1
  497. package/gel/driver.d.cts +2 -2
  498. package/gel/driver.d.ts +2 -2
  499. package/gel/driver.js +6 -10
  500. package/gel/driver.js.map +1 -1
  501. package/gel-core/columns/bigint.cjs.map +1 -1
  502. package/gel-core/columns/bigint.d.cts +0 -1
  503. package/gel-core/columns/bigint.d.ts +0 -1
  504. package/gel-core/columns/bigint.js.map +1 -1
  505. package/gel-core/columns/bigintT.cjs.map +1 -1
  506. package/gel-core/columns/bigintT.d.cts +0 -1
  507. package/gel-core/columns/bigintT.d.ts +0 -1
  508. package/gel-core/columns/bigintT.js.map +1 -1
  509. package/gel-core/columns/boolean.cjs.map +1 -1
  510. package/gel-core/columns/boolean.d.cts +0 -1
  511. package/gel-core/columns/boolean.d.ts +0 -1
  512. package/gel-core/columns/boolean.js.map +1 -1
  513. package/gel-core/columns/bytes.cjs.map +1 -1
  514. package/gel-core/columns/bytes.d.cts +0 -1
  515. package/gel-core/columns/bytes.d.ts +0 -1
  516. package/gel-core/columns/bytes.js.map +1 -1
  517. package/gel-core/columns/common.cjs +0 -4
  518. package/gel-core/columns/common.cjs.map +1 -1
  519. package/gel-core/columns/common.d.cts +1 -1
  520. package/gel-core/columns/common.d.ts +1 -1
  521. package/gel-core/columns/common.js +0 -4
  522. package/gel-core/columns/common.js.map +1 -1
  523. package/gel-core/columns/custom.cjs.map +1 -1
  524. package/gel-core/columns/custom.d.cts +0 -1
  525. package/gel-core/columns/custom.d.ts +0 -1
  526. package/gel-core/columns/custom.js.map +1 -1
  527. package/gel-core/columns/date-duration.cjs.map +1 -1
  528. package/gel-core/columns/date-duration.d.cts +0 -1
  529. package/gel-core/columns/date-duration.d.ts +0 -1
  530. package/gel-core/columns/date-duration.js.map +1 -1
  531. package/gel-core/columns/decimal.cjs.map +1 -1
  532. package/gel-core/columns/decimal.d.cts +0 -1
  533. package/gel-core/columns/decimal.d.ts +0 -1
  534. package/gel-core/columns/decimal.js.map +1 -1
  535. package/gel-core/columns/double-precision.cjs.map +1 -1
  536. package/gel-core/columns/double-precision.d.cts +0 -1
  537. package/gel-core/columns/double-precision.d.ts +0 -1
  538. package/gel-core/columns/double-precision.js.map +1 -1
  539. package/gel-core/columns/duration.cjs.map +1 -1
  540. package/gel-core/columns/duration.d.cts +0 -1
  541. package/gel-core/columns/duration.d.ts +0 -1
  542. package/gel-core/columns/duration.js.map +1 -1
  543. package/gel-core/columns/integer.cjs.map +1 -1
  544. package/gel-core/columns/integer.d.cts +0 -1
  545. package/gel-core/columns/integer.d.ts +0 -1
  546. package/gel-core/columns/integer.js.map +1 -1
  547. package/gel-core/columns/json.cjs.map +1 -1
  548. package/gel-core/columns/json.d.cts +0 -1
  549. package/gel-core/columns/json.d.ts +0 -1
  550. package/gel-core/columns/json.js.map +1 -1
  551. package/gel-core/columns/localdate.cjs.map +1 -1
  552. package/gel-core/columns/localdate.d.cts +0 -1
  553. package/gel-core/columns/localdate.d.ts +0 -1
  554. package/gel-core/columns/localdate.js.map +1 -1
  555. package/gel-core/columns/localtime.cjs.map +1 -1
  556. package/gel-core/columns/localtime.d.cts +0 -1
  557. package/gel-core/columns/localtime.d.ts +0 -1
  558. package/gel-core/columns/localtime.js.map +1 -1
  559. package/gel-core/columns/real.cjs.map +1 -1
  560. package/gel-core/columns/real.d.cts +0 -1
  561. package/gel-core/columns/real.d.ts +0 -1
  562. package/gel-core/columns/real.js.map +1 -1
  563. package/gel-core/columns/relative-duration.cjs.map +1 -1
  564. package/gel-core/columns/relative-duration.d.cts +0 -1
  565. package/gel-core/columns/relative-duration.d.ts +0 -1
  566. package/gel-core/columns/relative-duration.js.map +1 -1
  567. package/gel-core/columns/smallint.cjs.map +1 -1
  568. package/gel-core/columns/smallint.d.cts +0 -1
  569. package/gel-core/columns/smallint.d.ts +0 -1
  570. package/gel-core/columns/smallint.js.map +1 -1
  571. package/gel-core/columns/text.cjs.map +1 -1
  572. package/gel-core/columns/text.d.cts +0 -1
  573. package/gel-core/columns/text.d.ts +0 -1
  574. package/gel-core/columns/text.js.map +1 -1
  575. package/gel-core/columns/timestamp.cjs.map +1 -1
  576. package/gel-core/columns/timestamp.d.cts +0 -1
  577. package/gel-core/columns/timestamp.d.ts +0 -1
  578. package/gel-core/columns/timestamp.js.map +1 -1
  579. package/gel-core/columns/timestamptz.cjs.map +1 -1
  580. package/gel-core/columns/timestamptz.d.cts +0 -1
  581. package/gel-core/columns/timestamptz.d.ts +0 -1
  582. package/gel-core/columns/timestamptz.js.map +1 -1
  583. package/gel-core/columns/uuid.cjs.map +1 -1
  584. package/gel-core/columns/uuid.d.cts +0 -1
  585. package/gel-core/columns/uuid.d.ts +0 -1
  586. package/gel-core/columns/uuid.js.map +1 -1
  587. package/gel-core/dialect.cjs +1 -1
  588. package/gel-core/dialect.cjs.map +1 -1
  589. package/gel-core/dialect.js +8 -2
  590. package/gel-core/dialect.js.map +1 -1
  591. package/gel-core/query-builders/count.cjs.map +1 -1
  592. package/gel-core/query-builders/count.d.cts +4 -3
  593. package/gel-core/query-builders/count.d.ts +4 -3
  594. package/gel-core/query-builders/count.js.map +1 -1
  595. package/gel-core/query-builders/insert.cjs.map +1 -1
  596. package/gel-core/query-builders/insert.d.cts +6 -9
  597. package/gel-core/query-builders/insert.d.ts +6 -9
  598. package/gel-core/query-builders/insert.js.map +1 -1
  599. package/gel-core/query-builders/select.cjs +6 -7
  600. package/gel-core/query-builders/select.cjs.map +1 -1
  601. package/gel-core/query-builders/select.js +2 -2
  602. package/gel-core/query-builders/select.js.map +1 -1
  603. package/gel-core/query-builders/update.cjs.map +1 -1
  604. package/gel-core/query-builders/update.d.cts +1 -1
  605. package/gel-core/query-builders/update.d.ts +1 -1
  606. package/gel-core/query-builders/update.js.map +1 -1
  607. package/gel-core/utils.cjs +1 -2
  608. package/gel-core/utils.cjs.map +1 -1
  609. package/gel-core/utils.d.cts +1 -1
  610. package/gel-core/utils.d.ts +1 -1
  611. package/gel-core/utils.js +1 -2
  612. package/gel-core/utils.js.map +1 -1
  613. package/gel-core/view-common.cjs +3 -0
  614. package/gel-core/view-common.cjs.map +1 -1
  615. package/gel-core/view-common.d.cts +1 -0
  616. package/gel-core/view-common.d.ts +1 -0
  617. package/gel-core/view-common.js +2 -0
  618. package/gel-core/view-common.js.map +1 -1
  619. package/gel-core/view.cjs +2 -5
  620. package/gel-core/view.cjs.map +1 -1
  621. package/gel-core/view.d.cts +1 -2
  622. package/gel-core/view.d.ts +1 -2
  623. package/gel-core/view.js +1 -3
  624. package/gel-core/view.js.map +1 -1
  625. package/libsql/driver.cjs +6 -10
  626. package/libsql/driver.cjs.map +1 -1
  627. package/libsql/driver.d.cts +3 -3
  628. package/libsql/driver.d.ts +3 -3
  629. package/libsql/driver.js +6 -10
  630. package/libsql/driver.js.map +1 -1
  631. package/libsql/http/index.cjs +6 -10
  632. package/libsql/http/index.cjs.map +1 -1
  633. package/libsql/http/index.d.cts +3 -3
  634. package/libsql/http/index.d.ts +3 -3
  635. package/libsql/http/index.js +6 -10
  636. package/libsql/http/index.js.map +1 -1
  637. package/libsql/node/index.cjs +6 -10
  638. package/libsql/node/index.cjs.map +1 -1
  639. package/libsql/node/index.d.cts +3 -3
  640. package/libsql/node/index.d.ts +3 -3
  641. package/libsql/node/index.js +6 -10
  642. package/libsql/node/index.js.map +1 -1
  643. package/libsql/session.cjs +0 -2
  644. package/libsql/session.cjs.map +1 -1
  645. package/libsql/session.d.cts +1 -1
  646. package/libsql/session.d.ts +1 -1
  647. package/libsql/session.js +0 -2
  648. package/libsql/session.js.map +1 -1
  649. package/libsql/sqlite3/index.cjs +6 -10
  650. package/libsql/sqlite3/index.cjs.map +1 -1
  651. package/libsql/sqlite3/index.d.cts +3 -3
  652. package/libsql/sqlite3/index.d.ts +3 -3
  653. package/libsql/sqlite3/index.js +6 -10
  654. package/libsql/sqlite3/index.js.map +1 -1
  655. package/libsql/wasm/index.cjs +6 -10
  656. package/libsql/wasm/index.cjs.map +1 -1
  657. package/libsql/wasm/index.d.cts +3 -3
  658. package/libsql/wasm/index.d.ts +3 -3
  659. package/libsql/wasm/index.js +6 -10
  660. package/libsql/wasm/index.js.map +1 -1
  661. package/libsql/web/index.cjs +6 -10
  662. package/libsql/web/index.cjs.map +1 -1
  663. package/libsql/web/index.d.cts +3 -3
  664. package/libsql/web/index.d.ts +3 -3
  665. package/libsql/web/index.js +6 -10
  666. package/libsql/web/index.js.map +1 -1
  667. package/libsql/ws/index.cjs +6 -10
  668. package/libsql/ws/index.cjs.map +1 -1
  669. package/libsql/ws/index.d.cts +3 -3
  670. package/libsql/ws/index.d.ts +3 -3
  671. package/libsql/ws/index.js +6 -10
  672. package/libsql/ws/index.js.map +1 -1
  673. package/migrator.cjs +42 -5
  674. package/migrator.cjs.map +1 -1
  675. package/migrator.d.cts +5 -0
  676. package/migrator.d.ts +5 -0
  677. package/migrator.js +42 -6
  678. package/migrator.js.map +1 -1
  679. package/mssql-core/alias.cjs +32 -0
  680. package/mssql-core/alias.cjs.map +1 -0
  681. package/mssql-core/alias.d.cts +4 -0
  682. package/mssql-core/alias.d.ts +4 -0
  683. package/mssql-core/alias.js +8 -0
  684. package/mssql-core/alias.js.map +1 -0
  685. package/mssql-core/checks.cjs +58 -0
  686. package/mssql-core/checks.cjs.map +1 -0
  687. package/mssql-core/checks.d.cts +18 -0
  688. package/mssql-core/checks.d.ts +18 -0
  689. package/mssql-core/checks.js +32 -0
  690. package/mssql-core/checks.js.map +1 -0
  691. package/mssql-core/columns/all.cjs +74 -0
  692. package/mssql-core/columns/all.cjs.map +1 -0
  693. package/mssql-core/columns/all.d.cts +45 -0
  694. package/mssql-core/columns/all.d.ts +45 -0
  695. package/mssql-core/columns/all.js +50 -0
  696. package/mssql-core/columns/all.js.map +1 -0
  697. package/mssql-core/columns/bigint.cjs +72 -0
  698. package/mssql-core/columns/bigint.cjs.map +1 -0
  699. package/mssql-core/columns/bigint.d.cts +25 -0
  700. package/mssql-core/columns/bigint.d.ts +25 -0
  701. package/mssql-core/columns/bigint.js +46 -0
  702. package/mssql-core/columns/bigint.js.map +1 -0
  703. package/mssql-core/columns/binary.cjs +57 -0
  704. package/mssql-core/columns/binary.cjs.map +1 -0
  705. package/mssql-core/columns/binary.d.cts +24 -0
  706. package/mssql-core/columns/binary.d.ts +24 -0
  707. package/mssql-core/columns/binary.js +31 -0
  708. package/mssql-core/columns/binary.js.map +1 -0
  709. package/mssql-core/columns/bit.cjs +54 -0
  710. package/mssql-core/columns/bit.cjs.map +1 -0
  711. package/mssql-core/columns/bit.d.cts +17 -0
  712. package/mssql-core/columns/bit.d.ts +17 -0
  713. package/mssql-core/columns/bit.js +28 -0
  714. package/mssql-core/columns/bit.js.map +1 -0
  715. package/mssql-core/columns/char.cjs +73 -0
  716. package/mssql-core/columns/char.cjs.map +1 -0
  717. package/mssql-core/columns/char.d.cts +29 -0
  718. package/mssql-core/columns/char.d.ts +29 -0
  719. package/mssql-core/columns/char.js +46 -0
  720. package/mssql-core/columns/char.js.map +1 -0
  721. package/mssql-core/columns/common.cjs +112 -0
  722. package/mssql-core/columns/common.cjs.map +1 -0
  723. package/mssql-core/columns/common.d.cts +57 -0
  724. package/mssql-core/columns/common.d.ts +57 -0
  725. package/mssql-core/columns/common.js +85 -0
  726. package/mssql-core/columns/common.js.map +1 -0
  727. package/mssql-core/columns/custom.cjs +105 -0
  728. package/mssql-core/columns/custom.cjs.map +1 -0
  729. package/mssql-core/columns/custom.d.cts +261 -0
  730. package/mssql-core/columns/custom.d.ts +261 -0
  731. package/mssql-core/columns/custom.js +79 -0
  732. package/mssql-core/columns/custom.js.map +1 -0
  733. package/mssql-core/columns/date.cjs +94 -0
  734. package/mssql-core/columns/date.cjs.map +1 -0
  735. package/mssql-core/columns/date.common.cjs +37 -0
  736. package/mssql-core/columns/date.common.cjs.map +1 -0
  737. package/mssql-core/columns/date.common.d.cts +12 -0
  738. package/mssql-core/columns/date.common.d.ts +12 -0
  739. package/mssql-core/columns/date.common.js +13 -0
  740. package/mssql-core/columns/date.common.js.map +1 -0
  741. package/mssql-core/columns/date.d.cts +39 -0
  742. package/mssql-core/columns/date.d.ts +39 -0
  743. package/mssql-core/columns/date.js +66 -0
  744. package/mssql-core/columns/date.js.map +1 -0
  745. package/mssql-core/columns/datetime.cjs +94 -0
  746. package/mssql-core/columns/datetime.cjs.map +1 -0
  747. package/mssql-core/columns/datetime.d.cts +38 -0
  748. package/mssql-core/columns/datetime.d.ts +38 -0
  749. package/mssql-core/columns/datetime.js +66 -0
  750. package/mssql-core/columns/datetime.js.map +1 -0
  751. package/mssql-core/columns/datetime2.cjs +102 -0
  752. package/mssql-core/columns/datetime2.cjs.map +1 -0
  753. package/mssql-core/columns/datetime2.d.cts +38 -0
  754. package/mssql-core/columns/datetime2.d.ts +38 -0
  755. package/mssql-core/columns/datetime2.js +74 -0
  756. package/mssql-core/columns/datetime2.js.map +1 -0
  757. package/mssql-core/columns/datetimeoffset.cjs +102 -0
  758. package/mssql-core/columns/datetimeoffset.cjs.map +1 -0
  759. package/mssql-core/columns/datetimeoffset.d.cts +39 -0
  760. package/mssql-core/columns/datetimeoffset.d.ts +39 -0
  761. package/mssql-core/columns/datetimeoffset.js +74 -0
  762. package/mssql-core/columns/datetimeoffset.js.map +1 -0
  763. package/mssql-core/columns/decimal.cjs +146 -0
  764. package/mssql-core/columns/decimal.cjs.map +1 -0
  765. package/mssql-core/columns/decimal.d.cts +58 -0
  766. package/mssql-core/columns/decimal.d.ts +58 -0
  767. package/mssql-core/columns/decimal.js +116 -0
  768. package/mssql-core/columns/decimal.js.map +1 -0
  769. package/mssql-core/columns/float.cjs +58 -0
  770. package/mssql-core/columns/float.cjs.map +1 -0
  771. package/mssql-core/columns/float.d.cts +21 -0
  772. package/mssql-core/columns/float.d.ts +21 -0
  773. package/mssql-core/columns/float.js +32 -0
  774. package/mssql-core/columns/float.js.map +1 -0
  775. package/mssql-core/columns/index.cjs +63 -0
  776. package/mssql-core/columns/index.cjs.map +1 -0
  777. package/mssql-core/columns/index.d.cts +21 -0
  778. package/mssql-core/columns/index.d.ts +21 -0
  779. package/mssql-core/columns/index.js +22 -0
  780. package/mssql-core/columns/index.js.map +1 -0
  781. package/mssql-core/columns/int.cjs +53 -0
  782. package/mssql-core/columns/int.cjs.map +1 -0
  783. package/mssql-core/columns/int.d.cts +16 -0
  784. package/mssql-core/columns/int.d.ts +16 -0
  785. package/mssql-core/columns/int.js +27 -0
  786. package/mssql-core/columns/int.js.map +1 -0
  787. package/mssql-core/columns/numeric.cjs +146 -0
  788. package/mssql-core/columns/numeric.cjs.map +1 -0
  789. package/mssql-core/columns/numeric.d.cts +58 -0
  790. package/mssql-core/columns/numeric.d.ts +58 -0
  791. package/mssql-core/columns/numeric.js +116 -0
  792. package/mssql-core/columns/numeric.js.map +1 -0
  793. package/mssql-core/columns/real.cjs +53 -0
  794. package/mssql-core/columns/real.cjs.map +1 -0
  795. package/mssql-core/columns/real.d.cts +16 -0
  796. package/mssql-core/columns/real.d.ts +16 -0
  797. package/mssql-core/columns/real.js +27 -0
  798. package/mssql-core/columns/real.js.map +1 -0
  799. package/mssql-core/columns/smallint.cjs +62 -0
  800. package/mssql-core/columns/smallint.cjs.map +1 -0
  801. package/mssql-core/columns/smallint.d.cts +17 -0
  802. package/mssql-core/columns/smallint.d.ts +17 -0
  803. package/mssql-core/columns/smallint.js +36 -0
  804. package/mssql-core/columns/smallint.js.map +1 -0
  805. package/mssql-core/columns/text.cjs +68 -0
  806. package/mssql-core/columns/text.cjs.map +1 -0
  807. package/mssql-core/columns/text.d.cts +36 -0
  808. package/mssql-core/columns/text.d.ts +36 -0
  809. package/mssql-core/columns/text.js +41 -0
  810. package/mssql-core/columns/text.js.map +1 -0
  811. package/mssql-core/columns/time.cjs +90 -0
  812. package/mssql-core/columns/time.cjs.map +1 -0
  813. package/mssql-core/columns/time.d.cts +37 -0
  814. package/mssql-core/columns/time.d.ts +37 -0
  815. package/mssql-core/columns/time.js +62 -0
  816. package/mssql-core/columns/time.js.map +1 -0
  817. package/mssql-core/columns/tinyint.cjs +62 -0
  818. package/mssql-core/columns/tinyint.cjs.map +1 -0
  819. package/mssql-core/columns/tinyint.d.cts +17 -0
  820. package/mssql-core/columns/tinyint.d.ts +17 -0
  821. package/mssql-core/columns/tinyint.js +36 -0
  822. package/mssql-core/columns/tinyint.js.map +1 -0
  823. package/mssql-core/columns/varbinary.cjs +61 -0
  824. package/mssql-core/columns/varbinary.cjs.map +1 -0
  825. package/mssql-core/columns/varbinary.d.cts +23 -0
  826. package/mssql-core/columns/varbinary.d.ts +23 -0
  827. package/mssql-core/columns/varbinary.js +35 -0
  828. package/mssql-core/columns/varbinary.js.map +1 -0
  829. package/mssql-core/columns/varchar.cjs +117 -0
  830. package/mssql-core/columns/varchar.cjs.map +1 -0
  831. package/mssql-core/columns/varchar.d.cts +59 -0
  832. package/mssql-core/columns/varchar.d.ts +59 -0
  833. package/mssql-core/columns/varchar.js +88 -0
  834. package/mssql-core/columns/varchar.js.map +1 -0
  835. package/mssql-core/db.cjs +256 -0
  836. package/mssql-core/db.cjs.map +1 -0
  837. package/mssql-core/db.d.cts +228 -0
  838. package/mssql-core/db.d.ts +228 -0
  839. package/mssql-core/db.js +237 -0
  840. package/mssql-core/db.js.map +1 -0
  841. package/mssql-core/dialect.cjs +665 -0
  842. package/mssql-core/dialect.cjs.map +1 -0
  843. package/mssql-core/dialect.d.cts +58 -0
  844. package/mssql-core/dialect.d.ts +58 -0
  845. package/mssql-core/dialect.js +637 -0
  846. package/mssql-core/dialect.js.map +1 -0
  847. package/mssql-core/expressions.cjs +49 -0
  848. package/mssql-core/expressions.cjs.map +1 -0
  849. package/mssql-core/expressions.d.cts +8 -0
  850. package/mssql-core/expressions.d.ts +8 -0
  851. package/mssql-core/expressions.js +22 -0
  852. package/mssql-core/expressions.js.map +1 -0
  853. package/mssql-core/foreign-keys.cjs +94 -0
  854. package/mssql-core/foreign-keys.cjs.map +1 -0
  855. package/mssql-core/foreign-keys.d.cts +52 -0
  856. package/mssql-core/foreign-keys.d.ts +52 -0
  857. package/mssql-core/foreign-keys.js +68 -0
  858. package/mssql-core/foreign-keys.js.map +1 -0
  859. package/mssql-core/index.cjs +55 -0
  860. package/mssql-core/index.cjs.map +1 -0
  861. package/mssql-core/index.d.cts +17 -0
  862. package/mssql-core/index.d.ts +17 -0
  863. package/mssql-core/index.js +18 -0
  864. package/mssql-core/index.js.map +1 -0
  865. package/mssql-core/indexes.cjs +82 -0
  866. package/mssql-core/indexes.cjs.map +1 -0
  867. package/mssql-core/indexes.d.cts +50 -0
  868. package/mssql-core/indexes.d.ts +50 -0
  869. package/mssql-core/indexes.js +54 -0
  870. package/mssql-core/indexes.js.map +1 -0
  871. package/mssql-core/primary-keys.cjs +66 -0
  872. package/mssql-core/primary-keys.cjs.map +1 -0
  873. package/mssql-core/primary-keys.d.cts +24 -0
  874. package/mssql-core/primary-keys.d.ts +24 -0
  875. package/mssql-core/primary-keys.js +40 -0
  876. package/mssql-core/primary-keys.js.map +1 -0
  877. package/mssql-core/query-builders/delete.cjs +107 -0
  878. package/mssql-core/query-builders/delete.cjs.map +1 -0
  879. package/mssql-core/query-builders/delete.d.cts +98 -0
  880. package/mssql-core/query-builders/delete.d.ts +98 -0
  881. package/mssql-core/query-builders/delete.js +83 -0
  882. package/mssql-core/query-builders/delete.js.map +1 -0
  883. package/mssql-core/query-builders/index.cjs +33 -0
  884. package/mssql-core/query-builders/index.cjs.map +1 -0
  885. package/mssql-core/query-builders/index.d.cts +6 -0
  886. package/mssql-core/query-builders/index.d.ts +6 -0
  887. package/mssql-core/query-builders/index.js +7 -0
  888. package/mssql-core/query-builders/index.js.map +1 -0
  889. package/mssql-core/query-builders/insert.cjs +105 -0
  890. package/mssql-core/query-builders/insert.cjs.map +1 -0
  891. package/mssql-core/query-builders/insert.d.cts +79 -0
  892. package/mssql-core/query-builders/insert.d.ts +79 -0
  893. package/mssql-core/query-builders/insert.js +80 -0
  894. package/mssql-core/query-builders/insert.js.map +1 -0
  895. package/mssql-core/query-builders/query-builder.cjs +95 -0
  896. package/mssql-core/query-builders/query-builder.cjs.map +1 -0
  897. package/mssql-core/query-builders/query-builder.d.cts +32 -0
  898. package/mssql-core/query-builders/query-builder.d.ts +32 -0
  899. package/mssql-core/query-builders/query-builder.js +71 -0
  900. package/mssql-core/query-builders/query-builder.js.map +1 -0
  901. package/mssql-core/query-builders/query.cjs +126 -0
  902. package/mssql-core/query-builders/query.cjs.map +1 -0
  903. package/mssql-core/query-builders/query.d.cts +42 -0
  904. package/mssql-core/query-builders/query.d.ts +42 -0
  905. package/mssql-core/query-builders/query.js +103 -0
  906. package/mssql-core/query-builders/query.js.map +1 -0
  907. package/mssql-core/query-builders/select.cjs +678 -0
  908. package/mssql-core/query-builders/select.cjs.map +1 -0
  909. package/mssql-core/query-builders/select.d.cts +549 -0
  910. package/mssql-core/query-builders/select.d.ts +549 -0
  911. package/mssql-core/query-builders/select.js +654 -0
  912. package/mssql-core/query-builders/select.js.map +1 -0
  913. package/mssql-core/query-builders/select.types.cjs +17 -0
  914. package/mssql-core/query-builders/select.types.cjs.map +1 -0
  915. package/mssql-core/query-builders/select.types.d.cts +142 -0
  916. package/mssql-core/query-builders/select.types.d.ts +142 -0
  917. package/mssql-core/query-builders/select.types.js +1 -0
  918. package/mssql-core/query-builders/select.types.js.map +1 -0
  919. package/mssql-core/query-builders/update.cjs +138 -0
  920. package/mssql-core/query-builders/update.cjs.map +1 -0
  921. package/mssql-core/query-builders/update.d.cts +142 -0
  922. package/mssql-core/query-builders/update.d.ts +142 -0
  923. package/mssql-core/query-builders/update.js +113 -0
  924. package/mssql-core/query-builders/update.js.map +1 -0
  925. package/mssql-core/schema.cjs +53 -0
  926. package/mssql-core/schema.cjs.map +1 -0
  927. package/mssql-core/schema.d.cts +13 -0
  928. package/mssql-core/schema.d.ts +13 -0
  929. package/mssql-core/schema.js +28 -0
  930. package/mssql-core/schema.js.map +1 -0
  931. package/mssql-core/session.cjs +74 -0
  932. package/mssql-core/session.cjs.map +1 -0
  933. package/mssql-core/session.d.cts +63 -0
  934. package/mssql-core/session.d.ts +63 -0
  935. package/mssql-core/session.js +48 -0
  936. package/mssql-core/session.js.map +1 -0
  937. package/mssql-core/subquery.cjs +17 -0
  938. package/mssql-core/subquery.cjs.map +1 -0
  939. package/mssql-core/subquery.d.cts +18 -0
  940. package/mssql-core/subquery.d.ts +18 -0
  941. package/mssql-core/subquery.js +1 -0
  942. package/mssql-core/subquery.js.map +1 -0
  943. package/mssql-core/table.cjs +81 -0
  944. package/mssql-core/table.cjs.map +1 -0
  945. package/mssql-core/table.d.cts +40 -0
  946. package/mssql-core/table.d.ts +40 -0
  947. package/mssql-core/table.js +55 -0
  948. package/mssql-core/table.js.map +1 -0
  949. package/mssql-core/unique-constraint.cjs +78 -0
  950. package/mssql-core/unique-constraint.cjs.map +1 -0
  951. package/mssql-core/unique-constraint.d.cts +24 -0
  952. package/mssql-core/unique-constraint.d.ts +24 -0
  953. package/mssql-core/unique-constraint.js +51 -0
  954. package/mssql-core/unique-constraint.js.map +1 -0
  955. package/mssql-core/utils.cjs +85 -0
  956. package/mssql-core/utils.cjs.map +1 -0
  957. package/mssql-core/utils.d.cts +31 -0
  958. package/mssql-core/utils.d.ts +31 -0
  959. package/mssql-core/utils.js +60 -0
  960. package/mssql-core/utils.js.map +1 -0
  961. package/mssql-core/view-base.cjs +33 -0
  962. package/mssql-core/view-base.cjs.map +1 -0
  963. package/mssql-core/view-base.d.cts +9 -0
  964. package/mssql-core/view-base.d.ts +9 -0
  965. package/mssql-core/view-base.js +9 -0
  966. package/mssql-core/view-base.js.map +1 -0
  967. package/mssql-core/view-common.cjs +29 -0
  968. package/mssql-core/view-common.cjs.map +1 -0
  969. package/mssql-core/view-common.d.cts +1 -0
  970. package/mssql-core/view-common.d.ts +1 -0
  971. package/mssql-core/view-common.js +5 -0
  972. package/mssql-core/view-common.js.map +1 -0
  973. package/mssql-core/view.cjs +154 -0
  974. package/mssql-core/view.cjs.map +1 -0
  975. package/mssql-core/view.d.cts +63 -0
  976. package/mssql-core/view.d.ts +63 -0
  977. package/mssql-core/view.js +125 -0
  978. package/mssql-core/view.js.map +1 -0
  979. package/mysql-core/columns/all.cjs +6 -1
  980. package/mysql-core/columns/all.cjs.map +1 -1
  981. package/mysql-core/columns/all.d.cts +5 -0
  982. package/mysql-core/columns/all.d.ts +5 -0
  983. package/mysql-core/columns/all.js +6 -1
  984. package/mysql-core/columns/all.js.map +1 -1
  985. package/mysql-core/columns/bigint.cjs.map +1 -1
  986. package/mysql-core/columns/bigint.d.cts +0 -3
  987. package/mysql-core/columns/bigint.d.ts +0 -3
  988. package/mysql-core/columns/bigint.js.map +1 -1
  989. package/mysql-core/columns/binary.cjs +0 -1
  990. package/mysql-core/columns/binary.cjs.map +1 -1
  991. package/mysql-core/columns/binary.d.cts +0 -2
  992. package/mysql-core/columns/binary.d.ts +0 -2
  993. package/mysql-core/columns/binary.js +0 -1
  994. package/mysql-core/columns/binary.js.map +1 -1
  995. package/mysql-core/columns/blob.cjs +158 -0
  996. package/mysql-core/columns/blob.cjs.map +1 -0
  997. package/mysql-core/columns/blob.d.cts +54 -0
  998. package/mysql-core/columns/blob.d.ts +54 -0
  999. package/mysql-core/columns/blob.js +127 -0
  1000. package/mysql-core/columns/blob.js.map +1 -0
  1001. package/mysql-core/columns/boolean.cjs.map +1 -1
  1002. package/mysql-core/columns/boolean.d.cts +0 -1
  1003. package/mysql-core/columns/boolean.d.ts +0 -1
  1004. package/mysql-core/columns/boolean.js.map +1 -1
  1005. package/mysql-core/columns/char.cjs +3 -4
  1006. package/mysql-core/columns/char.cjs.map +1 -1
  1007. package/mysql-core/columns/char.d.cts +3 -5
  1008. package/mysql-core/columns/char.d.ts +3 -5
  1009. package/mysql-core/columns/char.js +3 -4
  1010. package/mysql-core/columns/char.js.map +1 -1
  1011. package/mysql-core/columns/common.cjs +0 -4
  1012. package/mysql-core/columns/common.cjs.map +1 -1
  1013. package/mysql-core/columns/common.d.cts +1 -1
  1014. package/mysql-core/columns/common.d.ts +1 -1
  1015. package/mysql-core/columns/common.js +0 -4
  1016. package/mysql-core/columns/common.js.map +1 -1
  1017. package/mysql-core/columns/custom.cjs.map +1 -1
  1018. package/mysql-core/columns/custom.d.cts +0 -1
  1019. package/mysql-core/columns/custom.d.ts +0 -1
  1020. package/mysql-core/columns/custom.js.map +1 -1
  1021. package/mysql-core/columns/date.cjs.map +1 -1
  1022. package/mysql-core/columns/date.common.cjs +3 -1
  1023. package/mysql-core/columns/date.common.cjs.map +1 -1
  1024. package/mysql-core/columns/date.common.d.cts +6 -1
  1025. package/mysql-core/columns/date.common.d.ts +6 -1
  1026. package/mysql-core/columns/date.common.js +3 -1
  1027. package/mysql-core/columns/date.common.js.map +1 -1
  1028. package/mysql-core/columns/date.d.cts +0 -2
  1029. package/mysql-core/columns/date.d.ts +0 -2
  1030. package/mysql-core/columns/date.js.map +1 -1
  1031. package/mysql-core/columns/datetime.cjs.map +1 -1
  1032. package/mysql-core/columns/datetime.d.cts +0 -2
  1033. package/mysql-core/columns/datetime.d.ts +0 -2
  1034. package/mysql-core/columns/datetime.js.map +1 -1
  1035. package/mysql-core/columns/decimal.cjs.map +1 -1
  1036. package/mysql-core/columns/decimal.d.cts +0 -3
  1037. package/mysql-core/columns/decimal.d.ts +0 -3
  1038. package/mysql-core/columns/decimal.js.map +1 -1
  1039. package/mysql-core/columns/double.cjs.map +1 -1
  1040. package/mysql-core/columns/double.d.cts +0 -1
  1041. package/mysql-core/columns/double.d.ts +0 -1
  1042. package/mysql-core/columns/double.js.map +1 -1
  1043. package/mysql-core/columns/enum.cjs +5 -5
  1044. package/mysql-core/columns/enum.cjs.map +1 -1
  1045. package/mysql-core/columns/enum.d.cts +5 -7
  1046. package/mysql-core/columns/enum.d.ts +5 -7
  1047. package/mysql-core/columns/enum.js +5 -5
  1048. package/mysql-core/columns/enum.js.map +1 -1
  1049. package/mysql-core/columns/float.cjs.map +1 -1
  1050. package/mysql-core/columns/float.d.cts +0 -1
  1051. package/mysql-core/columns/float.d.ts +0 -1
  1052. package/mysql-core/columns/float.js.map +1 -1
  1053. package/mysql-core/columns/index.cjs +2 -0
  1054. package/mysql-core/columns/index.cjs.map +1 -1
  1055. package/mysql-core/columns/index.d.cts +1 -0
  1056. package/mysql-core/columns/index.d.ts +1 -0
  1057. package/mysql-core/columns/index.js +1 -0
  1058. package/mysql-core/columns/index.js.map +1 -1
  1059. package/mysql-core/columns/int.cjs.map +1 -1
  1060. package/mysql-core/columns/int.d.cts +0 -1
  1061. package/mysql-core/columns/int.d.ts +0 -1
  1062. package/mysql-core/columns/int.js.map +1 -1
  1063. package/mysql-core/columns/json.cjs.map +1 -1
  1064. package/mysql-core/columns/json.d.cts +0 -1
  1065. package/mysql-core/columns/json.d.ts +0 -1
  1066. package/mysql-core/columns/json.js.map +1 -1
  1067. package/mysql-core/columns/mediumint.cjs.map +1 -1
  1068. package/mysql-core/columns/mediumint.d.cts +0 -1
  1069. package/mysql-core/columns/mediumint.d.ts +0 -1
  1070. package/mysql-core/columns/mediumint.js.map +1 -1
  1071. package/mysql-core/columns/real.cjs.map +1 -1
  1072. package/mysql-core/columns/real.d.cts +0 -1
  1073. package/mysql-core/columns/real.d.ts +0 -1
  1074. package/mysql-core/columns/real.js.map +1 -1
  1075. package/mysql-core/columns/serial.cjs.map +1 -1
  1076. package/mysql-core/columns/serial.d.cts +0 -1
  1077. package/mysql-core/columns/serial.d.ts +0 -1
  1078. package/mysql-core/columns/serial.js.map +1 -1
  1079. package/mysql-core/columns/smallint.cjs.map +1 -1
  1080. package/mysql-core/columns/smallint.d.cts +0 -1
  1081. package/mysql-core/columns/smallint.d.ts +0 -1
  1082. package/mysql-core/columns/smallint.js.map +1 -1
  1083. package/mysql-core/columns/string.common.cjs +48 -0
  1084. package/mysql-core/columns/string.common.cjs.map +1 -0
  1085. package/mysql-core/columns/string.common.d.cts +21 -0
  1086. package/mysql-core/columns/string.common.d.ts +21 -0
  1087. package/mysql-core/columns/string.common.js +23 -0
  1088. package/mysql-core/columns/string.common.js.map +1 -0
  1089. package/mysql-core/columns/text.cjs +3 -3
  1090. package/mysql-core/columns/text.cjs.map +1 -1
  1091. package/mysql-core/columns/text.d.cts +3 -4
  1092. package/mysql-core/columns/text.d.ts +3 -4
  1093. package/mysql-core/columns/text.js +3 -3
  1094. package/mysql-core/columns/text.js.map +1 -1
  1095. package/mysql-core/columns/time.cjs.map +1 -1
  1096. package/mysql-core/columns/time.d.cts +0 -1
  1097. package/mysql-core/columns/time.d.ts +0 -1
  1098. package/mysql-core/columns/time.js.map +1 -1
  1099. package/mysql-core/columns/timestamp.cjs.map +1 -1
  1100. package/mysql-core/columns/timestamp.d.cts +0 -2
  1101. package/mysql-core/columns/timestamp.d.ts +0 -2
  1102. package/mysql-core/columns/timestamp.js.map +1 -1
  1103. package/mysql-core/columns/tinyint.cjs.map +1 -1
  1104. package/mysql-core/columns/tinyint.d.cts +0 -1
  1105. package/mysql-core/columns/tinyint.d.ts +0 -1
  1106. package/mysql-core/columns/tinyint.js.map +1 -1
  1107. package/mysql-core/columns/varbinary.cjs.map +1 -1
  1108. package/mysql-core/columns/varbinary.d.cts +0 -1
  1109. package/mysql-core/columns/varbinary.d.ts +0 -1
  1110. package/mysql-core/columns/varbinary.js.map +1 -1
  1111. package/mysql-core/columns/varchar.cjs +4 -4
  1112. package/mysql-core/columns/varchar.cjs.map +1 -1
  1113. package/mysql-core/columns/varchar.d.cts +4 -5
  1114. package/mysql-core/columns/varchar.d.ts +4 -5
  1115. package/mysql-core/columns/varchar.js +4 -4
  1116. package/mysql-core/columns/varchar.js.map +1 -1
  1117. package/mysql-core/columns/year.cjs.map +1 -1
  1118. package/mysql-core/columns/year.d.cts +0 -1
  1119. package/mysql-core/columns/year.d.ts +0 -1
  1120. package/mysql-core/columns/year.js.map +1 -1
  1121. package/mysql-core/dialect.cjs +7 -2
  1122. package/mysql-core/dialect.cjs.map +1 -1
  1123. package/mysql-core/dialect.d.cts +1 -0
  1124. package/mysql-core/dialect.d.ts +1 -0
  1125. package/mysql-core/dialect.js +14 -3
  1126. package/mysql-core/dialect.js.map +1 -1
  1127. package/mysql-core/foreign-keys.cjs +3 -0
  1128. package/mysql-core/foreign-keys.cjs.map +1 -1
  1129. package/mysql-core/foreign-keys.d.cts +1 -0
  1130. package/mysql-core/foreign-keys.d.ts +1 -0
  1131. package/mysql-core/foreign-keys.js +3 -0
  1132. package/mysql-core/foreign-keys.js.map +1 -1
  1133. package/mysql-core/indexes.cjs +2 -0
  1134. package/mysql-core/indexes.cjs.map +1 -1
  1135. package/mysql-core/indexes.d.cts +1 -0
  1136. package/mysql-core/indexes.d.ts +1 -0
  1137. package/mysql-core/indexes.js +2 -0
  1138. package/mysql-core/indexes.js.map +1 -1
  1139. package/mysql-core/primary-keys.cjs +4 -13
  1140. package/mysql-core/primary-keys.cjs.map +1 -1
  1141. package/mysql-core/primary-keys.d.cts +3 -6
  1142. package/mysql-core/primary-keys.d.ts +3 -6
  1143. package/mysql-core/primary-keys.js +4 -13
  1144. package/mysql-core/primary-keys.js.map +1 -1
  1145. package/mysql-core/query-builders/count.cjs.map +1 -1
  1146. package/mysql-core/query-builders/count.d.cts +1 -1
  1147. package/mysql-core/query-builders/count.d.ts +1 -1
  1148. package/mysql-core/query-builders/count.js.map +1 -1
  1149. package/mysql-core/query-builders/insert.cjs.map +1 -1
  1150. package/mysql-core/query-builders/insert.d.cts +2 -2
  1151. package/mysql-core/query-builders/insert.d.ts +2 -2
  1152. package/mysql-core/query-builders/insert.js.map +1 -1
  1153. package/mysql-core/query-builders/update.cjs.map +1 -1
  1154. package/mysql-core/query-builders/update.d.cts +1 -1
  1155. package/mysql-core/query-builders/update.d.ts +1 -1
  1156. package/mysql-core/query-builders/update.js.map +1 -1
  1157. package/mysql-core/unique-constraint.cjs +2 -0
  1158. package/mysql-core/unique-constraint.cjs.map +1 -1
  1159. package/mysql-core/unique-constraint.d.cts +3 -2
  1160. package/mysql-core/unique-constraint.d.ts +3 -2
  1161. package/mysql-core/unique-constraint.js +2 -0
  1162. package/mysql-core/unique-constraint.js.map +1 -1
  1163. package/mysql-proxy/driver.cjs +2 -2
  1164. package/mysql-proxy/driver.cjs.map +1 -1
  1165. package/mysql-proxy/driver.d.cts +2 -1
  1166. package/mysql-proxy/driver.d.ts +2 -1
  1167. package/mysql-proxy/driver.js +2 -2
  1168. package/mysql-proxy/driver.js.map +1 -1
  1169. package/mysql2/driver.cjs +10 -14
  1170. package/mysql2/driver.cjs.map +1 -1
  1171. package/mysql2/driver.d.cts +3 -3
  1172. package/mysql2/driver.d.ts +3 -3
  1173. package/mysql2/driver.js +10 -14
  1174. package/mysql2/driver.js.map +1 -1
  1175. package/mysql2/session.cjs.map +1 -1
  1176. package/mysql2/session.js.map +1 -1
  1177. package/neon-http/driver.cjs +10 -14
  1178. package/neon-http/driver.cjs.map +1 -1
  1179. package/neon-http/driver.d.cts +3 -3
  1180. package/neon-http/driver.d.ts +3 -3
  1181. package/neon-http/driver.js +10 -14
  1182. package/neon-http/driver.js.map +1 -1
  1183. package/neon-http/session.cjs.map +1 -1
  1184. package/neon-http/session.d.cts +1 -1
  1185. package/neon-http/session.d.ts +1 -1
  1186. package/neon-http/session.js.map +1 -1
  1187. package/neon-serverless/driver.cjs +10 -14
  1188. package/neon-serverless/driver.cjs.map +1 -1
  1189. package/neon-serverless/driver.d.cts +3 -3
  1190. package/neon-serverless/driver.d.ts +3 -3
  1191. package/neon-serverless/driver.js +10 -14
  1192. package/neon-serverless/driver.js.map +1 -1
  1193. package/neon-serverless/session.cjs.map +1 -1
  1194. package/neon-serverless/session.js.map +1 -1
  1195. package/node-mssql/driver.cjs +129 -0
  1196. package/node-mssql/driver.cjs.map +1 -0
  1197. package/node-mssql/driver.d.cts +48 -0
  1198. package/node-mssql/driver.d.ts +48 -0
  1199. package/node-mssql/driver.js +92 -0
  1200. package/node-mssql/driver.js.map +1 -0
  1201. package/node-mssql/index.cjs +25 -0
  1202. package/node-mssql/index.cjs.map +1 -0
  1203. package/node-mssql/index.d.cts +2 -0
  1204. package/node-mssql/index.d.ts +2 -0
  1205. package/node-mssql/index.js +3 -0
  1206. package/node-mssql/index.js.map +1 -0
  1207. package/node-mssql/migrator.cjs +33 -0
  1208. package/node-mssql/migrator.cjs.map +1 -0
  1209. package/node-mssql/migrator.d.cts +3 -0
  1210. package/node-mssql/migrator.d.ts +3 -0
  1211. package/node-mssql/migrator.js +9 -0
  1212. package/node-mssql/migrator.js.map +1 -0
  1213. package/node-mssql/pool.cjs +54 -0
  1214. package/node-mssql/pool.cjs.map +1 -0
  1215. package/node-mssql/pool.d.cts +8 -0
  1216. package/node-mssql/pool.d.ts +8 -0
  1217. package/node-mssql/pool.js +20 -0
  1218. package/node-mssql/pool.js.map +1 -0
  1219. package/node-mssql/session.cjs +256 -0
  1220. package/node-mssql/session.cjs.map +1 -0
  1221. package/node-mssql/session.d.cts +48 -0
  1222. package/node-mssql/session.d.ts +48 -0
  1223. package/node-mssql/session.js +224 -0
  1224. package/node-mssql/session.js.map +1 -0
  1225. package/node-postgres/driver.cjs +8 -12
  1226. package/node-postgres/driver.cjs.map +1 -1
  1227. package/node-postgres/driver.d.cts +3 -3
  1228. package/node-postgres/driver.d.ts +3 -3
  1229. package/node-postgres/driver.js +8 -12
  1230. package/node-postgres/driver.js.map +1 -1
  1231. package/node-postgres/session.cjs.map +1 -1
  1232. package/node-postgres/session.js.map +1 -1
  1233. package/op-sqlite/migrator.cjs +10 -7
  1234. package/op-sqlite/migrator.cjs.map +1 -1
  1235. package/op-sqlite/migrator.d.cts +0 -16
  1236. package/op-sqlite/migrator.d.ts +0 -16
  1237. package/op-sqlite/migrator.js +10 -7
  1238. package/op-sqlite/migrator.js.map +1 -1
  1239. package/package.json +1498 -20
  1240. package/pg-core/columns/bigint.cjs.map +1 -1
  1241. package/pg-core/columns/bigint.d.cts +0 -3
  1242. package/pg-core/columns/bigint.d.ts +0 -3
  1243. package/pg-core/columns/bigint.js.map +1 -1
  1244. package/pg-core/columns/bigserial.cjs +1 -0
  1245. package/pg-core/columns/bigserial.cjs.map +1 -1
  1246. package/pg-core/columns/bigserial.d.cts +0 -2
  1247. package/pg-core/columns/bigserial.d.ts +0 -2
  1248. package/pg-core/columns/bigserial.js +1 -0
  1249. package/pg-core/columns/bigserial.js.map +1 -1
  1250. package/pg-core/columns/boolean.cjs.map +1 -1
  1251. package/pg-core/columns/boolean.d.cts +0 -1
  1252. package/pg-core/columns/boolean.d.ts +0 -1
  1253. package/pg-core/columns/boolean.js.map +1 -1
  1254. package/pg-core/columns/bytea.cjs.map +1 -1
  1255. package/pg-core/columns/bytea.d.cts +0 -1
  1256. package/pg-core/columns/bytea.d.ts +0 -1
  1257. package/pg-core/columns/bytea.js.map +1 -1
  1258. package/pg-core/columns/char.cjs +0 -1
  1259. package/pg-core/columns/char.cjs.map +1 -1
  1260. package/pg-core/columns/char.d.cts +0 -2
  1261. package/pg-core/columns/char.d.ts +0 -2
  1262. package/pg-core/columns/char.js +0 -1
  1263. package/pg-core/columns/char.js.map +1 -1
  1264. package/pg-core/columns/cidr.cjs.map +1 -1
  1265. package/pg-core/columns/cidr.d.cts +0 -1
  1266. package/pg-core/columns/cidr.d.ts +0 -1
  1267. package/pg-core/columns/cidr.js.map +1 -1
  1268. package/pg-core/columns/common.cjs +10 -14
  1269. package/pg-core/columns/common.cjs.map +1 -1
  1270. package/pg-core/columns/common.d.cts +4 -3
  1271. package/pg-core/columns/common.d.ts +4 -3
  1272. package/pg-core/columns/common.js +10 -14
  1273. package/pg-core/columns/common.js.map +1 -1
  1274. package/pg-core/columns/custom.cjs.map +1 -1
  1275. package/pg-core/columns/custom.d.cts +0 -1
  1276. package/pg-core/columns/custom.d.ts +0 -1
  1277. package/pg-core/columns/custom.js.map +1 -1
  1278. package/pg-core/columns/date.cjs.map +1 -1
  1279. package/pg-core/columns/date.d.cts +0 -2
  1280. package/pg-core/columns/date.d.ts +0 -2
  1281. package/pg-core/columns/date.js.map +1 -1
  1282. package/pg-core/columns/double-precision.cjs.map +1 -1
  1283. package/pg-core/columns/double-precision.d.cts +0 -1
  1284. package/pg-core/columns/double-precision.d.ts +0 -1
  1285. package/pg-core/columns/double-precision.js.map +1 -1
  1286. package/pg-core/columns/enum.cjs.map +1 -1
  1287. package/pg-core/columns/enum.d.cts +0 -2
  1288. package/pg-core/columns/enum.d.ts +0 -2
  1289. package/pg-core/columns/enum.js.map +1 -1
  1290. package/pg-core/columns/inet.cjs.map +1 -1
  1291. package/pg-core/columns/inet.d.cts +0 -1
  1292. package/pg-core/columns/inet.d.ts +0 -1
  1293. package/pg-core/columns/inet.js.map +1 -1
  1294. package/pg-core/columns/integer.cjs.map +1 -1
  1295. package/pg-core/columns/integer.d.cts +0 -1
  1296. package/pg-core/columns/integer.d.ts +0 -1
  1297. package/pg-core/columns/integer.js.map +1 -1
  1298. package/pg-core/columns/interval.cjs.map +1 -1
  1299. package/pg-core/columns/interval.d.cts +0 -1
  1300. package/pg-core/columns/interval.d.ts +0 -1
  1301. package/pg-core/columns/interval.js.map +1 -1
  1302. package/pg-core/columns/json.cjs.map +1 -1
  1303. package/pg-core/columns/json.d.cts +0 -1
  1304. package/pg-core/columns/json.d.ts +0 -1
  1305. package/pg-core/columns/json.js.map +1 -1
  1306. package/pg-core/columns/jsonb.cjs.map +1 -1
  1307. package/pg-core/columns/jsonb.d.cts +0 -1
  1308. package/pg-core/columns/jsonb.d.ts +0 -1
  1309. package/pg-core/columns/jsonb.js.map +1 -1
  1310. package/pg-core/columns/line.cjs +2 -0
  1311. package/pg-core/columns/line.cjs.map +1 -1
  1312. package/pg-core/columns/line.d.cts +2 -2
  1313. package/pg-core/columns/line.d.ts +2 -2
  1314. package/pg-core/columns/line.js +2 -0
  1315. package/pg-core/columns/line.js.map +1 -1
  1316. package/pg-core/columns/macaddr.cjs.map +1 -1
  1317. package/pg-core/columns/macaddr.d.cts +0 -1
  1318. package/pg-core/columns/macaddr.d.ts +0 -1
  1319. package/pg-core/columns/macaddr.js.map +1 -1
  1320. package/pg-core/columns/macaddr8.cjs.map +1 -1
  1321. package/pg-core/columns/macaddr8.d.cts +0 -1
  1322. package/pg-core/columns/macaddr8.d.ts +0 -1
  1323. package/pg-core/columns/macaddr8.js.map +1 -1
  1324. package/pg-core/columns/numeric.cjs.map +1 -1
  1325. package/pg-core/columns/numeric.d.cts +0 -3
  1326. package/pg-core/columns/numeric.d.ts +0 -3
  1327. package/pg-core/columns/numeric.js.map +1 -1
  1328. package/pg-core/columns/point.cjs +2 -0
  1329. package/pg-core/columns/point.cjs.map +1 -1
  1330. package/pg-core/columns/point.d.cts +2 -2
  1331. package/pg-core/columns/point.d.ts +2 -2
  1332. package/pg-core/columns/point.js +2 -0
  1333. package/pg-core/columns/point.js.map +1 -1
  1334. package/pg-core/columns/postgis_extension/geometry.cjs +14 -8
  1335. package/pg-core/columns/postgis_extension/geometry.cjs.map +1 -1
  1336. package/pg-core/columns/postgis_extension/geometry.d.cts +16 -6
  1337. package/pg-core/columns/postgis_extension/geometry.d.ts +16 -6
  1338. package/pg-core/columns/postgis_extension/geometry.js +14 -8
  1339. package/pg-core/columns/postgis_extension/geometry.js.map +1 -1
  1340. package/pg-core/columns/postgis_extension/utils.cjs +3 -3
  1341. package/pg-core/columns/postgis_extension/utils.cjs.map +1 -1
  1342. package/pg-core/columns/postgis_extension/utils.d.cts +4 -1
  1343. package/pg-core/columns/postgis_extension/utils.d.ts +4 -1
  1344. package/pg-core/columns/postgis_extension/utils.js +3 -3
  1345. package/pg-core/columns/postgis_extension/utils.js.map +1 -1
  1346. package/pg-core/columns/real.cjs.map +1 -1
  1347. package/pg-core/columns/real.d.cts +0 -1
  1348. package/pg-core/columns/real.d.ts +0 -1
  1349. package/pg-core/columns/real.js.map +1 -1
  1350. package/pg-core/columns/serial.cjs.map +1 -1
  1351. package/pg-core/columns/serial.d.cts +0 -1
  1352. package/pg-core/columns/serial.d.ts +0 -1
  1353. package/pg-core/columns/serial.js.map +1 -1
  1354. package/pg-core/columns/smallint.cjs.map +1 -1
  1355. package/pg-core/columns/smallint.d.cts +0 -1
  1356. package/pg-core/columns/smallint.d.ts +0 -1
  1357. package/pg-core/columns/smallint.js.map +1 -1
  1358. package/pg-core/columns/smallserial.cjs.map +1 -1
  1359. package/pg-core/columns/smallserial.d.cts +0 -1
  1360. package/pg-core/columns/smallserial.d.ts +0 -1
  1361. package/pg-core/columns/smallserial.js.map +1 -1
  1362. package/pg-core/columns/text.cjs.map +1 -1
  1363. package/pg-core/columns/text.d.cts +0 -1
  1364. package/pg-core/columns/text.d.ts +0 -1
  1365. package/pg-core/columns/text.js.map +1 -1
  1366. package/pg-core/columns/time.cjs.map +1 -1
  1367. package/pg-core/columns/time.d.cts +0 -1
  1368. package/pg-core/columns/time.d.ts +0 -1
  1369. package/pg-core/columns/time.js.map +1 -1
  1370. package/pg-core/columns/timestamp.cjs.map +1 -1
  1371. package/pg-core/columns/timestamp.d.cts +0 -2
  1372. package/pg-core/columns/timestamp.d.ts +0 -2
  1373. package/pg-core/columns/timestamp.js.map +1 -1
  1374. package/pg-core/columns/uuid.cjs.map +1 -1
  1375. package/pg-core/columns/uuid.d.cts +0 -1
  1376. package/pg-core/columns/uuid.d.ts +0 -1
  1377. package/pg-core/columns/uuid.js.map +1 -1
  1378. package/pg-core/columns/varchar.cjs.map +1 -1
  1379. package/pg-core/columns/varchar.d.cts +0 -1
  1380. package/pg-core/columns/varchar.d.ts +0 -1
  1381. package/pg-core/columns/varchar.js.map +1 -1
  1382. package/pg-core/columns/vector_extension/bit.cjs.map +1 -1
  1383. package/pg-core/columns/vector_extension/bit.d.cts +0 -1
  1384. package/pg-core/columns/vector_extension/bit.d.ts +0 -1
  1385. package/pg-core/columns/vector_extension/bit.js.map +1 -1
  1386. package/pg-core/columns/vector_extension/halfvec.cjs.map +1 -1
  1387. package/pg-core/columns/vector_extension/halfvec.d.cts +0 -1
  1388. package/pg-core/columns/vector_extension/halfvec.d.ts +0 -1
  1389. package/pg-core/columns/vector_extension/halfvec.js.map +1 -1
  1390. package/pg-core/columns/vector_extension/sparsevec.cjs.map +1 -1
  1391. package/pg-core/columns/vector_extension/sparsevec.d.cts +0 -1
  1392. package/pg-core/columns/vector_extension/sparsevec.d.ts +0 -1
  1393. package/pg-core/columns/vector_extension/sparsevec.js.map +1 -1
  1394. package/pg-core/columns/vector_extension/vector.cjs.map +1 -1
  1395. package/pg-core/columns/vector_extension/vector.d.cts +0 -1
  1396. package/pg-core/columns/vector_extension/vector.d.ts +0 -1
  1397. package/pg-core/columns/vector_extension/vector.js.map +1 -1
  1398. package/pg-core/dialect.cjs +4 -2
  1399. package/pg-core/dialect.cjs.map +1 -1
  1400. package/pg-core/dialect.js +11 -3
  1401. package/pg-core/dialect.js.map +1 -1
  1402. package/pg-core/foreign-keys.cjs +4 -0
  1403. package/pg-core/foreign-keys.cjs.map +1 -1
  1404. package/pg-core/foreign-keys.d.cts +2 -0
  1405. package/pg-core/foreign-keys.d.ts +2 -0
  1406. package/pg-core/foreign-keys.js +4 -0
  1407. package/pg-core/foreign-keys.js.map +1 -1
  1408. package/pg-core/indexes.cjs +2 -0
  1409. package/pg-core/indexes.cjs.map +1 -1
  1410. package/pg-core/indexes.d.cts +1 -0
  1411. package/pg-core/indexes.d.ts +1 -0
  1412. package/pg-core/indexes.js +2 -0
  1413. package/pg-core/indexes.js.map +1 -1
  1414. package/pg-core/primary-keys.cjs +2 -0
  1415. package/pg-core/primary-keys.cjs.map +1 -1
  1416. package/pg-core/primary-keys.d.cts +1 -0
  1417. package/pg-core/primary-keys.d.ts +1 -0
  1418. package/pg-core/primary-keys.js +2 -0
  1419. package/pg-core/primary-keys.js.map +1 -1
  1420. package/pg-core/query-builders/count.cjs.map +1 -1
  1421. package/pg-core/query-builders/count.d.cts +4 -3
  1422. package/pg-core/query-builders/count.d.ts +4 -3
  1423. package/pg-core/query-builders/count.js.map +1 -1
  1424. package/pg-core/query-builders/insert.cjs.map +1 -1
  1425. package/pg-core/query-builders/insert.d.cts +6 -9
  1426. package/pg-core/query-builders/insert.d.ts +6 -9
  1427. package/pg-core/query-builders/insert.js.map +1 -1
  1428. package/pg-core/query-builders/select.cjs +6 -7
  1429. package/pg-core/query-builders/select.cjs.map +1 -1
  1430. package/pg-core/query-builders/select.js +2 -2
  1431. package/pg-core/query-builders/select.js.map +1 -1
  1432. package/pg-core/query-builders/update.cjs.map +1 -1
  1433. package/pg-core/query-builders/update.d.cts +1 -1
  1434. package/pg-core/query-builders/update.d.ts +1 -1
  1435. package/pg-core/query-builders/update.js.map +1 -1
  1436. package/pg-core/schema.cjs +12 -0
  1437. package/pg-core/schema.cjs.map +1 -1
  1438. package/pg-core/schema.d.cts +2 -0
  1439. package/pg-core/schema.d.ts +2 -0
  1440. package/pg-core/schema.js +13 -1
  1441. package/pg-core/schema.js.map +1 -1
  1442. package/pg-core/table.cjs +15 -2
  1443. package/pg-core/table.cjs.map +1 -1
  1444. package/pg-core/table.d.cts +5 -1
  1445. package/pg-core/table.d.ts +5 -1
  1446. package/pg-core/table.js +15 -2
  1447. package/pg-core/table.js.map +1 -1
  1448. package/pg-core/unique-constraint.cjs +2 -0
  1449. package/pg-core/unique-constraint.cjs.map +1 -1
  1450. package/pg-core/unique-constraint.d.cts +1 -0
  1451. package/pg-core/unique-constraint.d.ts +1 -0
  1452. package/pg-core/unique-constraint.js +2 -0
  1453. package/pg-core/unique-constraint.js.map +1 -1
  1454. package/pg-core/utils.cjs +1 -2
  1455. package/pg-core/utils.cjs.map +1 -1
  1456. package/pg-core/utils.d.cts +1 -1
  1457. package/pg-core/utils.d.ts +1 -1
  1458. package/pg-core/utils.js +1 -2
  1459. package/pg-core/utils.js.map +1 -1
  1460. package/pg-core/view-common.cjs +3 -0
  1461. package/pg-core/view-common.cjs.map +1 -1
  1462. package/pg-core/view-common.d.cts +1 -0
  1463. package/pg-core/view-common.d.ts +1 -0
  1464. package/pg-core/view-common.js +2 -0
  1465. package/pg-core/view-common.js.map +1 -1
  1466. package/pg-core/view.cjs +2 -5
  1467. package/pg-core/view.cjs.map +1 -1
  1468. package/pg-core/view.d.cts +1 -2
  1469. package/pg-core/view.d.ts +1 -2
  1470. package/pg-core/view.js +1 -3
  1471. package/pg-core/view.js.map +1 -1
  1472. package/pglite/driver.cjs +10 -14
  1473. package/pglite/driver.cjs.map +1 -1
  1474. package/pglite/driver.d.cts +3 -3
  1475. package/pglite/driver.d.ts +3 -3
  1476. package/pglite/driver.js +10 -14
  1477. package/pglite/driver.js.map +1 -1
  1478. package/planetscale-serverless/driver.cjs +11 -15
  1479. package/planetscale-serverless/driver.cjs.map +1 -1
  1480. package/planetscale-serverless/driver.d.cts +3 -3
  1481. package/planetscale-serverless/driver.d.ts +3 -3
  1482. package/planetscale-serverless/driver.js +11 -15
  1483. package/planetscale-serverless/driver.js.map +1 -1
  1484. package/postgres-js/driver.cjs +10 -14
  1485. package/postgres-js/driver.cjs.map +1 -1
  1486. package/postgres-js/driver.d.cts +3 -3
  1487. package/postgres-js/driver.d.ts +3 -3
  1488. package/postgres-js/driver.js +10 -14
  1489. package/postgres-js/driver.js.map +1 -1
  1490. package/relations.cjs +2 -0
  1491. package/relations.cjs.map +1 -1
  1492. package/relations.d.cts +3 -3
  1493. package/relations.d.ts +3 -3
  1494. package/relations.js +3 -1
  1495. package/relations.js.map +1 -1
  1496. package/selection-proxy.cjs +4 -3
  1497. package/selection-proxy.cjs.map +1 -1
  1498. package/selection-proxy.js +5 -4
  1499. package/selection-proxy.js.map +1 -1
  1500. package/singlestore/driver.cjs +19 -26
  1501. package/singlestore/driver.cjs.map +1 -1
  1502. package/singlestore/driver.d.cts +3 -3
  1503. package/singlestore/driver.d.ts +3 -3
  1504. package/singlestore/driver.js +19 -26
  1505. package/singlestore/driver.js.map +1 -1
  1506. package/singlestore/session.cjs.map +1 -1
  1507. package/singlestore/session.js.map +1 -1
  1508. package/singlestore-core/columns/bigint.cjs.map +1 -1
  1509. package/singlestore-core/columns/bigint.d.cts +0 -3
  1510. package/singlestore-core/columns/bigint.d.ts +0 -3
  1511. package/singlestore-core/columns/bigint.js.map +1 -1
  1512. package/singlestore-core/columns/binary.cjs +0 -1
  1513. package/singlestore-core/columns/binary.cjs.map +1 -1
  1514. package/singlestore-core/columns/binary.d.cts +0 -2
  1515. package/singlestore-core/columns/binary.d.ts +0 -2
  1516. package/singlestore-core/columns/binary.js +0 -1
  1517. package/singlestore-core/columns/binary.js.map +1 -1
  1518. package/singlestore-core/columns/boolean.cjs.map +1 -1
  1519. package/singlestore-core/columns/boolean.d.cts +0 -1
  1520. package/singlestore-core/columns/boolean.d.ts +0 -1
  1521. package/singlestore-core/columns/boolean.js.map +1 -1
  1522. package/singlestore-core/columns/char.cjs +0 -1
  1523. package/singlestore-core/columns/char.cjs.map +1 -1
  1524. package/singlestore-core/columns/char.d.cts +0 -2
  1525. package/singlestore-core/columns/char.d.ts +0 -2
  1526. package/singlestore-core/columns/char.js +0 -1
  1527. package/singlestore-core/columns/char.js.map +1 -1
  1528. package/singlestore-core/columns/common.cjs +0 -4
  1529. package/singlestore-core/columns/common.cjs.map +1 -1
  1530. package/singlestore-core/columns/common.d.cts +1 -1
  1531. package/singlestore-core/columns/common.d.ts +1 -1
  1532. package/singlestore-core/columns/common.js +0 -4
  1533. package/singlestore-core/columns/common.js.map +1 -1
  1534. package/singlestore-core/columns/custom.cjs.map +1 -1
  1535. package/singlestore-core/columns/custom.d.cts +0 -1
  1536. package/singlestore-core/columns/custom.d.ts +0 -1
  1537. package/singlestore-core/columns/custom.js.map +1 -1
  1538. package/singlestore-core/columns/date.cjs.map +1 -1
  1539. package/singlestore-core/columns/date.d.cts +0 -2
  1540. package/singlestore-core/columns/date.d.ts +0 -2
  1541. package/singlestore-core/columns/date.js.map +1 -1
  1542. package/singlestore-core/columns/datetime.cjs.map +1 -1
  1543. package/singlestore-core/columns/datetime.d.cts +0 -2
  1544. package/singlestore-core/columns/datetime.d.ts +0 -2
  1545. package/singlestore-core/columns/datetime.js.map +1 -1
  1546. package/singlestore-core/columns/decimal.cjs.map +1 -1
  1547. package/singlestore-core/columns/decimal.d.cts +0 -3
  1548. package/singlestore-core/columns/decimal.d.ts +0 -3
  1549. package/singlestore-core/columns/decimal.js.map +1 -1
  1550. package/singlestore-core/columns/double.cjs.map +1 -1
  1551. package/singlestore-core/columns/double.d.cts +0 -1
  1552. package/singlestore-core/columns/double.d.ts +0 -1
  1553. package/singlestore-core/columns/double.js.map +1 -1
  1554. package/singlestore-core/columns/enum.cjs.map +1 -1
  1555. package/singlestore-core/columns/enum.d.cts +0 -1
  1556. package/singlestore-core/columns/enum.d.ts +0 -1
  1557. package/singlestore-core/columns/enum.js.map +1 -1
  1558. package/singlestore-core/columns/float.cjs.map +1 -1
  1559. package/singlestore-core/columns/float.d.cts +0 -1
  1560. package/singlestore-core/columns/float.d.ts +0 -1
  1561. package/singlestore-core/columns/float.js.map +1 -1
  1562. package/singlestore-core/columns/int.cjs.map +1 -1
  1563. package/singlestore-core/columns/int.d.cts +0 -1
  1564. package/singlestore-core/columns/int.d.ts +0 -1
  1565. package/singlestore-core/columns/int.js.map +1 -1
  1566. package/singlestore-core/columns/json.cjs.map +1 -1
  1567. package/singlestore-core/columns/json.d.cts +0 -1
  1568. package/singlestore-core/columns/json.d.ts +0 -1
  1569. package/singlestore-core/columns/json.js.map +1 -1
  1570. package/singlestore-core/columns/mediumint.cjs.map +1 -1
  1571. package/singlestore-core/columns/mediumint.d.cts +0 -1
  1572. package/singlestore-core/columns/mediumint.d.ts +0 -1
  1573. package/singlestore-core/columns/mediumint.js.map +1 -1
  1574. package/singlestore-core/columns/real.cjs.map +1 -1
  1575. package/singlestore-core/columns/real.d.cts +0 -1
  1576. package/singlestore-core/columns/real.d.ts +0 -1
  1577. package/singlestore-core/columns/real.js.map +1 -1
  1578. package/singlestore-core/columns/serial.cjs.map +1 -1
  1579. package/singlestore-core/columns/serial.d.cts +0 -1
  1580. package/singlestore-core/columns/serial.d.ts +0 -1
  1581. package/singlestore-core/columns/serial.js.map +1 -1
  1582. package/singlestore-core/columns/smallint.cjs.map +1 -1
  1583. package/singlestore-core/columns/smallint.d.cts +0 -1
  1584. package/singlestore-core/columns/smallint.d.ts +0 -1
  1585. package/singlestore-core/columns/smallint.js.map +1 -1
  1586. package/singlestore-core/columns/text.cjs.map +1 -1
  1587. package/singlestore-core/columns/text.d.cts +0 -1
  1588. package/singlestore-core/columns/text.d.ts +0 -1
  1589. package/singlestore-core/columns/text.js.map +1 -1
  1590. package/singlestore-core/columns/time.cjs.map +1 -1
  1591. package/singlestore-core/columns/time.d.cts +0 -1
  1592. package/singlestore-core/columns/time.d.ts +0 -1
  1593. package/singlestore-core/columns/time.js.map +1 -1
  1594. package/singlestore-core/columns/timestamp.cjs.map +1 -1
  1595. package/singlestore-core/columns/timestamp.d.cts +0 -2
  1596. package/singlestore-core/columns/timestamp.d.ts +0 -2
  1597. package/singlestore-core/columns/timestamp.js.map +1 -1
  1598. package/singlestore-core/columns/tinyint.cjs.map +1 -1
  1599. package/singlestore-core/columns/tinyint.d.cts +0 -1
  1600. package/singlestore-core/columns/tinyint.d.ts +0 -1
  1601. package/singlestore-core/columns/tinyint.js.map +1 -1
  1602. package/singlestore-core/columns/varbinary.cjs.map +1 -1
  1603. package/singlestore-core/columns/varbinary.d.cts +0 -1
  1604. package/singlestore-core/columns/varbinary.d.ts +0 -1
  1605. package/singlestore-core/columns/varbinary.js.map +1 -1
  1606. package/singlestore-core/columns/varchar.cjs.map +1 -1
  1607. package/singlestore-core/columns/varchar.d.cts +0 -1
  1608. package/singlestore-core/columns/varchar.d.ts +0 -1
  1609. package/singlestore-core/columns/varchar.js.map +1 -1
  1610. package/singlestore-core/columns/vector.cjs.map +1 -1
  1611. package/singlestore-core/columns/vector.d.cts +0 -2
  1612. package/singlestore-core/columns/vector.d.ts +0 -2
  1613. package/singlestore-core/columns/vector.js.map +1 -1
  1614. package/singlestore-core/columns/year.cjs.map +1 -1
  1615. package/singlestore-core/columns/year.d.cts +0 -1
  1616. package/singlestore-core/columns/year.d.ts +0 -1
  1617. package/singlestore-core/columns/year.js.map +1 -1
  1618. package/singlestore-core/dialect.cjs +4 -2
  1619. package/singlestore-core/dialect.cjs.map +1 -1
  1620. package/singlestore-core/dialect.js +11 -3
  1621. package/singlestore-core/dialect.js.map +1 -1
  1622. package/singlestore-core/indexes.cjs +2 -0
  1623. package/singlestore-core/indexes.cjs.map +1 -1
  1624. package/singlestore-core/indexes.d.cts +1 -0
  1625. package/singlestore-core/indexes.d.ts +1 -0
  1626. package/singlestore-core/indexes.js +2 -0
  1627. package/singlestore-core/indexes.js.map +1 -1
  1628. package/singlestore-core/primary-keys.cjs +2 -0
  1629. package/singlestore-core/primary-keys.cjs.map +1 -1
  1630. package/singlestore-core/primary-keys.d.cts +1 -0
  1631. package/singlestore-core/primary-keys.d.ts +1 -0
  1632. package/singlestore-core/primary-keys.js +2 -0
  1633. package/singlestore-core/primary-keys.js.map +1 -1
  1634. package/singlestore-core/query-builders/count.cjs.map +1 -1
  1635. package/singlestore-core/query-builders/count.d.cts +1 -1
  1636. package/singlestore-core/query-builders/count.d.ts +1 -1
  1637. package/singlestore-core/query-builders/count.js.map +1 -1
  1638. package/singlestore-core/query-builders/insert.cjs.map +1 -1
  1639. package/singlestore-core/query-builders/insert.d.cts +1 -1
  1640. package/singlestore-core/query-builders/insert.d.ts +1 -1
  1641. package/singlestore-core/query-builders/insert.js.map +1 -1
  1642. package/singlestore-core/query-builders/update.cjs.map +1 -1
  1643. package/singlestore-core/query-builders/update.d.cts +1 -1
  1644. package/singlestore-core/query-builders/update.d.ts +1 -1
  1645. package/singlestore-core/query-builders/update.js.map +1 -1
  1646. package/singlestore-core/unique-constraint.cjs +2 -0
  1647. package/singlestore-core/unique-constraint.cjs.map +1 -1
  1648. package/singlestore-core/unique-constraint.d.cts +3 -2
  1649. package/singlestore-core/unique-constraint.d.ts +3 -2
  1650. package/singlestore-core/unique-constraint.js +2 -0
  1651. package/singlestore-core/unique-constraint.js.map +1 -1
  1652. package/sql/sql.cjs +11 -10
  1653. package/sql/sql.cjs.map +1 -1
  1654. package/sql/sql.d.cts +3 -3
  1655. package/sql/sql.d.ts +3 -3
  1656. package/sql/sql.js +11 -10
  1657. package/sql/sql.js.map +1 -1
  1658. package/sql-js/session.cjs.map +1 -1
  1659. package/sql-js/session.js.map +1 -1
  1660. package/sqlite-cloud/driver.cjs +6 -10
  1661. package/sqlite-cloud/driver.cjs.map +1 -1
  1662. package/sqlite-cloud/driver.d.cts +3 -3
  1663. package/sqlite-cloud/driver.d.ts +3 -3
  1664. package/sqlite-cloud/driver.js +6 -10
  1665. package/sqlite-cloud/driver.js.map +1 -1
  1666. package/sqlite-core/columns/blob.cjs.map +1 -1
  1667. package/sqlite-core/columns/blob.d.cts +0 -3
  1668. package/sqlite-core/columns/blob.d.ts +0 -3
  1669. package/sqlite-core/columns/blob.js.map +1 -1
  1670. package/sqlite-core/columns/common.cjs +0 -4
  1671. package/sqlite-core/columns/common.cjs.map +1 -1
  1672. package/sqlite-core/columns/common.js +0 -4
  1673. package/sqlite-core/columns/common.js.map +1 -1
  1674. package/sqlite-core/columns/custom.cjs.map +1 -1
  1675. package/sqlite-core/columns/custom.d.cts +0 -1
  1676. package/sqlite-core/columns/custom.d.ts +0 -1
  1677. package/sqlite-core/columns/custom.js.map +1 -1
  1678. package/sqlite-core/columns/integer.cjs.map +1 -1
  1679. package/sqlite-core/columns/integer.d.cts +0 -3
  1680. package/sqlite-core/columns/integer.d.ts +0 -3
  1681. package/sqlite-core/columns/integer.js.map +1 -1
  1682. package/sqlite-core/columns/numeric.cjs.map +1 -1
  1683. package/sqlite-core/columns/numeric.d.cts +0 -3
  1684. package/sqlite-core/columns/numeric.d.ts +0 -3
  1685. package/sqlite-core/columns/numeric.js.map +1 -1
  1686. package/sqlite-core/columns/real.cjs.map +1 -1
  1687. package/sqlite-core/columns/real.d.cts +0 -1
  1688. package/sqlite-core/columns/real.d.ts +0 -1
  1689. package/sqlite-core/columns/real.js.map +1 -1
  1690. package/sqlite-core/columns/text.cjs.map +1 -1
  1691. package/sqlite-core/columns/text.d.cts +0 -2
  1692. package/sqlite-core/columns/text.d.ts +0 -2
  1693. package/sqlite-core/columns/text.js.map +1 -1
  1694. package/sqlite-core/dialect.cjs +8 -5
  1695. package/sqlite-core/dialect.cjs.map +1 -1
  1696. package/sqlite-core/dialect.js +15 -6
  1697. package/sqlite-core/dialect.js.map +1 -1
  1698. package/sqlite-core/foreign-keys.cjs +3 -0
  1699. package/sqlite-core/foreign-keys.cjs.map +1 -1
  1700. package/sqlite-core/foreign-keys.d.cts +1 -14
  1701. package/sqlite-core/foreign-keys.d.ts +1 -14
  1702. package/sqlite-core/foreign-keys.js +3 -0
  1703. package/sqlite-core/foreign-keys.js.map +1 -1
  1704. package/sqlite-core/indexes.cjs +2 -0
  1705. package/sqlite-core/indexes.cjs.map +1 -1
  1706. package/sqlite-core/indexes.d.cts +1 -0
  1707. package/sqlite-core/indexes.d.ts +1 -0
  1708. package/sqlite-core/indexes.js +2 -0
  1709. package/sqlite-core/indexes.js.map +1 -1
  1710. package/sqlite-core/primary-keys.cjs +2 -0
  1711. package/sqlite-core/primary-keys.cjs.map +1 -1
  1712. package/sqlite-core/primary-keys.d.cts +1 -0
  1713. package/sqlite-core/primary-keys.d.ts +1 -0
  1714. package/sqlite-core/primary-keys.js +2 -0
  1715. package/sqlite-core/primary-keys.js.map +1 -1
  1716. package/sqlite-core/query-builders/count.cjs.map +1 -1
  1717. package/sqlite-core/query-builders/count.d.cts +1 -1
  1718. package/sqlite-core/query-builders/count.d.ts +1 -1
  1719. package/sqlite-core/query-builders/count.js.map +1 -1
  1720. package/sqlite-core/query-builders/insert.cjs.map +1 -1
  1721. package/sqlite-core/query-builders/insert.d.cts +2 -2
  1722. package/sqlite-core/query-builders/insert.d.ts +2 -2
  1723. package/sqlite-core/query-builders/insert.js.map +1 -1
  1724. package/sqlite-core/query-builders/update.cjs.map +1 -1
  1725. package/sqlite-core/query-builders/update.d.cts +1 -1
  1726. package/sqlite-core/query-builders/update.d.ts +1 -1
  1727. package/sqlite-core/query-builders/update.js.map +1 -1
  1728. package/sqlite-core/unique-constraint.cjs +2 -0
  1729. package/sqlite-core/unique-constraint.cjs.map +1 -1
  1730. package/sqlite-core/unique-constraint.d.cts +3 -2
  1731. package/sqlite-core/unique-constraint.d.ts +3 -2
  1732. package/sqlite-core/unique-constraint.js +2 -0
  1733. package/sqlite-core/unique-constraint.js.map +1 -1
  1734. package/sqlite-proxy/session.cjs +0 -1
  1735. package/sqlite-proxy/session.cjs.map +1 -1
  1736. package/sqlite-proxy/session.js +0 -1
  1737. package/sqlite-proxy/session.js.map +1 -1
  1738. package/table.cjs +0 -1
  1739. package/table.cjs.map +1 -1
  1740. package/table.d.cts +2 -3
  1741. package/table.d.ts +2 -3
  1742. package/table.js +0 -1
  1743. package/table.js.map +1 -1
  1744. package/tidb-serverless/driver.cjs +8 -12
  1745. package/tidb-serverless/driver.cjs.map +1 -1
  1746. package/tidb-serverless/driver.d.cts +3 -3
  1747. package/tidb-serverless/driver.d.ts +3 -3
  1748. package/tidb-serverless/driver.js +8 -12
  1749. package/tidb-serverless/driver.js.map +1 -1
  1750. package/tracing.cjs +1 -1
  1751. package/tracing.cjs.map +1 -1
  1752. package/tracing.js +1 -1
  1753. package/tracing.js.map +1 -1
  1754. package/tursodatabase/database.cjs +6 -10
  1755. package/tursodatabase/database.cjs.map +1 -1
  1756. package/tursodatabase/database.d.cts +3 -3
  1757. package/tursodatabase/database.d.ts +3 -3
  1758. package/tursodatabase/database.js +6 -10
  1759. package/tursodatabase/database.js.map +1 -1
  1760. package/tursodatabase/session.cjs +0 -2
  1761. package/tursodatabase/session.cjs.map +1 -1
  1762. package/tursodatabase/session.js +0 -2
  1763. package/tursodatabase/session.js.map +1 -1
  1764. package/tursodatabase/wasm.cjs +6 -10
  1765. package/tursodatabase/wasm.cjs.map +1 -1
  1766. package/tursodatabase/wasm.d.cts +3 -3
  1767. package/tursodatabase/wasm.d.ts +3 -3
  1768. package/tursodatabase/wasm.js +6 -10
  1769. package/tursodatabase/wasm.js.map +1 -1
  1770. package/vercel-postgres/session.cjs.map +1 -1
  1771. package/vercel-postgres/session.js.map +1 -1
  1772. package/version.cjs +2 -2
  1773. package/version.cjs.map +1 -1
  1774. package/version.d.cts +2 -2
  1775. package/version.d.ts +2 -2
  1776. package/version.js +2 -2
  1777. package/version.js.map +1 -1
@@ -2,7 +2,6 @@ import type { ColumnBaseConfig } from "../../column.cjs";
2
2
  import { entityKind } from "../../entity.cjs";
3
3
  import { MySqlColumn, MySqlColumnBuilder } from "./common.cjs";
4
4
  export declare class MySqlYearBuilder extends MySqlColumnBuilder<{
5
- name: string;
6
5
  dataType: 'number year';
7
6
  data: number;
8
7
  driverParam: number;
@@ -2,7 +2,6 @@ import type { ColumnBaseConfig } from "../../column.js";
2
2
  import { entityKind } from "../../entity.js";
3
3
  import { MySqlColumn, MySqlColumnBuilder } from "./common.js";
4
4
  export declare class MySqlYearBuilder extends MySqlColumnBuilder<{
5
- name: string;
6
5
  dataType: 'number year';
7
6
  data: number;
8
7
  driverParam: number;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/mysql-core/columns/year.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { MySqlTable } from '~/mysql-core/table.ts';\nimport { MySqlColumn, MySqlColumnBuilder } from './common.ts';\n\nexport class MySqlYearBuilder extends MySqlColumnBuilder<{\n\tname: string;\n\tdataType: 'number year';\n\tdata: number;\n\tdriverParam: number;\n}> {\n\tstatic override readonly [entityKind]: string = 'MySqlYearBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'number year', 'MySqlYear');\n\t}\n\n\t/** @internal */\n\toverride build(table: MySqlTable) {\n\t\treturn new MySqlYear(table, this.config as any);\n\t}\n}\n\nexport class MySqlYear<\n\tT extends ColumnBaseConfig<'number year'>,\n> extends MySqlColumn<T> {\n\tstatic override readonly [entityKind]: string = 'MySqlYear';\n\n\tgetSQLType(): string {\n\t\treturn `year`;\n\t}\n\n\toverride mapFromDriverValue(value: number | string): number {\n\t\tif (typeof value === 'number') return value;\n\n\t\treturn Number(value);\n\t}\n}\n\nexport function year(name?: string): MySqlYearBuilder {\n\treturn new MySqlYearBuilder(name ?? '');\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAE3B,SAAS,aAAa,0BAA0B;AAEzC,MAAM,yBAAyB,mBAKnC;AAAA,EACF,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,eAAe,WAAW;AAAA,EACvC;AAAA;AAAA,EAGS,MAAM,OAAmB;AACjC,WAAO,IAAI,UAAU,OAAO,KAAK,MAAa;AAAA,EAC/C;AACD;AAEO,MAAM,kBAEH,YAAe;AAAA,EACxB,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAgC;AAC3D,QAAI,OAAO,UAAU,SAAU,QAAO;AAEtC,WAAO,OAAO,KAAK;AAAA,EACpB;AACD;AAEO,SAAS,KAAK,MAAiC;AACrD,SAAO,IAAI,iBAAiB,QAAQ,EAAE;AACvC;","names":[]}
1
+ {"version":3,"sources":["../../../src/mysql-core/columns/year.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { MySqlTable } from '~/mysql-core/table.ts';\nimport { MySqlColumn, MySqlColumnBuilder } from './common.ts';\n\nexport class MySqlYearBuilder extends MySqlColumnBuilder<{\n\tdataType: 'number year';\n\tdata: number;\n\tdriverParam: number;\n}> {\n\tstatic override readonly [entityKind]: string = 'MySqlYearBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'number year', 'MySqlYear');\n\t}\n\n\t/** @internal */\n\toverride build(table: MySqlTable) {\n\t\treturn new MySqlYear(table, this.config as any);\n\t}\n}\n\nexport class MySqlYear<\n\tT extends ColumnBaseConfig<'number year'>,\n> extends MySqlColumn<T> {\n\tstatic override readonly [entityKind]: string = 'MySqlYear';\n\n\tgetSQLType(): string {\n\t\treturn `year`;\n\t}\n\n\toverride mapFromDriverValue(value: number | string): number {\n\t\tif (typeof value === 'number') return value;\n\n\t\treturn Number(value);\n\t}\n}\n\nexport function year(name?: string): MySqlYearBuilder {\n\treturn new MySqlYearBuilder(name ?? '');\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAE3B,SAAS,aAAa,0BAA0B;AAEzC,MAAM,yBAAyB,mBAInC;AAAA,EACF,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,eAAe,WAAW;AAAA,EACvC;AAAA;AAAA,EAGS,MAAM,OAAmB;AACjC,WAAO,IAAI,UAAU,OAAO,KAAK,MAAa;AAAA,EAC/C;AACD;AAEO,MAAM,kBAEH,YAAe;AAAA,EACxB,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAgC;AAC3D,QAAI,OAAO,UAAU,SAAU,QAAO;AAEtC,WAAO,OAAO,KAAK;AAAA,EACpB;AACD;AAEO,SAAS,KAAK,MAAiC;AACrD,SAAO,IAAI,iBAAiB,QAAQ,EAAE;AACvC;","names":[]}
@@ -53,6 +53,9 @@ class MySqlDialect {
53
53
  casing;
54
54
  constructor(config) {
55
55
  this.casing = new import_casing.CasingCache(config?.casing);
56
+ if (config?.escapeParam) {
57
+ this.escapeParam = config.escapeParam;
58
+ }
56
59
  }
57
60
  async migrate(migrations, session, config) {
58
61
  const migrationsTable = config.migrationsTable ?? "__drizzle_migrations";
@@ -188,9 +191,11 @@ class MySqlDialect {
188
191
  }
189
192
  } else if ((0, import_entity.is)(field, import_column.Column)) {
190
193
  if (isSingleTable) {
191
- chunk.push(import_sql.sql.identifier(this.casing.getColumnCasing(field)));
194
+ chunk.push(
195
+ field.isAlias ? import_sql.sql`${import_sql.sql.identifier(this.casing.getColumnCasing((0, import_alias.getOriginalColumnFromAlias)(field)))} as ${field}` : import_sql.sql.identifier(this.casing.getColumnCasing(field))
196
+ );
192
197
  } else {
193
- chunk.push(field);
198
+ chunk.push(field.isAlias ? import_sql.sql`${(0, import_alias.getOriginalColumnFromAlias)(field)} as ${field}` : field);
194
199
  }
195
200
  } else if ((0, import_entity.is)(field, import_subquery.Subquery)) {
196
201
  const entries = Object.entries(field._.selectedFields);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/mysql-core/dialect.ts"],"sourcesContent":["import * as V1 from '~/_relations.ts';\nimport { aliasedTable, aliasedTableColumn, mapColumnsInAliasedSQLToAlias, mapColumnsInSQLToAlias } from '~/alias.ts';\nimport { CasingCache } from '~/casing.ts';\nimport { Column } from '~/column.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { DrizzleError } from '~/errors.ts';\nimport type { MigrationConfig, MigrationMeta, MigratorInitFailResponse } from '~/migrator.ts';\nimport type {\n\tAnyOne,\n\tBuildRelationalQueryResult,\n\tColumnWithTSName,\n\tDBQueryConfig,\n\tRelation,\n\tTableRelationalConfig,\n\tTablesRelationalConfig,\n\tWithContainer,\n} from '~/relations.ts';\nimport {\n\t// AggregatedField,\n\tgetTableAsAliasSQL,\n\tOne,\n\trelationExtrasToSQL,\n\trelationsFilterToSQL,\n\trelationsOrderToSQL,\n\trelationToSQL,\n} from '~/relations.ts';\nimport { and, eq } from '~/sql/expressions/index.ts';\nimport { isSQLWrapper, Param, SQL, sql, View } from '~/sql/sql.ts';\nimport type { Name, Placeholder, QueryWithTypings, SQLChunk, SQLWrapper } from '~/sql/sql.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { getTableName, getTableUniqueName, Table, TableColumns } from '~/table.ts';\nimport { type Casing, orderSelectedFields, type UpdateSet } from '~/utils.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport { MySqlColumn } from './columns/common.ts';\nimport type { MySqlCustomColumn } from './columns/custom.ts';\nimport type { MySqlDeleteConfig } from './query-builders/delete.ts';\nimport type { MySqlInsertConfig } from './query-builders/insert.ts';\nimport type {\n\tAnyMySqlSelectQueryBuilder,\n\tMySqlSelectConfig,\n\tMySqlSelectJoinConfig,\n\tSelectedFieldsOrdered,\n} from './query-builders/select.types.ts';\nimport type { MySqlUpdateConfig } from './query-builders/update.ts';\nimport type { MySqlSession } from './session.ts';\nimport { MySqlTable } from './table.ts';\nimport { MySqlViewBase } from './view-base.ts';\nimport type { MySqlView } from './view.ts';\n\nexport interface MySqlDialectConfig {\n\tcasing?: Casing;\n}\n\nexport class MySqlDialect {\n\tstatic readonly [entityKind]: string = 'MySqlDialect';\n\n\t/** @internal */\n\treadonly casing: CasingCache;\n\n\tconstructor(config?: MySqlDialectConfig) {\n\t\tthis.casing = new CasingCache(config?.casing);\n\t}\n\n\tasync migrate(\n\t\tmigrations: MigrationMeta[],\n\t\tsession: MySqlSession,\n\t\tconfig: Omit<MigrationConfig, 'migrationsSchema'>,\n\t): Promise<void | MigratorInitFailResponse> {\n\t\tconst migrationsTable = config.migrationsTable ?? '__drizzle_migrations';\n\t\tconst migrationTableCreate = sql`\n\t\t\tcreate table if not exists ${sql.identifier(migrationsTable)} (\n\t\t\t\tid serial primary key,\n\t\t\t\thash text not null,\n\t\t\t\tcreated_at bigint\n\t\t\t)\n\t\t`;\n\t\tawait session.execute(migrationTableCreate);\n\n\t\tconst dbMigrations = await session.all<{ id: number; hash: string; created_at: string }>(\n\t\t\tsql`select id, hash, created_at from ${sql.identifier(migrationsTable)} order by created_at desc limit 1`,\n\t\t);\n\n\t\tif (typeof config === 'object' && config.init) {\n\t\t\tif (dbMigrations.length) {\n\t\t\t\treturn { exitCode: 'databaseMigrations' as const };\n\t\t\t}\n\n\t\t\tif (migrations.length > 1) {\n\t\t\t\treturn { exitCode: 'localMigrations' as const };\n\t\t\t}\n\n\t\t\tconst [migration] = migrations;\n\n\t\t\tif (!migration) return;\n\n\t\t\tawait session.execute(\n\t\t\t\tsql`insert into ${\n\t\t\t\t\tsql.identifier(migrationsTable)\n\t\t\t\t} (\\`hash\\`, \\`created_at\\`) values(${migration.hash}, ${migration.folderMillis})`,\n\t\t\t);\n\n\t\t\treturn;\n\t\t}\n\n\t\tconst lastDbMigration = dbMigrations[0];\n\t\tawait session.transaction(async (tx) => {\n\t\t\tfor (const migration of migrations) {\n\t\t\t\tif (\n\t\t\t\t\t!lastDbMigration\n\t\t\t\t\t|| Number(lastDbMigration.created_at) < migration.folderMillis\n\t\t\t\t) {\n\t\t\t\t\tfor (const stmt of migration.sql) {\n\t\t\t\t\t\tawait tx.execute(sql.raw(stmt));\n\t\t\t\t\t}\n\t\t\t\t\tawait tx.execute(\n\t\t\t\t\t\tsql`insert into ${\n\t\t\t\t\t\t\tsql.identifier(migrationsTable)\n\t\t\t\t\t\t} (\\`hash\\`, \\`created_at\\`) values(${migration.hash}, ${migration.folderMillis})`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\n\tescapeName(name: string): string {\n\t\treturn `\\`${name}\\``;\n\t}\n\n\tescapeParam(_num: number): string {\n\t\treturn `?`;\n\t}\n\n\tescapeString(str: string): string {\n\t\treturn `'${str.replace(/'/g, \"''\")}'`;\n\t}\n\n\tprivate buildWithCTE(queries: Subquery[] | undefined): SQL | undefined {\n\t\tif (!queries?.length) return undefined;\n\n\t\tconst withSqlChunks = [sql`with `];\n\t\tfor (const [i, w] of queries.entries()) {\n\t\t\twithSqlChunks.push(sql`${sql.identifier(w._.alias)} as (${w._.sql})`);\n\t\t\tif (i < queries.length - 1) {\n\t\t\t\twithSqlChunks.push(sql`, `);\n\t\t\t}\n\t\t}\n\t\twithSqlChunks.push(sql` `);\n\t\treturn sql.join(withSqlChunks);\n\t}\n\n\tbuildDeleteQuery({ table, where, returning, withList, limit, orderBy }: MySqlDeleteConfig): SQL {\n\t\tconst withSql = this.buildWithCTE(withList);\n\n\t\tconst returningSql = returning\n\t\t\t? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}`\n\t\t\t: undefined;\n\n\t\tconst whereSql = where ? sql` where ${where}` : undefined;\n\n\t\tconst orderBySql = this.buildOrderBy(orderBy);\n\n\t\tconst limitSql = this.buildLimit(limit);\n\n\t\treturn sql`${withSql}delete from ${table}${whereSql}${orderBySql}${limitSql}${returningSql}`;\n\t}\n\n\tbuildUpdateSet(table: MySqlTable, set: UpdateSet): SQL {\n\t\tconst tableColumns = table[Table.Symbol.Columns];\n\n\t\tconst columnNames = Object.keys(tableColumns).filter((colName) =>\n\t\t\tset[colName] !== undefined || tableColumns[colName]?.onUpdateFn !== undefined\n\t\t);\n\n\t\tconst setLength = columnNames.length;\n\t\treturn sql.join(columnNames.flatMap((colName, i) => {\n\t\t\tconst col = tableColumns[colName]!;\n\n\t\t\tconst onUpdateFnResult = col.onUpdateFn?.();\n\t\t\tconst value = set[colName] ?? (is(onUpdateFnResult, SQL) ? onUpdateFnResult : sql.param(onUpdateFnResult, col));\n\t\t\tconst res = sql`${sql.identifier(this.casing.getColumnCasing(col))} = ${value}`;\n\n\t\t\tif (i < setLength - 1) {\n\t\t\t\treturn [res, sql.raw(', ')];\n\t\t\t}\n\t\t\treturn [res];\n\t\t}));\n\t}\n\n\tbuildUpdateQuery({ table, set, where, returning, withList, limit, orderBy }: MySqlUpdateConfig): SQL {\n\t\tconst withSql = this.buildWithCTE(withList);\n\n\t\tconst setSql = this.buildUpdateSet(table, set);\n\n\t\tconst returningSql = returning\n\t\t\t? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}`\n\t\t\t: undefined;\n\n\t\tconst whereSql = where ? sql` where ${where}` : undefined;\n\n\t\tconst orderBySql = this.buildOrderBy(orderBy);\n\n\t\tconst limitSql = this.buildLimit(limit);\n\n\t\treturn sql`${withSql}update ${table} set ${setSql}${whereSql}${orderBySql}${limitSql}${returningSql}`;\n\t}\n\n\t/**\n\t * Builds selection SQL with provided fields/expressions\n\t *\n\t * Examples:\n\t *\n\t * `select <selection> from`\n\t *\n\t * `insert ... returning <selection>`\n\t *\n\t * If `isSingleTable` is true, then columns won't be prefixed with table name\n\t */\n\tprivate buildSelection(\n\t\tfields: SelectedFieldsOrdered,\n\t\t{ isSingleTable = false }: { isSingleTable?: boolean } = {},\n\t): SQL {\n\t\tconst columnsLen = fields.length;\n\n\t\tconst chunks = fields\n\t\t\t.flatMap(({ field }, i) => {\n\t\t\t\tconst chunk: SQLChunk[] = [];\n\n\t\t\t\tif (is(field, SQL.Aliased) && field.isSelectionField) {\n\t\t\t\t\tchunk.push(sql.identifier(field.fieldAlias));\n\t\t\t\t} else if (is(field, SQL.Aliased) || is(field, SQL)) {\n\t\t\t\t\tconst query = is(field, SQL.Aliased) ? field.sql : field;\n\n\t\t\t\t\tif (isSingleTable) {\n\t\t\t\t\t\tchunk.push(\n\t\t\t\t\t\t\tnew SQL(\n\t\t\t\t\t\t\t\tquery.queryChunks.map((c) => {\n\t\t\t\t\t\t\t\t\tif (is(c, MySqlColumn)) {\n\t\t\t\t\t\t\t\t\t\treturn sql.identifier(this.casing.getColumnCasing(c));\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\treturn c;\n\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tchunk.push(query);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (is(field, SQL.Aliased)) {\n\t\t\t\t\t\tchunk.push(sql` as ${sql.identifier(field.fieldAlias)}`);\n\t\t\t\t\t}\n\t\t\t\t} else if (is(field, Column)) {\n\t\t\t\t\tif (isSingleTable) {\n\t\t\t\t\t\tchunk.push(sql.identifier(this.casing.getColumnCasing(field)));\n\t\t\t\t\t} else {\n\t\t\t\t\t\tchunk.push(field);\n\t\t\t\t\t}\n\t\t\t\t} else if (is(field, Subquery)) {\n\t\t\t\t\tconst entries = Object.entries(field._.selectedFields) as [string, SQL.Aliased | Column | SQL][];\n\n\t\t\t\t\tif (entries.length === 1) {\n\t\t\t\t\t\tconst entry = entries[0]![1];\n\n\t\t\t\t\t\tconst fieldDecoder = is(entry, SQL)\n\t\t\t\t\t\t\t? entry.decoder\n\t\t\t\t\t\t\t: is(entry, Column)\n\t\t\t\t\t\t\t? { mapFromDriverValue: (v: any) => entry.mapFromDriverValue(v) }\n\t\t\t\t\t\t\t: entry.sql.decoder;\n\n\t\t\t\t\t\tif (fieldDecoder) {\n\t\t\t\t\t\t\tfield._.sql.decoder = fieldDecoder;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tchunk.push(field);\n\t\t\t\t}\n\n\t\t\t\tif (i < columnsLen - 1) {\n\t\t\t\t\tchunk.push(sql`, `);\n\t\t\t\t}\n\n\t\t\t\treturn chunk;\n\t\t\t});\n\n\t\treturn sql.join(chunks);\n\t}\n\n\tprivate buildLimit(limit: number | Placeholder | undefined): SQL | undefined {\n\t\treturn typeof limit === 'object' || (typeof limit === 'number' && limit >= 0)\n\t\t\t? sql` limit ${limit}`\n\t\t\t: undefined;\n\t}\n\n\tprivate buildOrderBy(orderBy: (MySqlColumn | SQL | SQL.Aliased)[] | undefined): SQL | undefined {\n\t\treturn orderBy && orderBy.length > 0 ? sql` order by ${sql.join(orderBy, sql`, `)}` : undefined;\n\t}\n\n\tprivate buildIndex({\n\t\tindexes,\n\t\tindexFor,\n\t}: {\n\t\tindexes: string[] | undefined;\n\t\tindexFor: 'USE' | 'FORCE' | 'IGNORE';\n\t}): SQL | undefined {\n\t\treturn indexes && indexes.length > 0\n\t\t\t? sql` ${sql.raw(indexFor)} INDEX (${sql.raw(indexes.join(`, `))})`\n\t\t\t: undefined;\n\t}\n\n\tbuildSelectQuery(\n\t\t{\n\t\t\twithList,\n\t\t\tfields,\n\t\t\tfieldsFlat,\n\t\t\twhere,\n\t\t\thaving,\n\t\t\ttable,\n\t\t\tjoins,\n\t\t\torderBy,\n\t\t\tgroupBy,\n\t\t\tlimit,\n\t\t\toffset,\n\t\t\tlockingClause,\n\t\t\tdistinct,\n\t\t\tsetOperators,\n\t\t\tuseIndex,\n\t\t\tforceIndex,\n\t\t\tignoreIndex,\n\t\t}: MySqlSelectConfig,\n\t): SQL {\n\t\tconst fieldsList = fieldsFlat ?? orderSelectedFields<MySqlColumn>(fields);\n\t\tfor (const f of fieldsList) {\n\t\t\tif (\n\t\t\t\tis(f.field, Column)\n\t\t\t\t&& getTableName(f.field.table)\n\t\t\t\t\t!== (is(table, Subquery)\n\t\t\t\t\t\t? table._.alias\n\t\t\t\t\t\t: is(table, MySqlViewBase)\n\t\t\t\t\t\t? table[ViewBaseConfig].name\n\t\t\t\t\t\t: is(table, SQL)\n\t\t\t\t\t\t? undefined\n\t\t\t\t\t\t: getTableName(table))\n\t\t\t\t&& !((table) =>\n\t\t\t\t\tjoins?.some(({ alias }) =>\n\t\t\t\t\t\talias === (table[Table.Symbol.IsAlias] ? getTableName(table) : table[Table.Symbol.BaseName])\n\t\t\t\t\t))(f.field.table)\n\t\t\t) {\n\t\t\t\tconst tableName = getTableName(f.field.table);\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`Your \"${\n\t\t\t\t\t\tf.path.join('->')\n\t\t\t\t\t}\" field references a column \"${tableName}\".\"${f.field.name}\", but the table \"${tableName}\" is not part of the query! Did you forget to join it?`,\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\n\t\tconst isSingleTable = !joins || joins.length === 0;\n\n\t\tconst withSql = this.buildWithCTE(withList);\n\n\t\tconst distinctSql = distinct ? sql` distinct` : undefined;\n\n\t\tconst selection = this.buildSelection(fieldsList, { isSingleTable });\n\n\t\tconst tableSql = (() => {\n\t\t\tif (is(table, Table) && table[Table.Symbol.IsAlias]) {\n\t\t\t\treturn sql`${sql`${sql.identifier(table[Table.Symbol.Schema] ?? '')}.`.if(table[Table.Symbol.Schema])}${\n\t\t\t\t\tsql.identifier(table[Table.Symbol.OriginalName])\n\t\t\t\t} ${sql.identifier(table[Table.Symbol.Name])}`;\n\t\t\t}\n\n\t\t\treturn table;\n\t\t})();\n\n\t\tconst joinsArray: SQL[] = [];\n\n\t\tif (joins) {\n\t\t\tfor (const [index, joinMeta] of joins.entries()) {\n\t\t\t\tif (index === 0) {\n\t\t\t\t\tjoinsArray.push(sql` `);\n\t\t\t\t}\n\t\t\t\tconst table = joinMeta.table;\n\t\t\t\tconst lateralSql = joinMeta.lateral ? sql` lateral` : undefined;\n\t\t\t\tconst onSql = joinMeta.on ? sql` on ${joinMeta.on}` : undefined;\n\n\t\t\t\tif (is(table, MySqlTable)) {\n\t\t\t\t\tconst tableName = table[MySqlTable.Symbol.Name];\n\t\t\t\t\tconst tableSchema = table[MySqlTable.Symbol.Schema];\n\t\t\t\t\tconst origTableName = table[MySqlTable.Symbol.OriginalName];\n\t\t\t\t\tconst alias = tableName === origTableName ? undefined : joinMeta.alias;\n\t\t\t\t\tconst useIndexSql = this.buildIndex({ indexes: joinMeta.useIndex, indexFor: 'USE' });\n\t\t\t\t\tconst forceIndexSql = this.buildIndex({ indexes: joinMeta.forceIndex, indexFor: 'FORCE' });\n\t\t\t\t\tconst ignoreIndexSql = this.buildIndex({ indexes: joinMeta.ignoreIndex, indexFor: 'IGNORE' });\n\t\t\t\t\tjoinsArray.push(\n\t\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join${lateralSql} ${\n\t\t\t\t\t\t\ttableSchema ? sql`${sql.identifier(tableSchema)}.` : undefined\n\t\t\t\t\t\t}${sql.identifier(origTableName)}${useIndexSql}${forceIndexSql}${ignoreIndexSql}${\n\t\t\t\t\t\t\talias && sql` ${sql.identifier(alias)}`\n\t\t\t\t\t\t}${onSql}`,\n\t\t\t\t\t);\n\t\t\t\t} else if (is(table, View)) {\n\t\t\t\t\tconst viewName = table[ViewBaseConfig].name;\n\t\t\t\t\tconst viewSchema = table[ViewBaseConfig].schema;\n\t\t\t\t\tconst origViewName = table[ViewBaseConfig].originalName;\n\t\t\t\t\tconst alias = viewName === origViewName ? undefined : joinMeta.alias;\n\t\t\t\t\tjoinsArray.push(\n\t\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join${lateralSql} ${\n\t\t\t\t\t\t\tviewSchema ? sql`${sql.identifier(viewSchema)}.` : undefined\n\t\t\t\t\t\t}${sql.identifier(origViewName)}${alias && sql` ${sql.identifier(alias)}`}${onSql}`,\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\tjoinsArray.push(\n\t\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join${lateralSql} ${table}${onSql}`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\tif (index < joins.length - 1) {\n\t\t\t\t\tjoinsArray.push(sql` `);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tconst joinsSql = sql.join(joinsArray);\n\n\t\tconst whereSql = where ? sql` where ${where}` : undefined;\n\n\t\tconst havingSql = having ? sql` having ${having}` : undefined;\n\n\t\tconst orderBySql = this.buildOrderBy(orderBy);\n\n\t\tconst groupBySql = groupBy && groupBy.length > 0 ? sql` group by ${sql.join(groupBy, sql`, `)}` : undefined;\n\n\t\tconst limitSql = this.buildLimit(limit);\n\n\t\tconst offsetSql = offset ? sql` offset ${offset}` : undefined;\n\n\t\tconst useIndexSql = this.buildIndex({ indexes: useIndex, indexFor: 'USE' });\n\n\t\tconst forceIndexSql = this.buildIndex({ indexes: forceIndex, indexFor: 'FORCE' });\n\n\t\tconst ignoreIndexSql = this.buildIndex({ indexes: ignoreIndex, indexFor: 'IGNORE' });\n\n\t\tlet lockingClausesSql;\n\t\tif (lockingClause) {\n\t\t\tconst { config, strength } = lockingClause;\n\t\t\tlockingClausesSql = sql` for ${sql.raw(strength)}`;\n\t\t\tif (config.noWait) {\n\t\t\t\tlockingClausesSql.append(sql` nowait`);\n\t\t\t} else if (config.skipLocked) {\n\t\t\t\tlockingClausesSql.append(sql` skip locked`);\n\t\t\t}\n\t\t}\n\n\t\tconst finalQuery =\n\t\t\tsql`${withSql}select${distinctSql} ${selection} from ${tableSql}${useIndexSql}${forceIndexSql}${ignoreIndexSql}${joinsSql}${whereSql}${groupBySql}${havingSql}${orderBySql}${limitSql}${offsetSql}${lockingClausesSql}`;\n\n\t\tif (setOperators.length > 0) {\n\t\t\treturn this.buildSetOperations(finalQuery, setOperators);\n\t\t}\n\n\t\treturn finalQuery;\n\t}\n\n\tbuildSetOperations(leftSelect: SQL, setOperators: MySqlSelectConfig['setOperators']): SQL {\n\t\tconst [setOperator, ...rest] = setOperators;\n\n\t\tif (!setOperator) {\n\t\t\tthrow new Error('Cannot pass undefined values to any set operator');\n\t\t}\n\n\t\tif (rest.length === 0) {\n\t\t\treturn this.buildSetOperationQuery({ leftSelect, setOperator });\n\t\t}\n\n\t\t// Some recursive magic here\n\t\treturn this.buildSetOperations(\n\t\t\tthis.buildSetOperationQuery({ leftSelect, setOperator }),\n\t\t\trest,\n\t\t);\n\t}\n\n\tbuildSetOperationQuery({\n\t\tleftSelect,\n\t\tsetOperator: { type, isAll, rightSelect, limit, orderBy, offset },\n\t}: { leftSelect: SQL; setOperator: MySqlSelectConfig['setOperators'][number] }): SQL {\n\t\tconst leftChunk = sql`(${leftSelect.getSQL()}) `;\n\t\tconst rightChunk = sql`(${rightSelect.getSQL()})`;\n\n\t\tlet orderBySql;\n\t\tif (orderBy && orderBy.length > 0) {\n\t\t\tconst orderByValues: (SQL<unknown> | Name)[] = [];\n\n\t\t\t// The next bit is necessary because the sql operator replaces ${table.column} with `table`.`column`\n\t\t\t// which is invalid MySql syntax, Table from one of the SELECTs cannot be used in global ORDER clause\n\t\t\tfor (const orderByUnit of orderBy) {\n\t\t\t\tif (is(orderByUnit, MySqlColumn)) {\n\t\t\t\t\torderByValues.push(sql.identifier(this.casing.getColumnCasing(orderByUnit)));\n\t\t\t\t} else if (is(orderByUnit, SQL)) {\n\t\t\t\t\tfor (let i = 0; i < orderByUnit.queryChunks.length; i++) {\n\t\t\t\t\t\tconst chunk = orderByUnit.queryChunks[i];\n\n\t\t\t\t\t\tif (is(chunk, MySqlColumn)) {\n\t\t\t\t\t\t\torderByUnit.queryChunks[i] = sql.identifier(this.casing.getColumnCasing(chunk));\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\torderByValues.push(sql`${orderByUnit}`);\n\t\t\t\t} else {\n\t\t\t\t\torderByValues.push(sql`${orderByUnit}`);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\torderBySql = sql` order by ${sql.join(orderByValues, sql`, `)} `;\n\t\t}\n\n\t\tconst limitSql = typeof limit === 'object' || (typeof limit === 'number' && limit >= 0)\n\t\t\t? sql` limit ${limit}`\n\t\t\t: undefined;\n\n\t\tconst operatorChunk = sql.raw(`${type} ${isAll ? 'all ' : ''}`);\n\n\t\tconst offsetSql = offset ? sql` offset ${offset}` : undefined;\n\n\t\treturn sql`${leftChunk}${operatorChunk}${rightChunk}${orderBySql}${limitSql}${offsetSql}`;\n\t}\n\n\tbuildInsertQuery(\n\t\t{ table, values: valuesOrSelect, ignore, onConflict, select }: MySqlInsertConfig,\n\t): { sql: SQL; generatedIds: Record<string, unknown>[] } {\n\t\t// const isSingleValue = values.length === 1;\n\t\tconst valuesSqlList: ((SQLChunk | SQL)[] | SQL)[] = [];\n\t\tconst columns: Record<string, MySqlColumn> = table[Table.Symbol.Columns];\n\t\tconst colEntries: [string, MySqlColumn][] = Object.entries(columns).filter(([_, col]) =>\n\t\t\t!col.shouldDisableInsert()\n\t\t);\n\n\t\tconst insertOrder = colEntries.map(([, column]) => sql.identifier(this.casing.getColumnCasing(column)));\n\t\tconst generatedIdsResponse: Record<string, unknown>[] = [];\n\n\t\tif (select) {\n\t\t\tconst select = valuesOrSelect as AnyMySqlSelectQueryBuilder | SQL;\n\n\t\t\tif (is(select, SQL)) {\n\t\t\t\tvaluesSqlList.push(select);\n\t\t\t} else {\n\t\t\t\tvaluesSqlList.push(select.getSQL());\n\t\t\t}\n\t\t} else {\n\t\t\tconst values = valuesOrSelect as Record<string, Param | SQL>[];\n\t\t\tvaluesSqlList.push(sql.raw('values '));\n\n\t\t\tfor (const [valueIndex, value] of values.entries()) {\n\t\t\t\tconst generatedIds: Record<string, unknown> = {};\n\n\t\t\t\tconst valueList: (SQLChunk | SQL)[] = [];\n\t\t\t\tfor (const [fieldName, col] of colEntries) {\n\t\t\t\t\tconst colValue = value[fieldName];\n\t\t\t\t\tif (colValue === undefined || (is(colValue, Param) && colValue.value === undefined)) {\n\t\t\t\t\t\t// eslint-disable-next-line unicorn/no-negated-condition\n\t\t\t\t\t\tif (col.defaultFn !== undefined) {\n\t\t\t\t\t\t\tconst defaultFnResult = col.defaultFn();\n\t\t\t\t\t\t\tgeneratedIds[fieldName] = defaultFnResult;\n\t\t\t\t\t\t\tconst defaultValue = is(defaultFnResult, SQL) ? defaultFnResult : sql.param(defaultFnResult, col);\n\t\t\t\t\t\t\tvalueList.push(defaultValue);\n\t\t\t\t\t\t\t// eslint-disable-next-line unicorn/no-negated-condition\n\t\t\t\t\t\t} else if (!col.default && col.onUpdateFn !== undefined) {\n\t\t\t\t\t\t\tconst onUpdateFnResult = col.onUpdateFn();\n\t\t\t\t\t\t\tconst newValue = is(onUpdateFnResult, SQL) ? onUpdateFnResult : sql.param(onUpdateFnResult, col);\n\t\t\t\t\t\t\tvalueList.push(newValue);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tvalueList.push(sql`default`);\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tif (col.defaultFn && is(colValue, Param)) {\n\t\t\t\t\t\t\tgeneratedIds[fieldName] = colValue.value;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tvalueList.push(colValue);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tgeneratedIdsResponse.push(generatedIds);\n\t\t\t\tvaluesSqlList.push(valueList);\n\t\t\t\tif (valueIndex < values.length - 1) {\n\t\t\t\t\tvaluesSqlList.push(sql`, `);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tconst valuesSql = sql.join(valuesSqlList);\n\n\t\tconst ignoreSql = ignore ? sql` ignore` : undefined;\n\n\t\tconst onConflictSql = onConflict ? sql` on duplicate key ${onConflict}` : undefined;\n\n\t\treturn {\n\t\t\tsql: sql`insert${ignoreSql} into ${table} ${insertOrder} ${valuesSql}${onConflictSql}`,\n\t\t\tgeneratedIds: generatedIdsResponse,\n\t\t};\n\t}\n\n\tsqlToQuery(sql: SQL, invokeSource?: 'indexes' | undefined): QueryWithTypings {\n\t\treturn sql.toQuery({\n\t\t\tcasing: this.casing,\n\t\t\tescapeName: this.escapeName,\n\t\t\tescapeParam: this.escapeParam,\n\t\t\tescapeString: this.escapeString,\n\t\t\tinvokeSource,\n\t\t});\n\t}\n\n\t/** @deprecated */\n\t_buildRelationalQuery({\n\t\tfullSchema,\n\t\tschema,\n\t\ttableNamesMap,\n\t\ttable,\n\t\ttableConfig,\n\t\tqueryConfig: config,\n\t\ttableAlias,\n\t\tnestedQueryRelation,\n\t\tjoinOn,\n\t}: {\n\t\tfullSchema: Record<string, unknown>;\n\t\tschema: V1.TablesRelationalConfig;\n\t\ttableNamesMap: Record<string, string>;\n\t\ttable: MySqlTable;\n\t\ttableConfig: V1.TableRelationalConfig;\n\t\tqueryConfig: true | V1.DBQueryConfig<'many', true>;\n\t\ttableAlias: string;\n\t\tnestedQueryRelation?: V1.Relation;\n\t\tjoinOn?: SQL;\n\t}): V1.BuildRelationalQueryResult<MySqlTable, MySqlColumn> {\n\t\tlet selection: V1.BuildRelationalQueryResult<MySqlTable, MySqlColumn>['selection'] = [];\n\t\tlet limit, offset, orderBy: MySqlSelectConfig['orderBy'], where;\n\t\tconst joins: MySqlSelectJoinConfig[] = [];\n\n\t\tif (config === true) {\n\t\t\tconst selectionEntries = Object.entries(tableConfig.columns);\n\t\t\tselection = selectionEntries.map((\n\t\t\t\t[key, value],\n\t\t\t) => ({\n\t\t\t\tdbKey: value.name,\n\t\t\t\ttsKey: key,\n\t\t\t\tfield: aliasedTableColumn(value as MySqlColumn, tableAlias),\n\t\t\t\trelationTableTsKey: undefined,\n\t\t\t\tisJson: false,\n\t\t\t\tselection: [],\n\t\t\t}));\n\t\t} else {\n\t\t\tconst aliasedColumns = Object.fromEntries(\n\t\t\t\tObject.entries(tableConfig.columns).map(([key, value]) => [key, aliasedTableColumn(value, tableAlias)]),\n\t\t\t);\n\n\t\t\tif (config.where) {\n\t\t\t\tconst whereSql = typeof config.where === 'function'\n\t\t\t\t\t? config.where(aliasedColumns, V1.getOperators())\n\t\t\t\t\t: config.where;\n\t\t\t\twhere = whereSql && mapColumnsInSQLToAlias(whereSql, tableAlias);\n\t\t\t}\n\n\t\t\tconst fieldsSelection: { tsKey: string; value: MySqlColumn | SQL.Aliased }[] = [];\n\t\t\tlet selectedColumns: string[] = [];\n\n\t\t\t// Figure out which columns to select\n\t\t\tif (config.columns) {\n\t\t\t\tlet isIncludeMode = false;\n\n\t\t\t\tfor (const [field, value] of Object.entries(config.columns)) {\n\t\t\t\t\tif (value === undefined) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (field in tableConfig.columns) {\n\t\t\t\t\t\tif (!isIncludeMode && value === true) {\n\t\t\t\t\t\t\tisIncludeMode = true;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tselectedColumns.push(field);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (selectedColumns.length > 0) {\n\t\t\t\t\tselectedColumns = isIncludeMode\n\t\t\t\t\t\t? selectedColumns.filter((c) => config.columns?.[c] === true)\n\t\t\t\t\t\t: Object.keys(tableConfig.columns).filter((key) => !selectedColumns.includes(key));\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Select all columns if selection is not specified\n\t\t\t\tselectedColumns = Object.keys(tableConfig.columns);\n\t\t\t}\n\n\t\t\tfor (const field of selectedColumns) {\n\t\t\t\tconst column = tableConfig.columns[field]! as MySqlColumn;\n\t\t\t\tfieldsSelection.push({ tsKey: field, value: column });\n\t\t\t}\n\n\t\t\tlet selectedRelations: {\n\t\t\t\ttsKey: string;\n\t\t\t\tqueryConfig: true | V1.DBQueryConfig<'many', false>;\n\t\t\t\trelation: V1.Relation;\n\t\t\t}[] = [];\n\n\t\t\t// Figure out which V1.relations to select\n\t\t\tif (config.with) {\n\t\t\t\tselectedRelations = Object.entries(config.with)\n\t\t\t\t\t.filter((entry): entry is [typeof entry[0], NonNullable<typeof entry[1]>] => !!entry[1])\n\t\t\t\t\t.map(([tsKey, queryConfig]) => ({ tsKey, queryConfig, relation: tableConfig.relations[tsKey]! }));\n\t\t\t}\n\n\t\t\tlet extras;\n\n\t\t\t// Figure out which extras to select\n\t\t\tif (config.extras) {\n\t\t\t\textras = typeof config.extras === 'function'\n\t\t\t\t\t? config.extras(aliasedColumns, { sql })\n\t\t\t\t\t: config.extras;\n\t\t\t\tfor (const [tsKey, value] of Object.entries(extras)) {\n\t\t\t\t\tfieldsSelection.push({\n\t\t\t\t\t\ttsKey,\n\t\t\t\t\t\tvalue: mapColumnsInAliasedSQLToAlias(value, tableAlias),\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Transform `fieldsSelection` into `selection`\n\t\t\t// `fieldsSelection` shouldn't be used after this point\n\t\t\tfor (const { tsKey, value } of fieldsSelection) {\n\t\t\t\tselection.push({\n\t\t\t\t\tdbKey: is(value, SQL.Aliased) ? value.fieldAlias : tableConfig.columns[tsKey]!.name,\n\t\t\t\t\ttsKey,\n\t\t\t\t\tfield: is(value, Column) ? aliasedTableColumn(value, tableAlias) : value,\n\t\t\t\t\trelationTableTsKey: undefined,\n\t\t\t\t\tisJson: false,\n\t\t\t\t\tselection: [],\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tlet orderByOrig = typeof config.orderBy === 'function'\n\t\t\t\t? config.orderBy(aliasedColumns, V1.getOrderByOperators())\n\t\t\t\t: config.orderBy ?? [];\n\t\t\tif (!Array.isArray(orderByOrig)) {\n\t\t\t\torderByOrig = [orderByOrig];\n\t\t\t}\n\t\t\torderBy = orderByOrig.map((orderByValue) => {\n\t\t\t\tif (is(orderByValue, Column)) {\n\t\t\t\t\treturn aliasedTableColumn(orderByValue, tableAlias) as MySqlColumn;\n\t\t\t\t}\n\t\t\t\treturn mapColumnsInSQLToAlias(orderByValue, tableAlias);\n\t\t\t});\n\n\t\t\tlimit = config.limit;\n\t\t\toffset = config.offset;\n\n\t\t\t// Process all V1.relations\n\t\t\tfor (\n\t\t\t\tconst {\n\t\t\t\t\ttsKey: selectedRelationTsKey,\n\t\t\t\t\tqueryConfig: selectedRelationConfigValue,\n\t\t\t\t\trelation,\n\t\t\t\t} of selectedRelations\n\t\t\t) {\n\t\t\t\tconst normalizedRelation = V1.normalizeRelation(schema, tableNamesMap, relation);\n\t\t\t\tconst relationTableName = getTableUniqueName(relation.referencedTable);\n\t\t\t\tconst relationTableTsName = tableNamesMap[relationTableName]!;\n\t\t\t\tconst relationTableAlias = `${tableAlias}_${selectedRelationTsKey}`;\n\t\t\t\tconst joinOn = and(\n\t\t\t\t\t...normalizedRelation.fields.map((field, i) =>\n\t\t\t\t\t\teq(\n\t\t\t\t\t\t\taliasedTableColumn(normalizedRelation.references[i]!, relationTableAlias),\n\t\t\t\t\t\t\taliasedTableColumn(field, tableAlias),\n\t\t\t\t\t\t)\n\t\t\t\t\t),\n\t\t\t\t);\n\t\t\t\tconst builtRelation = this._buildRelationalQuery({\n\t\t\t\t\tfullSchema,\n\t\t\t\t\tschema,\n\t\t\t\t\ttableNamesMap,\n\t\t\t\t\ttable: fullSchema[relationTableTsName] as MySqlTable,\n\t\t\t\t\ttableConfig: schema[relationTableTsName]!,\n\t\t\t\t\tqueryConfig: is(relation, V1.One)\n\t\t\t\t\t\t? (selectedRelationConfigValue === true\n\t\t\t\t\t\t\t? { limit: 1 }\n\t\t\t\t\t\t\t: { ...selectedRelationConfigValue, limit: 1 })\n\t\t\t\t\t\t: selectedRelationConfigValue,\n\t\t\t\t\ttableAlias: relationTableAlias,\n\t\t\t\t\tjoinOn,\n\t\t\t\t\tnestedQueryRelation: relation,\n\t\t\t\t});\n\t\t\t\tconst field = sql`${sql.identifier(relationTableAlias)}.${sql.identifier('data')}`.as(selectedRelationTsKey);\n\t\t\t\tjoins.push({\n\t\t\t\t\ton: sql`true`,\n\t\t\t\t\ttable: new Subquery(builtRelation.sql as SQL, {}, relationTableAlias),\n\t\t\t\t\talias: relationTableAlias,\n\t\t\t\t\tjoinType: 'left',\n\t\t\t\t\tlateral: true,\n\t\t\t\t});\n\t\t\t\tselection.push({\n\t\t\t\t\tdbKey: selectedRelationTsKey,\n\t\t\t\t\ttsKey: selectedRelationTsKey,\n\t\t\t\t\tfield,\n\t\t\t\t\trelationTableTsKey: relationTableTsName,\n\t\t\t\t\tisJson: true,\n\t\t\t\t\tselection: builtRelation.selection,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tif (selection.length === 0) {\n\t\t\tthrow new DrizzleError({ message: `No fields selected for table \"${tableConfig.tsName}\" (\"${tableAlias}\")` });\n\t\t}\n\n\t\tlet result;\n\n\t\twhere = and(joinOn, where);\n\n\t\tif (nestedQueryRelation) {\n\t\t\tlet field = sql`json_array(${\n\t\t\t\tsql.join(\n\t\t\t\t\tselection.map(({ field, tsKey, isJson }) =>\n\t\t\t\t\t\tisJson\n\t\t\t\t\t\t\t? sql`${sql.identifier(`${tableAlias}_${tsKey}`)}.${sql.identifier('data')}`\n\t\t\t\t\t\t\t: is(field, SQL.Aliased)\n\t\t\t\t\t\t\t? field.sql\n\t\t\t\t\t\t\t: field\n\t\t\t\t\t),\n\t\t\t\t\tsql`, `,\n\t\t\t\t)\n\t\t\t})`;\n\t\t\tif (is(nestedQueryRelation, V1.Many)) {\n\t\t\t\tfield = sql`coalesce(json_arrayagg(${field}), json_array())`;\n\t\t\t}\n\t\t\tconst nestedSelection = [{\n\t\t\t\tdbKey: 'data',\n\t\t\t\ttsKey: 'data',\n\t\t\t\tfield: field.as('data'),\n\t\t\t\tisJson: true,\n\t\t\t\trelationTableTsKey: tableConfig.tsName,\n\t\t\t\tselection,\n\t\t\t}];\n\n\t\t\tconst needsSubquery = limit !== undefined || offset !== undefined || (orderBy?.length ?? 0) > 0;\n\n\t\t\tif (needsSubquery) {\n\t\t\t\tresult = this.buildSelectQuery({\n\t\t\t\t\ttable: aliasedTable(table, tableAlias),\n\t\t\t\t\tfields: {},\n\t\t\t\t\tfieldsFlat: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tpath: [],\n\t\t\t\t\t\t\tfield: sql.raw('*'),\n\t\t\t\t\t\t},\n\t\t\t\t\t\t...(((orderBy?.length ?? 0) > 0)\n\t\t\t\t\t\t\t? [{\n\t\t\t\t\t\t\t\tpath: [],\n\t\t\t\t\t\t\t\tfield: sql`row_number() over (order by ${sql.join(orderBy!, sql`, `)})`,\n\t\t\t\t\t\t\t}]\n\t\t\t\t\t\t\t: []),\n\t\t\t\t\t],\n\t\t\t\t\twhere,\n\t\t\t\t\tlimit,\n\t\t\t\t\toffset,\n\t\t\t\t\tsetOperators: [],\n\t\t\t\t});\n\n\t\t\t\twhere = undefined;\n\t\t\t\tlimit = undefined;\n\t\t\t\toffset = undefined;\n\t\t\t\torderBy = undefined;\n\t\t\t} else {\n\t\t\t\tresult = aliasedTable(table, tableAlias);\n\t\t\t}\n\n\t\t\tresult = this.buildSelectQuery({\n\t\t\t\ttable: is(result, MySqlTable) ? result : new Subquery(result, {}, tableAlias),\n\t\t\t\tfields: {},\n\t\t\t\tfieldsFlat: nestedSelection.map(({ field }) => ({\n\t\t\t\t\tpath: [],\n\t\t\t\t\tfield: is(field, Column) ? aliasedTableColumn(field, tableAlias) : field,\n\t\t\t\t})),\n\t\t\t\tjoins,\n\t\t\t\twhere,\n\t\t\t\tlimit,\n\t\t\t\toffset,\n\t\t\t\torderBy,\n\t\t\t\tsetOperators: [],\n\t\t\t});\n\t\t} else {\n\t\t\tresult = this.buildSelectQuery({\n\t\t\t\ttable: aliasedTable(table, tableAlias),\n\t\t\t\tfields: {},\n\t\t\t\tfieldsFlat: selection.map(({ field }) => ({\n\t\t\t\t\tpath: [],\n\t\t\t\t\tfield: is(field, Column) ? aliasedTableColumn(field, tableAlias) : field,\n\t\t\t\t})),\n\t\t\t\tjoins,\n\t\t\t\twhere,\n\t\t\t\tlimit,\n\t\t\t\toffset,\n\t\t\t\torderBy,\n\t\t\t\tsetOperators: [],\n\t\t\t});\n\t\t}\n\n\t\treturn {\n\t\t\ttableTsKey: tableConfig.tsName,\n\t\t\tsql: result,\n\t\t\tselection,\n\t\t};\n\t}\n\n\t/** @deprecated */\n\t_buildRelationalQueryWithoutLateralSubqueries({\n\t\tfullSchema,\n\t\tschema,\n\t\ttableNamesMap,\n\t\ttable,\n\t\ttableConfig,\n\t\tqueryConfig: config,\n\t\ttableAlias,\n\t\tnestedQueryRelation,\n\t\tjoinOn,\n\t}: {\n\t\tfullSchema: Record<string, unknown>;\n\t\tschema: V1.TablesRelationalConfig;\n\t\ttableNamesMap: Record<string, string>;\n\t\ttable: MySqlTable;\n\t\ttableConfig: V1.TableRelationalConfig;\n\t\tqueryConfig: true | V1.DBQueryConfig<'many', true>;\n\t\ttableAlias: string;\n\t\tnestedQueryRelation?: V1.Relation;\n\t\tjoinOn?: SQL;\n\t}): V1.BuildRelationalQueryResult<MySqlTable, MySqlColumn> {\n\t\tlet selection: V1.BuildRelationalQueryResult<MySqlTable, MySqlColumn>['selection'] = [];\n\t\tlet limit, offset, orderBy: MySqlSelectConfig['orderBy'] = [], where;\n\n\t\tif (config === true) {\n\t\t\tconst selectionEntries = Object.entries(tableConfig.columns);\n\t\t\tselection = selectionEntries.map((\n\t\t\t\t[key, value],\n\t\t\t) => ({\n\t\t\t\tdbKey: value.name,\n\t\t\t\ttsKey: key,\n\t\t\t\tfield: aliasedTableColumn(value as MySqlColumn, tableAlias),\n\t\t\t\trelationTableTsKey: undefined,\n\t\t\t\tisJson: false,\n\t\t\t\tselection: [],\n\t\t\t}));\n\t\t} else {\n\t\t\tconst aliasedColumns = Object.fromEntries(\n\t\t\t\tObject.entries(tableConfig.columns).map(([key, value]) => [key, aliasedTableColumn(value, tableAlias)]),\n\t\t\t);\n\n\t\t\tif (config.where) {\n\t\t\t\tconst whereSql = typeof config.where === 'function'\n\t\t\t\t\t? config.where(aliasedColumns, V1.getOperators())\n\t\t\t\t\t: config.where;\n\t\t\t\twhere = whereSql && mapColumnsInSQLToAlias(whereSql, tableAlias);\n\t\t\t}\n\n\t\t\tconst fieldsSelection: { tsKey: string; value: MySqlColumn | SQL.Aliased }[] = [];\n\t\t\tlet selectedColumns: string[] = [];\n\n\t\t\t// Figure out which columns to select\n\t\t\tif (config.columns) {\n\t\t\t\tlet isIncludeMode = false;\n\n\t\t\t\tfor (const [field, value] of Object.entries(config.columns)) {\n\t\t\t\t\tif (value === undefined) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (field in tableConfig.columns) {\n\t\t\t\t\t\tif (!isIncludeMode && value === true) {\n\t\t\t\t\t\t\tisIncludeMode = true;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tselectedColumns.push(field);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (selectedColumns.length > 0) {\n\t\t\t\t\tselectedColumns = isIncludeMode\n\t\t\t\t\t\t? selectedColumns.filter((c) => config.columns?.[c] === true)\n\t\t\t\t\t\t: Object.keys(tableConfig.columns).filter((key) => !selectedColumns.includes(key));\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Select all columns if selection is not specified\n\t\t\t\tselectedColumns = Object.keys(tableConfig.columns);\n\t\t\t}\n\n\t\t\tfor (const field of selectedColumns) {\n\t\t\t\tconst column = tableConfig.columns[field]! as MySqlColumn;\n\t\t\t\tfieldsSelection.push({ tsKey: field, value: column });\n\t\t\t}\n\n\t\t\tlet selectedRelations: {\n\t\t\t\ttsKey: string;\n\t\t\t\tqueryConfig: true | V1.DBQueryConfig<'many', false>;\n\t\t\t\trelation: V1.Relation;\n\t\t\t}[] = [];\n\n\t\t\t// Figure out which V1.relations to select\n\t\t\tif (config.with) {\n\t\t\t\tselectedRelations = Object.entries(config.with)\n\t\t\t\t\t.filter((entry): entry is [typeof entry[0], NonNullable<typeof entry[1]>] => !!entry[1])\n\t\t\t\t\t.map(([tsKey, queryConfig]) => ({ tsKey, queryConfig, relation: tableConfig.relations[tsKey]! }));\n\t\t\t}\n\n\t\t\tlet extras;\n\n\t\t\t// Figure out which extras to select\n\t\t\tif (config.extras) {\n\t\t\t\textras = typeof config.extras === 'function'\n\t\t\t\t\t? config.extras(aliasedColumns, { sql })\n\t\t\t\t\t: config.extras;\n\t\t\t\tfor (const [tsKey, value] of Object.entries(extras)) {\n\t\t\t\t\tfieldsSelection.push({\n\t\t\t\t\t\ttsKey,\n\t\t\t\t\t\tvalue: mapColumnsInAliasedSQLToAlias(value, tableAlias),\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Transform `fieldsSelection` into `selection`\n\t\t\t// `fieldsSelection` shouldn't be used after this point\n\t\t\tfor (const { tsKey, value } of fieldsSelection) {\n\t\t\t\tselection.push({\n\t\t\t\t\tdbKey: is(value, SQL.Aliased) ? value.fieldAlias : tableConfig.columns[tsKey]!.name,\n\t\t\t\t\ttsKey,\n\t\t\t\t\tfield: is(value, Column) ? aliasedTableColumn(value, tableAlias) : value,\n\t\t\t\t\trelationTableTsKey: undefined,\n\t\t\t\t\tisJson: false,\n\t\t\t\t\tselection: [],\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tlet orderByOrig = typeof config.orderBy === 'function'\n\t\t\t\t? config.orderBy(aliasedColumns, V1.getOrderByOperators())\n\t\t\t\t: config.orderBy ?? [];\n\t\t\tif (!Array.isArray(orderByOrig)) {\n\t\t\t\torderByOrig = [orderByOrig];\n\t\t\t}\n\t\t\torderBy = orderByOrig.map((orderByValue) => {\n\t\t\t\tif (is(orderByValue, Column)) {\n\t\t\t\t\treturn aliasedTableColumn(orderByValue, tableAlias) as MySqlColumn;\n\t\t\t\t}\n\t\t\t\treturn mapColumnsInSQLToAlias(orderByValue, tableAlias);\n\t\t\t});\n\n\t\t\tlimit = config.limit;\n\t\t\toffset = config.offset;\n\n\t\t\t// Process all V1.relations\n\t\t\tfor (\n\t\t\t\tconst {\n\t\t\t\t\ttsKey: selectedRelationTsKey,\n\t\t\t\t\tqueryConfig: selectedRelationConfigValue,\n\t\t\t\t\trelation,\n\t\t\t\t} of selectedRelations\n\t\t\t) {\n\t\t\t\tconst normalizedRelation = V1.normalizeRelation(schema, tableNamesMap, relation);\n\t\t\t\tconst relationTableName = getTableUniqueName(relation.referencedTable);\n\t\t\t\tconst relationTableTsName = tableNamesMap[relationTableName]!;\n\t\t\t\tconst relationTableAlias = `${tableAlias}_${selectedRelationTsKey}`;\n\t\t\t\tconst joinOn = and(\n\t\t\t\t\t...normalizedRelation.fields.map((field, i) =>\n\t\t\t\t\t\teq(\n\t\t\t\t\t\t\taliasedTableColumn(normalizedRelation.references[i]!, relationTableAlias),\n\t\t\t\t\t\t\taliasedTableColumn(field, tableAlias),\n\t\t\t\t\t\t)\n\t\t\t\t\t),\n\t\t\t\t);\n\t\t\t\tconst builtRelation = this._buildRelationalQueryWithoutLateralSubqueries({\n\t\t\t\t\tfullSchema,\n\t\t\t\t\tschema,\n\t\t\t\t\ttableNamesMap,\n\t\t\t\t\ttable: fullSchema[relationTableTsName] as MySqlTable,\n\t\t\t\t\ttableConfig: schema[relationTableTsName]!,\n\t\t\t\t\tqueryConfig: is(relation, V1.One)\n\t\t\t\t\t\t? (selectedRelationConfigValue === true\n\t\t\t\t\t\t\t? { limit: 1 }\n\t\t\t\t\t\t\t: { ...selectedRelationConfigValue, limit: 1 })\n\t\t\t\t\t\t: selectedRelationConfigValue,\n\t\t\t\t\ttableAlias: relationTableAlias,\n\t\t\t\t\tjoinOn,\n\t\t\t\t\tnestedQueryRelation: relation,\n\t\t\t\t});\n\t\t\t\tlet fieldSql = sql`(${builtRelation.sql})`;\n\t\t\t\tif (is(relation, V1.Many)) {\n\t\t\t\t\tfieldSql = sql`coalesce(${fieldSql}, json_array())`;\n\t\t\t\t}\n\t\t\t\tconst field = fieldSql.as(selectedRelationTsKey);\n\t\t\t\tselection.push({\n\t\t\t\t\tdbKey: selectedRelationTsKey,\n\t\t\t\t\ttsKey: selectedRelationTsKey,\n\t\t\t\t\tfield,\n\t\t\t\t\trelationTableTsKey: relationTableTsName,\n\t\t\t\t\tisJson: true,\n\t\t\t\t\tselection: builtRelation.selection,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tif (selection.length === 0) {\n\t\t\tthrow new DrizzleError({\n\t\t\t\tmessage:\n\t\t\t\t\t`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.`,\n\t\t\t});\n\t\t}\n\n\t\tlet result;\n\n\t\twhere = and(joinOn, where);\n\n\t\tif (nestedQueryRelation) {\n\t\t\tlet field = sql`json_array(${\n\t\t\t\tsql.join(\n\t\t\t\t\tselection.map(({ field }) =>\n\t\t\t\t\t\tis(field, MySqlColumn)\n\t\t\t\t\t\t\t? sql.identifier(this.casing.getColumnCasing(field))\n\t\t\t\t\t\t\t: is(field, SQL.Aliased)\n\t\t\t\t\t\t\t? field.sql\n\t\t\t\t\t\t\t: field\n\t\t\t\t\t),\n\t\t\t\t\tsql`, `,\n\t\t\t\t)\n\t\t\t})`;\n\t\t\tif (is(nestedQueryRelation, V1.Many)) {\n\t\t\t\tfield = sql`json_arrayagg(${field})`;\n\t\t\t}\n\t\t\tconst nestedSelection = [{\n\t\t\t\tdbKey: 'data',\n\t\t\t\ttsKey: 'data',\n\t\t\t\tfield,\n\t\t\t\tisJson: true,\n\t\t\t\trelationTableTsKey: tableConfig.tsName,\n\t\t\t\tselection,\n\t\t\t}];\n\n\t\t\tconst needsSubquery = limit !== undefined || offset !== undefined || orderBy.length > 0;\n\n\t\t\tif (needsSubquery) {\n\t\t\t\tresult = this.buildSelectQuery({\n\t\t\t\t\ttable: aliasedTable(table, tableAlias),\n\t\t\t\t\tfields: {},\n\t\t\t\t\tfieldsFlat: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tpath: [],\n\t\t\t\t\t\t\tfield: sql.raw('*'),\n\t\t\t\t\t\t},\n\t\t\t\t\t\t...(orderBy.length > 0)\n\t\t\t\t\t\t\t? [{\n\t\t\t\t\t\t\t\tpath: [],\n\t\t\t\t\t\t\t\tfield: sql`row_number() over (order by ${sql.join(orderBy, sql`, `)})`,\n\t\t\t\t\t\t\t}]\n\t\t\t\t\t\t\t: [],\n\t\t\t\t\t],\n\t\t\t\t\twhere,\n\t\t\t\t\tlimit,\n\t\t\t\t\toffset,\n\t\t\t\t\tsetOperators: [],\n\t\t\t\t});\n\n\t\t\t\twhere = undefined;\n\t\t\t\tlimit = undefined;\n\t\t\t\toffset = undefined;\n\t\t\t\torderBy = undefined;\n\t\t\t} else {\n\t\t\t\tresult = aliasedTable(table, tableAlias);\n\t\t\t}\n\n\t\t\tresult = this.buildSelectQuery({\n\t\t\t\ttable: is(result, MySqlTable) ? result : new Subquery(result, {}, tableAlias),\n\t\t\t\tfields: {},\n\t\t\t\tfieldsFlat: nestedSelection.map(({ field }) => ({\n\t\t\t\t\tpath: [],\n\t\t\t\t\tfield: is(field, Column) ? aliasedTableColumn(field, tableAlias) : field,\n\t\t\t\t})),\n\t\t\t\twhere,\n\t\t\t\tlimit,\n\t\t\t\toffset,\n\t\t\t\torderBy,\n\t\t\t\tsetOperators: [],\n\t\t\t});\n\t\t} else {\n\t\t\tresult = this.buildSelectQuery({\n\t\t\t\ttable: aliasedTable(table, tableAlias),\n\t\t\t\tfields: {},\n\t\t\t\tfieldsFlat: selection.map(({ field }) => ({\n\t\t\t\t\tpath: [],\n\t\t\t\t\tfield: is(field, Column) ? aliasedTableColumn(field, tableAlias) : field,\n\t\t\t\t})),\n\t\t\t\twhere,\n\t\t\t\tlimit,\n\t\t\t\toffset,\n\t\t\t\torderBy,\n\t\t\t\tsetOperators: [],\n\t\t\t});\n\t\t}\n\n\t\treturn {\n\t\t\ttableTsKey: tableConfig.tsName,\n\t\t\tsql: result,\n\t\t\tselection,\n\t\t};\n\t}\n\n\tprivate nestedSelectionerror() {\n\t\tthrow new DrizzleError({\n\t\t\tmessage: `Views with nested selections are not supported by the relational query builder`,\n\t\t});\n\t}\n\n\tprivate buildRqbColumn(table: Table | View, column: unknown, key: string) {\n\t\tif (is(column, Column)) {\n\t\t\tconst name = sql`${table}.${sql.identifier(this.casing.getColumnCasing(column))}`;\n\n\t\t\tswitch (column.columnType) {\n\t\t\t\tcase 'MySqlBinary':\n\t\t\t\tcase 'MySqlVarBinary':\n\t\t\t\tcase 'MySqlTime':\n\t\t\t\tcase 'MySqlDateTimeString':\n\t\t\t\tcase 'MySqlTimestampString':\n\t\t\t\tcase 'MySqlFloat':\n\t\t\t\tcase 'MySqlDecimal':\n\t\t\t\tcase 'MySqlDecimalNumber':\n\t\t\t\tcase 'MySqlDecimalBigInt':\n\t\t\t\tcase 'MySqlBigInt64':\n\t\t\t\tcase 'MySqlBigIntString': {\n\t\t\t\t\treturn sql`cast(${name} as char) as ${sql.identifier(key)}`;\n\t\t\t\t}\n\n\t\t\t\tcase 'MySqlCustomColumn': {\n\t\t\t\t\treturn sql`${(<MySqlCustomColumn<any>> column).jsonSelectIdentifier(name, sql)} as ${sql.identifier(key)}`;\n\t\t\t\t}\n\n\t\t\t\tdefault: {\n\t\t\t\t\treturn sql`${name} as ${sql.identifier(key)}`;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn sql`${table}.${\n\t\t\tis(column, SQL.Aliased)\n\t\t\t\t? sql.identifier(column.fieldAlias)\n\t\t\t\t: isSQLWrapper(column)\n\t\t\t\t? sql.identifier(key)\n\t\t\t\t: this.nestedSelectionerror()\n\t\t} as ${sql.identifier(key)}`;\n\t}\n\n\tprivate unwrapAllColumns = (table: Table | View, selection: BuildRelationalQueryResult['selection']) => {\n\t\treturn sql.join(\n\t\t\tObject.entries(table[TableColumns]).map(([k, v]) => {\n\t\t\t\tselection.push({\n\t\t\t\t\tkey: k,\n\t\t\t\t\tfield: v as Column | SQL | SQLWrapper | SQL.Aliased,\n\t\t\t\t});\n\n\t\t\t\treturn this.buildRqbColumn(table, v, k);\n\t\t\t}),\n\t\t\tsql`, `,\n\t\t);\n\t};\n\n\tprivate getSelectedTableColumns = (table: Table | View, columns: Record<string, boolean | undefined>) => {\n\t\tconst selectedColumns: ColumnWithTSName[] = [];\n\t\tconst columnContainer = table[TableColumns];\n\t\tconst entries = Object.entries(columns);\n\n\t\tlet colSelectionMode: boolean | undefined;\n\t\tfor (const [k, v] of entries) {\n\t\t\tif (v === undefined) continue;\n\t\t\tcolSelectionMode = colSelectionMode || v;\n\n\t\t\tif (v) {\n\t\t\t\tconst column = columnContainer[k]!;\n\n\t\t\t\tselectedColumns.push({\n\t\t\t\t\tcolumn: column as Column | SQL | SQLWrapper | SQL.Aliased,\n\t\t\t\t\ttsName: k,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tif (colSelectionMode === false) {\n\t\t\tfor (const [k, v] of Object.entries(columnContainer)) {\n\t\t\t\tif (columns[k] === false) continue;\n\n\t\t\t\tselectedColumns.push({\n\t\t\t\t\tcolumn: v as Column | SQL | SQLWrapper | SQL.Aliased | Table,\n\t\t\t\t\ttsName: k,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\treturn selectedColumns;\n\t};\n\n\tprivate buildColumns = (\n\t\ttable: MySqlTable | MySqlView,\n\t\tselection: BuildRelationalQueryResult['selection'],\n\t\tparams?: DBQueryConfig<'many'>,\n\t) =>\n\t\tparams?.columns\n\t\t\t? (() => {\n\t\t\t\tconst columnIdentifiers: SQL[] = [];\n\n\t\t\t\tconst selectedColumns = this.getSelectedTableColumns(table, params.columns);\n\n\t\t\t\tfor (const { column, tsName } of selectedColumns) {\n\t\t\t\t\tcolumnIdentifiers.push(this.buildRqbColumn(table, column, tsName));\n\n\t\t\t\t\tselection.push({\n\t\t\t\t\t\tkey: tsName,\n\t\t\t\t\t\tfield: column,\n\t\t\t\t\t});\n\t\t\t\t}\n\n\t\t\t\treturn columnIdentifiers.length\n\t\t\t\t\t? sql.join(columnIdentifiers, sql`, `)\n\t\t\t\t\t: undefined;\n\t\t\t})()\n\t\t\t: this.unwrapAllColumns(table, selection);\n\n\tbuildRelationalQuery(\n\t\t{\n\t\t\tschema,\n\t\t\ttable,\n\t\t\ttableConfig,\n\t\t\tqueryConfig: config,\n\t\t\trelationWhere,\n\t\t\tmode,\n\t\t\terrorPath,\n\t\t\tdepth,\n\t\t\tisNestedMany,\n\t\t\tthroughJoin,\n\t\t}: {\n\t\t\tschema: TablesRelationalConfig;\n\t\t\ttable: MySqlTable | MySqlView;\n\t\t\ttableConfig: TableRelationalConfig;\n\t\t\tqueryConfig?: DBQueryConfig<'many'> | true;\n\t\t\trelationWhere?: SQL;\n\t\t\tmode: 'first' | 'many';\n\t\t\terrorPath?: string;\n\t\t\tdepth?: number;\n\t\t\tisNestedMany?: boolean;\n\t\t\tthroughJoin?: SQL;\n\t\t},\n\t): BuildRelationalQueryResult {\n\t\tconst selection: BuildRelationalQueryResult['selection'] = [];\n\t\tconst isSingle = mode === 'first';\n\t\tconst params = config === true ? undefined : config;\n\t\tconst currentPath = errorPath ?? '';\n\t\tconst currentDepth = depth ?? 0;\n\t\tif (!currentDepth) table = aliasedTable(table, `d${currentDepth}`);\n\n\t\tconst limit = isSingle ? 1 : params?.limit;\n\t\tconst offset = params?.offset;\n\n\t\tconst columns = this.buildColumns(table, selection, params);\n\n\t\tconst where: SQL | undefined = (params?.where && relationWhere)\n\t\t\t? and(\n\t\t\t\trelationsFilterToSQL(table, params.where, tableConfig.relations, schema, this.casing),\n\t\t\t\trelationWhere,\n\t\t\t)\n\t\t\t: params?.where\n\t\t\t? relationsFilterToSQL(table, params.where, tableConfig.relations, schema, this.casing)\n\t\t\t: relationWhere;\n\t\tconst order = params?.orderBy ? relationsOrderToSQL(table, params.orderBy) : undefined;\n\t\tconst extras = params?.extras ? relationExtrasToSQL(table, params.extras) : undefined;\n\t\tif (extras) selection.push(...extras.selection);\n\n\t\tconst selectionArr: SQL[] = columns ? [columns] : [];\n\n\t\tconst joins = params\n\t\t\t? (() => {\n\t\t\t\tconst { with: joins } = params as WithContainer;\n\t\t\t\tif (!joins) return;\n\n\t\t\t\tconst withEntries = Object.entries(joins).filter(([_, v]) => v);\n\t\t\t\tif (!withEntries.length) return;\n\n\t\t\t\treturn sql.join(\n\t\t\t\t\twithEntries.map(([k, join]) => {\n\t\t\t\t\t\tselectionArr.push(sql`${sql.identifier(k)}.${sql.identifier('r')} as ${sql.identifier(k)}`);\n\n\t\t\t\t\t\t// if (is(tableConfig.relations[k]!, AggregatedField)) {\n\t\t\t\t\t\t// \tconst relation = tableConfig.relations[k]!;\n\t\t\t\t\t\t// \trelation.onTable(table);\n\t\t\t\t\t\t// \tconst query = relation.getSQL();\n\n\t\t\t\t\t\t// \tselection.push({\n\t\t\t\t\t\t// \t\tkey: k,\n\t\t\t\t\t\t// \t\tfield: relation,\n\t\t\t\t\t\t// \t});\n\n\t\t\t\t\t\t// \treturn sql` left join lateral (${query}) as ${sql.identifier(k)} on true`;\n\t\t\t\t\t\t// }\n\n\t\t\t\t\t\tconst relation = tableConfig.relations[k]! as Relation;\n\t\t\t\t\t\tconst isSingle = is(relation, One);\n\t\t\t\t\t\tconst targetTable = aliasedTable(relation.targetTable, `d${currentDepth + 1}`);\n\t\t\t\t\t\tconst throughTable = relation.throughTable\n\t\t\t\t\t\t\t? aliasedTable(relation.throughTable, `tr${currentDepth}`)\n\t\t\t\t\t\t\t: undefined;\n\t\t\t\t\t\tconst { filter, joinCondition } = relationToSQL(\n\t\t\t\t\t\t\tthis.casing,\n\t\t\t\t\t\t\trelation,\n\t\t\t\t\t\t\ttable,\n\t\t\t\t\t\t\ttargetTable,\n\t\t\t\t\t\t\tthroughTable,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tconst throughJoin = throughTable\n\t\t\t\t\t\t\t? sql` inner join ${getTableAsAliasSQL(throughTable)} on ${joinCondition!}`\n\t\t\t\t\t\t\t: undefined;\n\n\t\t\t\t\t\tconst innerQuery = this.buildRelationalQuery({\n\t\t\t\t\t\t\ttable: targetTable as MySqlTable,\n\t\t\t\t\t\t\tmode: isSingle ? 'first' : 'many',\n\t\t\t\t\t\t\tschema,\n\t\t\t\t\t\t\tqueryConfig: join as DBQueryConfig,\n\t\t\t\t\t\t\ttableConfig: schema[relation.targetTableName]!,\n\t\t\t\t\t\t\trelationWhere: filter,\n\t\t\t\t\t\t\terrorPath: `${currentPath.length ? `${currentPath}.` : ''}${k}`,\n\t\t\t\t\t\t\tdepth: currentDepth + 1,\n\t\t\t\t\t\t\tisNestedMany: !isSingle,\n\t\t\t\t\t\t\tthroughJoin,\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tselection.push({\n\t\t\t\t\t\t\tfield: targetTable,\n\t\t\t\t\t\t\tkey: k,\n\t\t\t\t\t\t\tselection: innerQuery.selection,\n\t\t\t\t\t\t\tisArray: !isSingle,\n\t\t\t\t\t\t\tisOptional: ((relation as AnyOne).optional ?? false)\n\t\t\t\t\t\t\t\t|| (join !== true && !!(join as Exclude<typeof join, boolean | undefined>).where),\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tconst jsonColumns = sql.join(\n\t\t\t\t\t\t\tinnerQuery.selection.map((s) => sql`${sql.raw(this.escapeString(s.key))}, ${sql.identifier(s.key)}`),\n\t\t\t\t\t\t\tsql`, `,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tconst joinQuery = sql` left join lateral(select ${sql`${\n\t\t\t\t\t\t\tisSingle\n\t\t\t\t\t\t\t\t? sql`json_object(${jsonColumns})`\n\t\t\t\t\t\t\t\t: sql`coalesce(json_arrayagg(json_object(${jsonColumns})), json_array())`\n\t\t\t\t\t\t} as ${sql.identifier('r')}`} from (${innerQuery.sql}) as ${sql.identifier('t')}) as ${\n\t\t\t\t\t\t\tsql.identifier(k)\n\t\t\t\t\t\t} on true`;\n\n\t\t\t\t\t\treturn joinQuery;\n\t\t\t\t\t}),\n\t\t\t\t);\n\t\t\t})()\n\t\t\t: undefined;\n\n\t\tif (extras?.sql) selectionArr.push(extras.sql);\n\t\tif (!selectionArr.length) {\n\t\t\tthrow new DrizzleError({\n\t\t\t\tmessage: `No fields selected for table \"${tableConfig.name}\"${currentPath ? ` (\"${currentPath}\")` : ''}`,\n\t\t\t});\n\t\t}\n\t\t// json_arrayagg() ignores order by clause otherwise\n\t\tif (isNestedMany && order) {\n\t\t\tselectionArr.push(sql`row_number() over (order by ${order})`);\n\t\t}\n\t\tconst selectionSet = sql.join(selectionArr, sql`, `);\n\n\t\tconst query = sql`select ${selectionSet} from ${getTableAsAliasSQL(table)}${throughJoin}${sql`${joins}`.if(joins)}${\n\t\t\tsql` where ${where}`.if(where)\n\t\t}${sql` order by ${order}`.if(order)}${sql` limit ${limit}`.if(limit !== undefined)}${\n\t\t\tsql` offset ${offset}`.if(offset !== undefined)\n\t\t}`;\n\n\t\treturn {\n\t\t\tsql: query,\n\t\t\tselection,\n\t\t};\n\t}\n}\n"],"mappings":"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","names":["import_table","table","useIndexSql","forceIndexSql","ignoreIndexSql","select","sql","joinOn","field","joins","isSingle","throughJoin"]}
1
+ {"version":3,"sources":["../../src/mysql-core/dialect.ts"],"sourcesContent":["import * as V1 from '~/_relations.ts';\nimport {\n\taliasedTable,\n\taliasedTableColumn,\n\tgetOriginalColumnFromAlias,\n\tmapColumnsInAliasedSQLToAlias,\n\tmapColumnsInSQLToAlias,\n} from '~/alias.ts';\nimport { CasingCache } from '~/casing.ts';\nimport { Column } from '~/column.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { DrizzleError } from '~/errors.ts';\nimport type { MigrationConfig, MigrationMeta, MigratorInitFailResponse } from '~/migrator.ts';\nimport type {\n\tAnyOne,\n\tBuildRelationalQueryResult,\n\tColumnWithTSName,\n\tDBQueryConfig,\n\tRelation,\n\tTableRelationalConfig,\n\tTablesRelationalConfig,\n\tWithContainer,\n} from '~/relations.ts';\nimport {\n\t// AggregatedField,\n\tgetTableAsAliasSQL,\n\tOne,\n\trelationExtrasToSQL,\n\trelationsFilterToSQL,\n\trelationsOrderToSQL,\n\trelationToSQL,\n} from '~/relations.ts';\nimport { and, eq } from '~/sql/expressions/index.ts';\nimport { isSQLWrapper, Param, SQL, sql, View } from '~/sql/sql.ts';\nimport type { Name, Placeholder, QueryWithTypings, SQLChunk, SQLWrapper } from '~/sql/sql.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { getTableName, getTableUniqueName, Table, TableColumns } from '~/table.ts';\nimport { type Casing, orderSelectedFields, type UpdateSet } from '~/utils.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport { MySqlColumn } from './columns/common.ts';\nimport type { MySqlCustomColumn } from './columns/custom.ts';\nimport type { MySqlDeleteConfig } from './query-builders/delete.ts';\nimport type { MySqlInsertConfig } from './query-builders/insert.ts';\nimport type {\n\tAnyMySqlSelectQueryBuilder,\n\tMySqlSelectConfig,\n\tMySqlSelectJoinConfig,\n\tSelectedFieldsOrdered,\n} from './query-builders/select.types.ts';\nimport type { MySqlUpdateConfig } from './query-builders/update.ts';\nimport type { MySqlSession } from './session.ts';\nimport { MySqlTable } from './table.ts';\nimport { MySqlViewBase } from './view-base.ts';\nimport type { MySqlView } from './view.ts';\n\nexport interface MySqlDialectConfig {\n\tcasing?: Casing;\n\tescapeParam?: (num: number) => string;\n}\n\nexport class MySqlDialect {\n\tstatic readonly [entityKind]: string = 'MySqlDialect';\n\n\t/** @internal */\n\treadonly casing: CasingCache;\n\n\tconstructor(config?: MySqlDialectConfig) {\n\t\tthis.casing = new CasingCache(config?.casing);\n\n\t\tif (config?.escapeParam) {\n\t\t\tthis.escapeParam = config.escapeParam;\n\t\t}\n\t}\n\n\tasync migrate(\n\t\tmigrations: MigrationMeta[],\n\t\tsession: MySqlSession,\n\t\tconfig: Omit<MigrationConfig, 'migrationsSchema'>,\n\t): Promise<void | MigratorInitFailResponse> {\n\t\tconst migrationsTable = config.migrationsTable ?? '__drizzle_migrations';\n\t\tconst migrationTableCreate = sql`\n\t\t\tcreate table if not exists ${sql.identifier(migrationsTable)} (\n\t\t\t\tid serial primary key,\n\t\t\t\thash text not null,\n\t\t\t\tcreated_at bigint\n\t\t\t)\n\t\t`;\n\t\tawait session.execute(migrationTableCreate);\n\n\t\tconst dbMigrations = await session.all<{ id: number; hash: string; created_at: string }>(\n\t\t\tsql`select id, hash, created_at from ${sql.identifier(migrationsTable)} order by created_at desc limit 1`,\n\t\t);\n\n\t\tif (typeof config === 'object' && config.init) {\n\t\t\tif (dbMigrations.length) {\n\t\t\t\treturn { exitCode: 'databaseMigrations' as const };\n\t\t\t}\n\n\t\t\tif (migrations.length > 1) {\n\t\t\t\treturn { exitCode: 'localMigrations' as const };\n\t\t\t}\n\n\t\t\tconst [migration] = migrations;\n\n\t\t\tif (!migration) return;\n\n\t\t\tawait session.execute(\n\t\t\t\tsql`insert into ${\n\t\t\t\t\tsql.identifier(migrationsTable)\n\t\t\t\t} (\\`hash\\`, \\`created_at\\`) values(${migration.hash}, ${migration.folderMillis})`,\n\t\t\t);\n\n\t\t\treturn;\n\t\t}\n\n\t\tconst lastDbMigration = dbMigrations[0];\n\t\tawait session.transaction(async (tx) => {\n\t\t\tfor (const migration of migrations) {\n\t\t\t\tif (\n\t\t\t\t\t!lastDbMigration\n\t\t\t\t\t|| Number(lastDbMigration.created_at) < migration.folderMillis\n\t\t\t\t) {\n\t\t\t\t\tfor (const stmt of migration.sql) {\n\t\t\t\t\t\tawait tx.execute(sql.raw(stmt));\n\t\t\t\t\t}\n\t\t\t\t\tawait tx.execute(\n\t\t\t\t\t\tsql`insert into ${\n\t\t\t\t\t\t\tsql.identifier(migrationsTable)\n\t\t\t\t\t\t} (\\`hash\\`, \\`created_at\\`) values(${migration.hash}, ${migration.folderMillis})`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\n\tescapeName(name: string): string {\n\t\treturn `\\`${name}\\``;\n\t}\n\n\tescapeParam(_num: number): string {\n\t\treturn `?`;\n\t}\n\n\tescapeString(str: string): string {\n\t\treturn `'${str.replace(/'/g, \"''\")}'`;\n\t}\n\n\tprivate buildWithCTE(queries: Subquery[] | undefined): SQL | undefined {\n\t\tif (!queries?.length) return undefined;\n\n\t\tconst withSqlChunks = [sql`with `];\n\t\tfor (const [i, w] of queries.entries()) {\n\t\t\twithSqlChunks.push(sql`${sql.identifier(w._.alias)} as (${w._.sql})`);\n\t\t\tif (i < queries.length - 1) {\n\t\t\t\twithSqlChunks.push(sql`, `);\n\t\t\t}\n\t\t}\n\t\twithSqlChunks.push(sql` `);\n\t\treturn sql.join(withSqlChunks);\n\t}\n\n\tbuildDeleteQuery({ table, where, returning, withList, limit, orderBy }: MySqlDeleteConfig): SQL {\n\t\tconst withSql = this.buildWithCTE(withList);\n\n\t\tconst returningSql = returning\n\t\t\t? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}`\n\t\t\t: undefined;\n\n\t\tconst whereSql = where ? sql` where ${where}` : undefined;\n\n\t\tconst orderBySql = this.buildOrderBy(orderBy);\n\n\t\tconst limitSql = this.buildLimit(limit);\n\n\t\treturn sql`${withSql}delete from ${table}${whereSql}${orderBySql}${limitSql}${returningSql}`;\n\t}\n\n\tbuildUpdateSet(table: MySqlTable, set: UpdateSet): SQL {\n\t\tconst tableColumns = table[Table.Symbol.Columns];\n\n\t\tconst columnNames = Object.keys(tableColumns).filter((colName) =>\n\t\t\tset[colName] !== undefined || tableColumns[colName]?.onUpdateFn !== undefined\n\t\t);\n\n\t\tconst setLength = columnNames.length;\n\t\treturn sql.join(columnNames.flatMap((colName, i) => {\n\t\t\tconst col = tableColumns[colName]!;\n\n\t\t\tconst onUpdateFnResult = col.onUpdateFn?.();\n\t\t\tconst value = set[colName] ?? (is(onUpdateFnResult, SQL) ? onUpdateFnResult : sql.param(onUpdateFnResult, col));\n\t\t\tconst res = sql`${sql.identifier(this.casing.getColumnCasing(col))} = ${value}`;\n\n\t\t\tif (i < setLength - 1) {\n\t\t\t\treturn [res, sql.raw(', ')];\n\t\t\t}\n\t\t\treturn [res];\n\t\t}));\n\t}\n\n\tbuildUpdateQuery({ table, set, where, returning, withList, limit, orderBy }: MySqlUpdateConfig): SQL {\n\t\tconst withSql = this.buildWithCTE(withList);\n\n\t\tconst setSql = this.buildUpdateSet(table, set);\n\n\t\tconst returningSql = returning\n\t\t\t? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}`\n\t\t\t: undefined;\n\n\t\tconst whereSql = where ? sql` where ${where}` : undefined;\n\n\t\tconst orderBySql = this.buildOrderBy(orderBy);\n\n\t\tconst limitSql = this.buildLimit(limit);\n\n\t\treturn sql`${withSql}update ${table} set ${setSql}${whereSql}${orderBySql}${limitSql}${returningSql}`;\n\t}\n\n\t/**\n\t * Builds selection SQL with provided fields/expressions\n\t *\n\t * Examples:\n\t *\n\t * `select <selection> from`\n\t *\n\t * `insert ... returning <selection>`\n\t *\n\t * If `isSingleTable` is true, then columns won't be prefixed with table name\n\t */\n\tprivate buildSelection(\n\t\tfields: SelectedFieldsOrdered,\n\t\t{ isSingleTable = false }: { isSingleTable?: boolean } = {},\n\t): SQL {\n\t\tconst columnsLen = fields.length;\n\n\t\tconst chunks = fields\n\t\t\t.flatMap(({ field }, i) => {\n\t\t\t\tconst chunk: SQLChunk[] = [];\n\n\t\t\t\tif (is(field, SQL.Aliased) && field.isSelectionField) {\n\t\t\t\t\tchunk.push(sql.identifier(field.fieldAlias));\n\t\t\t\t} else if (is(field, SQL.Aliased) || is(field, SQL)) {\n\t\t\t\t\tconst query = is(field, SQL.Aliased) ? field.sql : field;\n\n\t\t\t\t\tif (isSingleTable) {\n\t\t\t\t\t\tchunk.push(\n\t\t\t\t\t\t\tnew SQL(\n\t\t\t\t\t\t\t\tquery.queryChunks.map((c) => {\n\t\t\t\t\t\t\t\t\tif (is(c, MySqlColumn)) {\n\t\t\t\t\t\t\t\t\t\treturn sql.identifier(this.casing.getColumnCasing(c));\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\treturn c;\n\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tchunk.push(query);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (is(field, SQL.Aliased)) {\n\t\t\t\t\t\tchunk.push(sql` as ${sql.identifier(field.fieldAlias)}`);\n\t\t\t\t\t}\n\t\t\t\t} else if (is(field, Column)) {\n\t\t\t\t\tif (isSingleTable) {\n\t\t\t\t\t\tchunk.push(\n\t\t\t\t\t\t\tfield.isAlias\n\t\t\t\t\t\t\t\t? sql`${sql.identifier(this.casing.getColumnCasing(getOriginalColumnFromAlias(field)))} as ${field}`\n\t\t\t\t\t\t\t\t: sql.identifier(this.casing.getColumnCasing(field)),\n\t\t\t\t\t\t);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tchunk.push(field.isAlias ? sql`${getOriginalColumnFromAlias(field)} as ${field}` : field);\n\t\t\t\t\t}\n\t\t\t\t} else if (is(field, Subquery)) {\n\t\t\t\t\tconst entries = Object.entries(field._.selectedFields) as [string, SQL.Aliased | Column | SQL][];\n\n\t\t\t\t\tif (entries.length === 1) {\n\t\t\t\t\t\tconst entry = entries[0]![1];\n\n\t\t\t\t\t\tconst fieldDecoder = is(entry, SQL)\n\t\t\t\t\t\t\t? entry.decoder\n\t\t\t\t\t\t\t: is(entry, Column)\n\t\t\t\t\t\t\t? { mapFromDriverValue: (v: any) => entry.mapFromDriverValue(v) }\n\t\t\t\t\t\t\t: entry.sql.decoder;\n\n\t\t\t\t\t\tif (fieldDecoder) {\n\t\t\t\t\t\t\tfield._.sql.decoder = fieldDecoder;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tchunk.push(field);\n\t\t\t\t}\n\n\t\t\t\tif (i < columnsLen - 1) {\n\t\t\t\t\tchunk.push(sql`, `);\n\t\t\t\t}\n\n\t\t\t\treturn chunk;\n\t\t\t});\n\n\t\treturn sql.join(chunks);\n\t}\n\n\tprivate buildLimit(limit: number | Placeholder | undefined): SQL | undefined {\n\t\treturn typeof limit === 'object' || (typeof limit === 'number' && limit >= 0)\n\t\t\t? sql` limit ${limit}`\n\t\t\t: undefined;\n\t}\n\n\tprivate buildOrderBy(orderBy: (MySqlColumn | SQL | SQL.Aliased)[] | undefined): SQL | undefined {\n\t\treturn orderBy && orderBy.length > 0 ? sql` order by ${sql.join(orderBy, sql`, `)}` : undefined;\n\t}\n\n\tprivate buildIndex({\n\t\tindexes,\n\t\tindexFor,\n\t}: {\n\t\tindexes: string[] | undefined;\n\t\tindexFor: 'USE' | 'FORCE' | 'IGNORE';\n\t}): SQL | undefined {\n\t\treturn indexes && indexes.length > 0\n\t\t\t? sql` ${sql.raw(indexFor)} INDEX (${sql.raw(indexes.join(`, `))})`\n\t\t\t: undefined;\n\t}\n\n\tbuildSelectQuery(\n\t\t{\n\t\t\twithList,\n\t\t\tfields,\n\t\t\tfieldsFlat,\n\t\t\twhere,\n\t\t\thaving,\n\t\t\ttable,\n\t\t\tjoins,\n\t\t\torderBy,\n\t\t\tgroupBy,\n\t\t\tlimit,\n\t\t\toffset,\n\t\t\tlockingClause,\n\t\t\tdistinct,\n\t\t\tsetOperators,\n\t\t\tuseIndex,\n\t\t\tforceIndex,\n\t\t\tignoreIndex,\n\t\t}: MySqlSelectConfig,\n\t): SQL {\n\t\tconst fieldsList = fieldsFlat ?? orderSelectedFields<MySqlColumn>(fields);\n\t\tfor (const f of fieldsList) {\n\t\t\tif (\n\t\t\t\tis(f.field, Column)\n\t\t\t\t&& getTableName(f.field.table)\n\t\t\t\t\t!== (is(table, Subquery)\n\t\t\t\t\t\t? table._.alias\n\t\t\t\t\t\t: is(table, MySqlViewBase)\n\t\t\t\t\t\t? table[ViewBaseConfig].name\n\t\t\t\t\t\t: is(table, SQL)\n\t\t\t\t\t\t? undefined\n\t\t\t\t\t\t: getTableName(table))\n\t\t\t\t&& !((table) =>\n\t\t\t\t\tjoins?.some(({ alias }) =>\n\t\t\t\t\t\talias === (table[Table.Symbol.IsAlias] ? getTableName(table) : table[Table.Symbol.BaseName])\n\t\t\t\t\t))(f.field.table)\n\t\t\t) {\n\t\t\t\tconst tableName = getTableName(f.field.table);\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`Your \"${\n\t\t\t\t\t\tf.path.join('->')\n\t\t\t\t\t}\" field references a column \"${tableName}\".\"${f.field.name}\", but the table \"${tableName}\" is not part of the query! Did you forget to join it?`,\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\n\t\tconst isSingleTable = !joins || joins.length === 0;\n\n\t\tconst withSql = this.buildWithCTE(withList);\n\n\t\tconst distinctSql = distinct ? sql` distinct` : undefined;\n\n\t\tconst selection = this.buildSelection(fieldsList, { isSingleTable });\n\n\t\tconst tableSql = (() => {\n\t\t\tif (is(table, Table) && table[Table.Symbol.IsAlias]) {\n\t\t\t\treturn sql`${sql`${sql.identifier(table[Table.Symbol.Schema] ?? '')}.`.if(table[Table.Symbol.Schema])}${\n\t\t\t\t\tsql.identifier(table[Table.Symbol.OriginalName])\n\t\t\t\t} ${sql.identifier(table[Table.Symbol.Name])}`;\n\t\t\t}\n\n\t\t\treturn table;\n\t\t})();\n\n\t\tconst joinsArray: SQL[] = [];\n\n\t\tif (joins) {\n\t\t\tfor (const [index, joinMeta] of joins.entries()) {\n\t\t\t\tif (index === 0) {\n\t\t\t\t\tjoinsArray.push(sql` `);\n\t\t\t\t}\n\t\t\t\tconst table = joinMeta.table;\n\t\t\t\tconst lateralSql = joinMeta.lateral ? sql` lateral` : undefined;\n\t\t\t\tconst onSql = joinMeta.on ? sql` on ${joinMeta.on}` : undefined;\n\n\t\t\t\tif (is(table, MySqlTable)) {\n\t\t\t\t\tconst tableName = table[MySqlTable.Symbol.Name];\n\t\t\t\t\tconst tableSchema = table[MySqlTable.Symbol.Schema];\n\t\t\t\t\tconst origTableName = table[MySqlTable.Symbol.OriginalName];\n\t\t\t\t\tconst alias = tableName === origTableName ? undefined : joinMeta.alias;\n\t\t\t\t\tconst useIndexSql = this.buildIndex({ indexes: joinMeta.useIndex, indexFor: 'USE' });\n\t\t\t\t\tconst forceIndexSql = this.buildIndex({ indexes: joinMeta.forceIndex, indexFor: 'FORCE' });\n\t\t\t\t\tconst ignoreIndexSql = this.buildIndex({ indexes: joinMeta.ignoreIndex, indexFor: 'IGNORE' });\n\t\t\t\t\tjoinsArray.push(\n\t\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join${lateralSql} ${\n\t\t\t\t\t\t\ttableSchema ? sql`${sql.identifier(tableSchema)}.` : undefined\n\t\t\t\t\t\t}${sql.identifier(origTableName)}${useIndexSql}${forceIndexSql}${ignoreIndexSql}${\n\t\t\t\t\t\t\talias && sql` ${sql.identifier(alias)}`\n\t\t\t\t\t\t}${onSql}`,\n\t\t\t\t\t);\n\t\t\t\t} else if (is(table, View)) {\n\t\t\t\t\tconst viewName = table[ViewBaseConfig].name;\n\t\t\t\t\tconst viewSchema = table[ViewBaseConfig].schema;\n\t\t\t\t\tconst origViewName = table[ViewBaseConfig].originalName;\n\t\t\t\t\tconst alias = viewName === origViewName ? undefined : joinMeta.alias;\n\t\t\t\t\tjoinsArray.push(\n\t\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join${lateralSql} ${\n\t\t\t\t\t\t\tviewSchema ? sql`${sql.identifier(viewSchema)}.` : undefined\n\t\t\t\t\t\t}${sql.identifier(origViewName)}${alias && sql` ${sql.identifier(alias)}`}${onSql}`,\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\tjoinsArray.push(\n\t\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join${lateralSql} ${table}${onSql}`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\tif (index < joins.length - 1) {\n\t\t\t\t\tjoinsArray.push(sql` `);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tconst joinsSql = sql.join(joinsArray);\n\n\t\tconst whereSql = where ? sql` where ${where}` : undefined;\n\n\t\tconst havingSql = having ? sql` having ${having}` : undefined;\n\n\t\tconst orderBySql = this.buildOrderBy(orderBy);\n\n\t\tconst groupBySql = groupBy && groupBy.length > 0 ? sql` group by ${sql.join(groupBy, sql`, `)}` : undefined;\n\n\t\tconst limitSql = this.buildLimit(limit);\n\n\t\tconst offsetSql = offset ? sql` offset ${offset}` : undefined;\n\n\t\tconst useIndexSql = this.buildIndex({ indexes: useIndex, indexFor: 'USE' });\n\n\t\tconst forceIndexSql = this.buildIndex({ indexes: forceIndex, indexFor: 'FORCE' });\n\n\t\tconst ignoreIndexSql = this.buildIndex({ indexes: ignoreIndex, indexFor: 'IGNORE' });\n\n\t\tlet lockingClausesSql;\n\t\tif (lockingClause) {\n\t\t\tconst { config, strength } = lockingClause;\n\t\t\tlockingClausesSql = sql` for ${sql.raw(strength)}`;\n\t\t\tif (config.noWait) {\n\t\t\t\tlockingClausesSql.append(sql` nowait`);\n\t\t\t} else if (config.skipLocked) {\n\t\t\t\tlockingClausesSql.append(sql` skip locked`);\n\t\t\t}\n\t\t}\n\n\t\tconst finalQuery =\n\t\t\tsql`${withSql}select${distinctSql} ${selection} from ${tableSql}${useIndexSql}${forceIndexSql}${ignoreIndexSql}${joinsSql}${whereSql}${groupBySql}${havingSql}${orderBySql}${limitSql}${offsetSql}${lockingClausesSql}`;\n\n\t\tif (setOperators.length > 0) {\n\t\t\treturn this.buildSetOperations(finalQuery, setOperators);\n\t\t}\n\n\t\treturn finalQuery;\n\t}\n\n\tbuildSetOperations(leftSelect: SQL, setOperators: MySqlSelectConfig['setOperators']): SQL {\n\t\tconst [setOperator, ...rest] = setOperators;\n\n\t\tif (!setOperator) {\n\t\t\tthrow new Error('Cannot pass undefined values to any set operator');\n\t\t}\n\n\t\tif (rest.length === 0) {\n\t\t\treturn this.buildSetOperationQuery({ leftSelect, setOperator });\n\t\t}\n\n\t\t// Some recursive magic here\n\t\treturn this.buildSetOperations(\n\t\t\tthis.buildSetOperationQuery({ leftSelect, setOperator }),\n\t\t\trest,\n\t\t);\n\t}\n\n\tbuildSetOperationQuery({\n\t\tleftSelect,\n\t\tsetOperator: { type, isAll, rightSelect, limit, orderBy, offset },\n\t}: { leftSelect: SQL; setOperator: MySqlSelectConfig['setOperators'][number] }): SQL {\n\t\tconst leftChunk = sql`(${leftSelect.getSQL()}) `;\n\t\tconst rightChunk = sql`(${rightSelect.getSQL()})`;\n\n\t\tlet orderBySql;\n\t\tif (orderBy && orderBy.length > 0) {\n\t\t\tconst orderByValues: (SQL<unknown> | Name)[] = [];\n\n\t\t\t// The next bit is necessary because the sql operator replaces ${table.column} with `table`.`column`\n\t\t\t// which is invalid MySql syntax, Table from one of the SELECTs cannot be used in global ORDER clause\n\t\t\tfor (const orderByUnit of orderBy) {\n\t\t\t\tif (is(orderByUnit, MySqlColumn)) {\n\t\t\t\t\torderByValues.push(sql.identifier(this.casing.getColumnCasing(orderByUnit)));\n\t\t\t\t} else if (is(orderByUnit, SQL)) {\n\t\t\t\t\tfor (let i = 0; i < orderByUnit.queryChunks.length; i++) {\n\t\t\t\t\t\tconst chunk = orderByUnit.queryChunks[i];\n\n\t\t\t\t\t\tif (is(chunk, MySqlColumn)) {\n\t\t\t\t\t\t\torderByUnit.queryChunks[i] = sql.identifier(this.casing.getColumnCasing(chunk));\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\torderByValues.push(sql`${orderByUnit}`);\n\t\t\t\t} else {\n\t\t\t\t\torderByValues.push(sql`${orderByUnit}`);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\torderBySql = sql` order by ${sql.join(orderByValues, sql`, `)} `;\n\t\t}\n\n\t\tconst limitSql = typeof limit === 'object' || (typeof limit === 'number' && limit >= 0)\n\t\t\t? sql` limit ${limit}`\n\t\t\t: undefined;\n\n\t\tconst operatorChunk = sql.raw(`${type} ${isAll ? 'all ' : ''}`);\n\n\t\tconst offsetSql = offset ? sql` offset ${offset}` : undefined;\n\n\t\treturn sql`${leftChunk}${operatorChunk}${rightChunk}${orderBySql}${limitSql}${offsetSql}`;\n\t}\n\n\tbuildInsertQuery(\n\t\t{ table, values: valuesOrSelect, ignore, onConflict, select }: MySqlInsertConfig,\n\t): { sql: SQL; generatedIds: Record<string, unknown>[] } {\n\t\t// const isSingleValue = values.length === 1;\n\t\tconst valuesSqlList: ((SQLChunk | SQL)[] | SQL)[] = [];\n\t\tconst columns: Record<string, MySqlColumn> = table[Table.Symbol.Columns];\n\t\tconst colEntries: [string, MySqlColumn][] = Object.entries(columns).filter(([_, col]) =>\n\t\t\t!col.shouldDisableInsert()\n\t\t);\n\n\t\tconst insertOrder = colEntries.map(([, column]) => sql.identifier(this.casing.getColumnCasing(column)));\n\t\tconst generatedIdsResponse: Record<string, unknown>[] = [];\n\n\t\tif (select) {\n\t\t\tconst select = valuesOrSelect as AnyMySqlSelectQueryBuilder | SQL;\n\n\t\t\tif (is(select, SQL)) {\n\t\t\t\tvaluesSqlList.push(select);\n\t\t\t} else {\n\t\t\t\tvaluesSqlList.push(select.getSQL());\n\t\t\t}\n\t\t} else {\n\t\t\tconst values = valuesOrSelect as Record<string, Param | SQL>[];\n\t\t\tvaluesSqlList.push(sql.raw('values '));\n\n\t\t\tfor (const [valueIndex, value] of values.entries()) {\n\t\t\t\tconst generatedIds: Record<string, unknown> = {};\n\n\t\t\t\tconst valueList: (SQLChunk | SQL)[] = [];\n\t\t\t\tfor (const [fieldName, col] of colEntries) {\n\t\t\t\t\tconst colValue = value[fieldName];\n\t\t\t\t\tif (colValue === undefined || (is(colValue, Param) && colValue.value === undefined)) {\n\t\t\t\t\t\t// eslint-disable-next-line unicorn/no-negated-condition\n\t\t\t\t\t\tif (col.defaultFn !== undefined) {\n\t\t\t\t\t\t\tconst defaultFnResult = col.defaultFn();\n\t\t\t\t\t\t\tgeneratedIds[fieldName] = defaultFnResult;\n\t\t\t\t\t\t\tconst defaultValue = is(defaultFnResult, SQL) ? defaultFnResult : sql.param(defaultFnResult, col);\n\t\t\t\t\t\t\tvalueList.push(defaultValue);\n\t\t\t\t\t\t\t// eslint-disable-next-line unicorn/no-negated-condition\n\t\t\t\t\t\t} else if (!col.default && col.onUpdateFn !== undefined) {\n\t\t\t\t\t\t\tconst onUpdateFnResult = col.onUpdateFn();\n\t\t\t\t\t\t\tconst newValue = is(onUpdateFnResult, SQL) ? onUpdateFnResult : sql.param(onUpdateFnResult, col);\n\t\t\t\t\t\t\tvalueList.push(newValue);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tvalueList.push(sql`default`);\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tif (col.defaultFn && is(colValue, Param)) {\n\t\t\t\t\t\t\tgeneratedIds[fieldName] = colValue.value;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tvalueList.push(colValue);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tgeneratedIdsResponse.push(generatedIds);\n\t\t\t\tvaluesSqlList.push(valueList);\n\t\t\t\tif (valueIndex < values.length - 1) {\n\t\t\t\t\tvaluesSqlList.push(sql`, `);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tconst valuesSql = sql.join(valuesSqlList);\n\n\t\tconst ignoreSql = ignore ? sql` ignore` : undefined;\n\n\t\tconst onConflictSql = onConflict ? sql` on duplicate key ${onConflict}` : undefined;\n\n\t\treturn {\n\t\t\tsql: sql`insert${ignoreSql} into ${table} ${insertOrder} ${valuesSql}${onConflictSql}`,\n\t\t\tgeneratedIds: generatedIdsResponse,\n\t\t};\n\t}\n\n\tsqlToQuery(sql: SQL, invokeSource?: 'indexes' | undefined): QueryWithTypings {\n\t\treturn sql.toQuery({\n\t\t\tcasing: this.casing,\n\t\t\tescapeName: this.escapeName,\n\t\t\tescapeParam: this.escapeParam,\n\t\t\tescapeString: this.escapeString,\n\t\t\tinvokeSource,\n\t\t});\n\t}\n\n\t/** @deprecated */\n\t_buildRelationalQuery({\n\t\tfullSchema,\n\t\tschema,\n\t\ttableNamesMap,\n\t\ttable,\n\t\ttableConfig,\n\t\tqueryConfig: config,\n\t\ttableAlias,\n\t\tnestedQueryRelation,\n\t\tjoinOn,\n\t}: {\n\t\tfullSchema: Record<string, unknown>;\n\t\tschema: V1.TablesRelationalConfig;\n\t\ttableNamesMap: Record<string, string>;\n\t\ttable: MySqlTable;\n\t\ttableConfig: V1.TableRelationalConfig;\n\t\tqueryConfig: true | V1.DBQueryConfig<'many', true>;\n\t\ttableAlias: string;\n\t\tnestedQueryRelation?: V1.Relation;\n\t\tjoinOn?: SQL;\n\t}): V1.BuildRelationalQueryResult<MySqlTable, MySqlColumn> {\n\t\tlet selection: V1.BuildRelationalQueryResult<MySqlTable, MySqlColumn>['selection'] = [];\n\t\tlet limit, offset, orderBy: MySqlSelectConfig['orderBy'], where;\n\t\tconst joins: MySqlSelectJoinConfig[] = [];\n\n\t\tif (config === true) {\n\t\t\tconst selectionEntries = Object.entries(tableConfig.columns);\n\t\t\tselection = selectionEntries.map((\n\t\t\t\t[key, value],\n\t\t\t) => ({\n\t\t\t\tdbKey: value.name,\n\t\t\t\ttsKey: key,\n\t\t\t\tfield: aliasedTableColumn(value as MySqlColumn, tableAlias),\n\t\t\t\trelationTableTsKey: undefined,\n\t\t\t\tisJson: false,\n\t\t\t\tselection: [],\n\t\t\t}));\n\t\t} else {\n\t\t\tconst aliasedColumns = Object.fromEntries(\n\t\t\t\tObject.entries(tableConfig.columns).map(([key, value]) => [key, aliasedTableColumn(value, tableAlias)]),\n\t\t\t);\n\n\t\t\tif (config.where) {\n\t\t\t\tconst whereSql = typeof config.where === 'function'\n\t\t\t\t\t? config.where(aliasedColumns, V1.getOperators())\n\t\t\t\t\t: config.where;\n\t\t\t\twhere = whereSql && mapColumnsInSQLToAlias(whereSql, tableAlias);\n\t\t\t}\n\n\t\t\tconst fieldsSelection: { tsKey: string; value: MySqlColumn | SQL.Aliased }[] = [];\n\t\t\tlet selectedColumns: string[] = [];\n\n\t\t\t// Figure out which columns to select\n\t\t\tif (config.columns) {\n\t\t\t\tlet isIncludeMode = false;\n\n\t\t\t\tfor (const [field, value] of Object.entries(config.columns)) {\n\t\t\t\t\tif (value === undefined) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (field in tableConfig.columns) {\n\t\t\t\t\t\tif (!isIncludeMode && value === true) {\n\t\t\t\t\t\t\tisIncludeMode = true;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tselectedColumns.push(field);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (selectedColumns.length > 0) {\n\t\t\t\t\tselectedColumns = isIncludeMode\n\t\t\t\t\t\t? selectedColumns.filter((c) => config.columns?.[c] === true)\n\t\t\t\t\t\t: Object.keys(tableConfig.columns).filter((key) => !selectedColumns.includes(key));\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Select all columns if selection is not specified\n\t\t\t\tselectedColumns = Object.keys(tableConfig.columns);\n\t\t\t}\n\n\t\t\tfor (const field of selectedColumns) {\n\t\t\t\tconst column = tableConfig.columns[field]! as MySqlColumn;\n\t\t\t\tfieldsSelection.push({ tsKey: field, value: column });\n\t\t\t}\n\n\t\t\tlet selectedRelations: {\n\t\t\t\ttsKey: string;\n\t\t\t\tqueryConfig: true | V1.DBQueryConfig<'many', false>;\n\t\t\t\trelation: V1.Relation;\n\t\t\t}[] = [];\n\n\t\t\t// Figure out which V1.relations to select\n\t\t\tif (config.with) {\n\t\t\t\tselectedRelations = Object.entries(config.with)\n\t\t\t\t\t.filter((entry): entry is [typeof entry[0], NonNullable<typeof entry[1]>] => !!entry[1])\n\t\t\t\t\t.map(([tsKey, queryConfig]) => ({ tsKey, queryConfig, relation: tableConfig.relations[tsKey]! }));\n\t\t\t}\n\n\t\t\tlet extras;\n\n\t\t\t// Figure out which extras to select\n\t\t\tif (config.extras) {\n\t\t\t\textras = typeof config.extras === 'function'\n\t\t\t\t\t? config.extras(aliasedColumns, { sql })\n\t\t\t\t\t: config.extras;\n\t\t\t\tfor (const [tsKey, value] of Object.entries(extras)) {\n\t\t\t\t\tfieldsSelection.push({\n\t\t\t\t\t\ttsKey,\n\t\t\t\t\t\tvalue: mapColumnsInAliasedSQLToAlias(value, tableAlias),\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Transform `fieldsSelection` into `selection`\n\t\t\t// `fieldsSelection` shouldn't be used after this point\n\t\t\tfor (const { tsKey, value } of fieldsSelection) {\n\t\t\t\tselection.push({\n\t\t\t\t\tdbKey: is(value, SQL.Aliased) ? value.fieldAlias : tableConfig.columns[tsKey]!.name,\n\t\t\t\t\ttsKey,\n\t\t\t\t\tfield: is(value, Column) ? aliasedTableColumn(value, tableAlias) : value,\n\t\t\t\t\trelationTableTsKey: undefined,\n\t\t\t\t\tisJson: false,\n\t\t\t\t\tselection: [],\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tlet orderByOrig = typeof config.orderBy === 'function'\n\t\t\t\t? config.orderBy(aliasedColumns, V1.getOrderByOperators())\n\t\t\t\t: config.orderBy ?? [];\n\t\t\tif (!Array.isArray(orderByOrig)) {\n\t\t\t\torderByOrig = [orderByOrig];\n\t\t\t}\n\t\t\torderBy = orderByOrig.map((orderByValue) => {\n\t\t\t\tif (is(orderByValue, Column)) {\n\t\t\t\t\treturn aliasedTableColumn(orderByValue, tableAlias) as MySqlColumn;\n\t\t\t\t}\n\t\t\t\treturn mapColumnsInSQLToAlias(orderByValue, tableAlias);\n\t\t\t});\n\n\t\t\tlimit = config.limit;\n\t\t\toffset = config.offset;\n\n\t\t\t// Process all V1.relations\n\t\t\tfor (\n\t\t\t\tconst {\n\t\t\t\t\ttsKey: selectedRelationTsKey,\n\t\t\t\t\tqueryConfig: selectedRelationConfigValue,\n\t\t\t\t\trelation,\n\t\t\t\t} of selectedRelations\n\t\t\t) {\n\t\t\t\tconst normalizedRelation = V1.normalizeRelation(schema, tableNamesMap, relation);\n\t\t\t\tconst relationTableName = getTableUniqueName(relation.referencedTable);\n\t\t\t\tconst relationTableTsName = tableNamesMap[relationTableName]!;\n\t\t\t\tconst relationTableAlias = `${tableAlias}_${selectedRelationTsKey}`;\n\t\t\t\tconst joinOn = and(\n\t\t\t\t\t...normalizedRelation.fields.map((field, i) =>\n\t\t\t\t\t\teq(\n\t\t\t\t\t\t\taliasedTableColumn(normalizedRelation.references[i]!, relationTableAlias),\n\t\t\t\t\t\t\taliasedTableColumn(field, tableAlias),\n\t\t\t\t\t\t)\n\t\t\t\t\t),\n\t\t\t\t);\n\t\t\t\tconst builtRelation = this._buildRelationalQuery({\n\t\t\t\t\tfullSchema,\n\t\t\t\t\tschema,\n\t\t\t\t\ttableNamesMap,\n\t\t\t\t\ttable: fullSchema[relationTableTsName] as MySqlTable,\n\t\t\t\t\ttableConfig: schema[relationTableTsName]!,\n\t\t\t\t\tqueryConfig: is(relation, V1.One)\n\t\t\t\t\t\t? (selectedRelationConfigValue === true\n\t\t\t\t\t\t\t? { limit: 1 }\n\t\t\t\t\t\t\t: { ...selectedRelationConfigValue, limit: 1 })\n\t\t\t\t\t\t: selectedRelationConfigValue,\n\t\t\t\t\ttableAlias: relationTableAlias,\n\t\t\t\t\tjoinOn,\n\t\t\t\t\tnestedQueryRelation: relation,\n\t\t\t\t});\n\t\t\t\tconst field = sql`${sql.identifier(relationTableAlias)}.${sql.identifier('data')}`.as(selectedRelationTsKey);\n\t\t\t\tjoins.push({\n\t\t\t\t\ton: sql`true`,\n\t\t\t\t\ttable: new Subquery(builtRelation.sql as SQL, {}, relationTableAlias),\n\t\t\t\t\talias: relationTableAlias,\n\t\t\t\t\tjoinType: 'left',\n\t\t\t\t\tlateral: true,\n\t\t\t\t});\n\t\t\t\tselection.push({\n\t\t\t\t\tdbKey: selectedRelationTsKey,\n\t\t\t\t\ttsKey: selectedRelationTsKey,\n\t\t\t\t\tfield,\n\t\t\t\t\trelationTableTsKey: relationTableTsName,\n\t\t\t\t\tisJson: true,\n\t\t\t\t\tselection: builtRelation.selection,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tif (selection.length === 0) {\n\t\t\tthrow new DrizzleError({ message: `No fields selected for table \"${tableConfig.tsName}\" (\"${tableAlias}\")` });\n\t\t}\n\n\t\tlet result;\n\n\t\twhere = and(joinOn, where);\n\n\t\tif (nestedQueryRelation) {\n\t\t\tlet field = sql`json_array(${\n\t\t\t\tsql.join(\n\t\t\t\t\tselection.map(({ field, tsKey, isJson }) =>\n\t\t\t\t\t\tisJson\n\t\t\t\t\t\t\t? sql`${sql.identifier(`${tableAlias}_${tsKey}`)}.${sql.identifier('data')}`\n\t\t\t\t\t\t\t: is(field, SQL.Aliased)\n\t\t\t\t\t\t\t? field.sql\n\t\t\t\t\t\t\t: field\n\t\t\t\t\t),\n\t\t\t\t\tsql`, `,\n\t\t\t\t)\n\t\t\t})`;\n\t\t\tif (is(nestedQueryRelation, V1.Many)) {\n\t\t\t\tfield = sql`coalesce(json_arrayagg(${field}), json_array())`;\n\t\t\t}\n\t\t\tconst nestedSelection = [{\n\t\t\t\tdbKey: 'data',\n\t\t\t\ttsKey: 'data',\n\t\t\t\tfield: field.as('data'),\n\t\t\t\tisJson: true,\n\t\t\t\trelationTableTsKey: tableConfig.tsName,\n\t\t\t\tselection,\n\t\t\t}];\n\n\t\t\tconst needsSubquery = limit !== undefined || offset !== undefined || (orderBy?.length ?? 0) > 0;\n\n\t\t\tif (needsSubquery) {\n\t\t\t\tresult = this.buildSelectQuery({\n\t\t\t\t\ttable: aliasedTable(table, tableAlias),\n\t\t\t\t\tfields: {},\n\t\t\t\t\tfieldsFlat: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tpath: [],\n\t\t\t\t\t\t\tfield: sql.raw('*'),\n\t\t\t\t\t\t},\n\t\t\t\t\t\t...(((orderBy?.length ?? 0) > 0)\n\t\t\t\t\t\t\t? [{\n\t\t\t\t\t\t\t\tpath: [],\n\t\t\t\t\t\t\t\tfield: sql`row_number() over (order by ${sql.join(orderBy!, sql`, `)})`,\n\t\t\t\t\t\t\t}]\n\t\t\t\t\t\t\t: []),\n\t\t\t\t\t],\n\t\t\t\t\twhere,\n\t\t\t\t\tlimit,\n\t\t\t\t\toffset,\n\t\t\t\t\tsetOperators: [],\n\t\t\t\t});\n\n\t\t\t\twhere = undefined;\n\t\t\t\tlimit = undefined;\n\t\t\t\toffset = undefined;\n\t\t\t\torderBy = undefined;\n\t\t\t} else {\n\t\t\t\tresult = aliasedTable(table, tableAlias);\n\t\t\t}\n\n\t\t\tresult = this.buildSelectQuery({\n\t\t\t\ttable: is(result, MySqlTable) ? result : new Subquery(result, {}, tableAlias),\n\t\t\t\tfields: {},\n\t\t\t\tfieldsFlat: nestedSelection.map(({ field }) => ({\n\t\t\t\t\tpath: [],\n\t\t\t\t\tfield: is(field, Column) ? aliasedTableColumn(field, tableAlias) : field,\n\t\t\t\t})),\n\t\t\t\tjoins,\n\t\t\t\twhere,\n\t\t\t\tlimit,\n\t\t\t\toffset,\n\t\t\t\torderBy,\n\t\t\t\tsetOperators: [],\n\t\t\t});\n\t\t} else {\n\t\t\tresult = this.buildSelectQuery({\n\t\t\t\ttable: aliasedTable(table, tableAlias),\n\t\t\t\tfields: {},\n\t\t\t\tfieldsFlat: selection.map(({ field }) => ({\n\t\t\t\t\tpath: [],\n\t\t\t\t\tfield: is(field, Column) ? aliasedTableColumn(field, tableAlias) : field,\n\t\t\t\t})),\n\t\t\t\tjoins,\n\t\t\t\twhere,\n\t\t\t\tlimit,\n\t\t\t\toffset,\n\t\t\t\torderBy,\n\t\t\t\tsetOperators: [],\n\t\t\t});\n\t\t}\n\n\t\treturn {\n\t\t\ttableTsKey: tableConfig.tsName,\n\t\t\tsql: result,\n\t\t\tselection,\n\t\t};\n\t}\n\n\t/** @deprecated */\n\t_buildRelationalQueryWithoutLateralSubqueries({\n\t\tfullSchema,\n\t\tschema,\n\t\ttableNamesMap,\n\t\ttable,\n\t\ttableConfig,\n\t\tqueryConfig: config,\n\t\ttableAlias,\n\t\tnestedQueryRelation,\n\t\tjoinOn,\n\t}: {\n\t\tfullSchema: Record<string, unknown>;\n\t\tschema: V1.TablesRelationalConfig;\n\t\ttableNamesMap: Record<string, string>;\n\t\ttable: MySqlTable;\n\t\ttableConfig: V1.TableRelationalConfig;\n\t\tqueryConfig: true | V1.DBQueryConfig<'many', true>;\n\t\ttableAlias: string;\n\t\tnestedQueryRelation?: V1.Relation;\n\t\tjoinOn?: SQL;\n\t}): V1.BuildRelationalQueryResult<MySqlTable, MySqlColumn> {\n\t\tlet selection: V1.BuildRelationalQueryResult<MySqlTable, MySqlColumn>['selection'] = [];\n\t\tlet limit, offset, orderBy: MySqlSelectConfig['orderBy'] = [], where;\n\n\t\tif (config === true) {\n\t\t\tconst selectionEntries = Object.entries(tableConfig.columns);\n\t\t\tselection = selectionEntries.map((\n\t\t\t\t[key, value],\n\t\t\t) => ({\n\t\t\t\tdbKey: value.name,\n\t\t\t\ttsKey: key,\n\t\t\t\tfield: aliasedTableColumn(value as MySqlColumn, tableAlias),\n\t\t\t\trelationTableTsKey: undefined,\n\t\t\t\tisJson: false,\n\t\t\t\tselection: [],\n\t\t\t}));\n\t\t} else {\n\t\t\tconst aliasedColumns = Object.fromEntries(\n\t\t\t\tObject.entries(tableConfig.columns).map(([key, value]) => [key, aliasedTableColumn(value, tableAlias)]),\n\t\t\t);\n\n\t\t\tif (config.where) {\n\t\t\t\tconst whereSql = typeof config.where === 'function'\n\t\t\t\t\t? config.where(aliasedColumns, V1.getOperators())\n\t\t\t\t\t: config.where;\n\t\t\t\twhere = whereSql && mapColumnsInSQLToAlias(whereSql, tableAlias);\n\t\t\t}\n\n\t\t\tconst fieldsSelection: { tsKey: string; value: MySqlColumn | SQL.Aliased }[] = [];\n\t\t\tlet selectedColumns: string[] = [];\n\n\t\t\t// Figure out which columns to select\n\t\t\tif (config.columns) {\n\t\t\t\tlet isIncludeMode = false;\n\n\t\t\t\tfor (const [field, value] of Object.entries(config.columns)) {\n\t\t\t\t\tif (value === undefined) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (field in tableConfig.columns) {\n\t\t\t\t\t\tif (!isIncludeMode && value === true) {\n\t\t\t\t\t\t\tisIncludeMode = true;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tselectedColumns.push(field);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (selectedColumns.length > 0) {\n\t\t\t\t\tselectedColumns = isIncludeMode\n\t\t\t\t\t\t? selectedColumns.filter((c) => config.columns?.[c] === true)\n\t\t\t\t\t\t: Object.keys(tableConfig.columns).filter((key) => !selectedColumns.includes(key));\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Select all columns if selection is not specified\n\t\t\t\tselectedColumns = Object.keys(tableConfig.columns);\n\t\t\t}\n\n\t\t\tfor (const field of selectedColumns) {\n\t\t\t\tconst column = tableConfig.columns[field]! as MySqlColumn;\n\t\t\t\tfieldsSelection.push({ tsKey: field, value: column });\n\t\t\t}\n\n\t\t\tlet selectedRelations: {\n\t\t\t\ttsKey: string;\n\t\t\t\tqueryConfig: true | V1.DBQueryConfig<'many', false>;\n\t\t\t\trelation: V1.Relation;\n\t\t\t}[] = [];\n\n\t\t\t// Figure out which V1.relations to select\n\t\t\tif (config.with) {\n\t\t\t\tselectedRelations = Object.entries(config.with)\n\t\t\t\t\t.filter((entry): entry is [typeof entry[0], NonNullable<typeof entry[1]>] => !!entry[1])\n\t\t\t\t\t.map(([tsKey, queryConfig]) => ({ tsKey, queryConfig, relation: tableConfig.relations[tsKey]! }));\n\t\t\t}\n\n\t\t\tlet extras;\n\n\t\t\t// Figure out which extras to select\n\t\t\tif (config.extras) {\n\t\t\t\textras = typeof config.extras === 'function'\n\t\t\t\t\t? config.extras(aliasedColumns, { sql })\n\t\t\t\t\t: config.extras;\n\t\t\t\tfor (const [tsKey, value] of Object.entries(extras)) {\n\t\t\t\t\tfieldsSelection.push({\n\t\t\t\t\t\ttsKey,\n\t\t\t\t\t\tvalue: mapColumnsInAliasedSQLToAlias(value, tableAlias),\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Transform `fieldsSelection` into `selection`\n\t\t\t// `fieldsSelection` shouldn't be used after this point\n\t\t\tfor (const { tsKey, value } of fieldsSelection) {\n\t\t\t\tselection.push({\n\t\t\t\t\tdbKey: is(value, SQL.Aliased) ? value.fieldAlias : tableConfig.columns[tsKey]!.name,\n\t\t\t\t\ttsKey,\n\t\t\t\t\tfield: is(value, Column) ? aliasedTableColumn(value, tableAlias) : value,\n\t\t\t\t\trelationTableTsKey: undefined,\n\t\t\t\t\tisJson: false,\n\t\t\t\t\tselection: [],\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tlet orderByOrig = typeof config.orderBy === 'function'\n\t\t\t\t? config.orderBy(aliasedColumns, V1.getOrderByOperators())\n\t\t\t\t: config.orderBy ?? [];\n\t\t\tif (!Array.isArray(orderByOrig)) {\n\t\t\t\torderByOrig = [orderByOrig];\n\t\t\t}\n\t\t\torderBy = orderByOrig.map((orderByValue) => {\n\t\t\t\tif (is(orderByValue, Column)) {\n\t\t\t\t\treturn aliasedTableColumn(orderByValue, tableAlias) as MySqlColumn;\n\t\t\t\t}\n\t\t\t\treturn mapColumnsInSQLToAlias(orderByValue, tableAlias);\n\t\t\t});\n\n\t\t\tlimit = config.limit;\n\t\t\toffset = config.offset;\n\n\t\t\t// Process all V1.relations\n\t\t\tfor (\n\t\t\t\tconst {\n\t\t\t\t\ttsKey: selectedRelationTsKey,\n\t\t\t\t\tqueryConfig: selectedRelationConfigValue,\n\t\t\t\t\trelation,\n\t\t\t\t} of selectedRelations\n\t\t\t) {\n\t\t\t\tconst normalizedRelation = V1.normalizeRelation(schema, tableNamesMap, relation);\n\t\t\t\tconst relationTableName = getTableUniqueName(relation.referencedTable);\n\t\t\t\tconst relationTableTsName = tableNamesMap[relationTableName]!;\n\t\t\t\tconst relationTableAlias = `${tableAlias}_${selectedRelationTsKey}`;\n\t\t\t\tconst joinOn = and(\n\t\t\t\t\t...normalizedRelation.fields.map((field, i) =>\n\t\t\t\t\t\teq(\n\t\t\t\t\t\t\taliasedTableColumn(normalizedRelation.references[i]!, relationTableAlias),\n\t\t\t\t\t\t\taliasedTableColumn(field, tableAlias),\n\t\t\t\t\t\t)\n\t\t\t\t\t),\n\t\t\t\t);\n\t\t\t\tconst builtRelation = this._buildRelationalQueryWithoutLateralSubqueries({\n\t\t\t\t\tfullSchema,\n\t\t\t\t\tschema,\n\t\t\t\t\ttableNamesMap,\n\t\t\t\t\ttable: fullSchema[relationTableTsName] as MySqlTable,\n\t\t\t\t\ttableConfig: schema[relationTableTsName]!,\n\t\t\t\t\tqueryConfig: is(relation, V1.One)\n\t\t\t\t\t\t? (selectedRelationConfigValue === true\n\t\t\t\t\t\t\t? { limit: 1 }\n\t\t\t\t\t\t\t: { ...selectedRelationConfigValue, limit: 1 })\n\t\t\t\t\t\t: selectedRelationConfigValue,\n\t\t\t\t\ttableAlias: relationTableAlias,\n\t\t\t\t\tjoinOn,\n\t\t\t\t\tnestedQueryRelation: relation,\n\t\t\t\t});\n\t\t\t\tlet fieldSql = sql`(${builtRelation.sql})`;\n\t\t\t\tif (is(relation, V1.Many)) {\n\t\t\t\t\tfieldSql = sql`coalesce(${fieldSql}, json_array())`;\n\t\t\t\t}\n\t\t\t\tconst field = fieldSql.as(selectedRelationTsKey);\n\t\t\t\tselection.push({\n\t\t\t\t\tdbKey: selectedRelationTsKey,\n\t\t\t\t\ttsKey: selectedRelationTsKey,\n\t\t\t\t\tfield,\n\t\t\t\t\trelationTableTsKey: relationTableTsName,\n\t\t\t\t\tisJson: true,\n\t\t\t\t\tselection: builtRelation.selection,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tif (selection.length === 0) {\n\t\t\tthrow new DrizzleError({\n\t\t\t\tmessage:\n\t\t\t\t\t`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.`,\n\t\t\t});\n\t\t}\n\n\t\tlet result;\n\n\t\twhere = and(joinOn, where);\n\n\t\tif (nestedQueryRelation) {\n\t\t\tlet field = sql`json_array(${\n\t\t\t\tsql.join(\n\t\t\t\t\tselection.map(({ field }) =>\n\t\t\t\t\t\tis(field, MySqlColumn)\n\t\t\t\t\t\t\t? sql.identifier(this.casing.getColumnCasing(field))\n\t\t\t\t\t\t\t: is(field, SQL.Aliased)\n\t\t\t\t\t\t\t? field.sql\n\t\t\t\t\t\t\t: field\n\t\t\t\t\t),\n\t\t\t\t\tsql`, `,\n\t\t\t\t)\n\t\t\t})`;\n\t\t\tif (is(nestedQueryRelation, V1.Many)) {\n\t\t\t\tfield = sql`json_arrayagg(${field})`;\n\t\t\t}\n\t\t\tconst nestedSelection = [{\n\t\t\t\tdbKey: 'data',\n\t\t\t\ttsKey: 'data',\n\t\t\t\tfield,\n\t\t\t\tisJson: true,\n\t\t\t\trelationTableTsKey: tableConfig.tsName,\n\t\t\t\tselection,\n\t\t\t}];\n\n\t\t\tconst needsSubquery = limit !== undefined || offset !== undefined || orderBy.length > 0;\n\n\t\t\tif (needsSubquery) {\n\t\t\t\tresult = this.buildSelectQuery({\n\t\t\t\t\ttable: aliasedTable(table, tableAlias),\n\t\t\t\t\tfields: {},\n\t\t\t\t\tfieldsFlat: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tpath: [],\n\t\t\t\t\t\t\tfield: sql.raw('*'),\n\t\t\t\t\t\t},\n\t\t\t\t\t\t...(orderBy.length > 0)\n\t\t\t\t\t\t\t? [{\n\t\t\t\t\t\t\t\tpath: [],\n\t\t\t\t\t\t\t\tfield: sql`row_number() over (order by ${sql.join(orderBy, sql`, `)})`,\n\t\t\t\t\t\t\t}]\n\t\t\t\t\t\t\t: [],\n\t\t\t\t\t],\n\t\t\t\t\twhere,\n\t\t\t\t\tlimit,\n\t\t\t\t\toffset,\n\t\t\t\t\tsetOperators: [],\n\t\t\t\t});\n\n\t\t\t\twhere = undefined;\n\t\t\t\tlimit = undefined;\n\t\t\t\toffset = undefined;\n\t\t\t\torderBy = undefined;\n\t\t\t} else {\n\t\t\t\tresult = aliasedTable(table, tableAlias);\n\t\t\t}\n\n\t\t\tresult = this.buildSelectQuery({\n\t\t\t\ttable: is(result, MySqlTable) ? result : new Subquery(result, {}, tableAlias),\n\t\t\t\tfields: {},\n\t\t\t\tfieldsFlat: nestedSelection.map(({ field }) => ({\n\t\t\t\t\tpath: [],\n\t\t\t\t\tfield: is(field, Column) ? aliasedTableColumn(field, tableAlias) : field,\n\t\t\t\t})),\n\t\t\t\twhere,\n\t\t\t\tlimit,\n\t\t\t\toffset,\n\t\t\t\torderBy,\n\t\t\t\tsetOperators: [],\n\t\t\t});\n\t\t} else {\n\t\t\tresult = this.buildSelectQuery({\n\t\t\t\ttable: aliasedTable(table, tableAlias),\n\t\t\t\tfields: {},\n\t\t\t\tfieldsFlat: selection.map(({ field }) => ({\n\t\t\t\t\tpath: [],\n\t\t\t\t\tfield: is(field, Column) ? aliasedTableColumn(field, tableAlias) : field,\n\t\t\t\t})),\n\t\t\t\twhere,\n\t\t\t\tlimit,\n\t\t\t\toffset,\n\t\t\t\torderBy,\n\t\t\t\tsetOperators: [],\n\t\t\t});\n\t\t}\n\n\t\treturn {\n\t\t\ttableTsKey: tableConfig.tsName,\n\t\t\tsql: result,\n\t\t\tselection,\n\t\t};\n\t}\n\n\tprivate nestedSelectionerror() {\n\t\tthrow new DrizzleError({\n\t\t\tmessage: `Views with nested selections are not supported by the relational query builder`,\n\t\t});\n\t}\n\n\tprivate buildRqbColumn(table: Table | View, column: unknown, key: string) {\n\t\tif (is(column, Column)) {\n\t\t\tconst name = sql`${table}.${sql.identifier(this.casing.getColumnCasing(column))}`;\n\n\t\t\tswitch (column.columnType) {\n\t\t\t\tcase 'MySqlBinary':\n\t\t\t\tcase 'MySqlVarBinary':\n\t\t\t\tcase 'MySqlTime':\n\t\t\t\tcase 'MySqlDateTimeString':\n\t\t\t\tcase 'MySqlTimestampString':\n\t\t\t\tcase 'MySqlFloat':\n\t\t\t\tcase 'MySqlDecimal':\n\t\t\t\tcase 'MySqlDecimalNumber':\n\t\t\t\tcase 'MySqlDecimalBigInt':\n\t\t\t\tcase 'MySqlBigInt64':\n\t\t\t\tcase 'MySqlBigIntString': {\n\t\t\t\t\treturn sql`cast(${name} as char) as ${sql.identifier(key)}`;\n\t\t\t\t}\n\n\t\t\t\tcase 'MySqlCustomColumn': {\n\t\t\t\t\treturn sql`${(<MySqlCustomColumn<any>> column).jsonSelectIdentifier(name, sql)} as ${sql.identifier(key)}`;\n\t\t\t\t}\n\n\t\t\t\tdefault: {\n\t\t\t\t\treturn sql`${name} as ${sql.identifier(key)}`;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn sql`${table}.${\n\t\t\tis(column, SQL.Aliased)\n\t\t\t\t? sql.identifier(column.fieldAlias)\n\t\t\t\t: isSQLWrapper(column)\n\t\t\t\t? sql.identifier(key)\n\t\t\t\t: this.nestedSelectionerror()\n\t\t} as ${sql.identifier(key)}`;\n\t}\n\n\tprivate unwrapAllColumns = (table: Table | View, selection: BuildRelationalQueryResult['selection']) => {\n\t\treturn sql.join(\n\t\t\tObject.entries(table[TableColumns]).map(([k, v]) => {\n\t\t\t\tselection.push({\n\t\t\t\t\tkey: k,\n\t\t\t\t\tfield: v as Column | SQL | SQLWrapper | SQL.Aliased,\n\t\t\t\t});\n\n\t\t\t\treturn this.buildRqbColumn(table, v, k);\n\t\t\t}),\n\t\t\tsql`, `,\n\t\t);\n\t};\n\n\tprivate getSelectedTableColumns = (table: Table | View, columns: Record<string, boolean | undefined>) => {\n\t\tconst selectedColumns: ColumnWithTSName[] = [];\n\t\tconst columnContainer = table[TableColumns];\n\t\tconst entries = Object.entries(columns);\n\n\t\tlet colSelectionMode: boolean | undefined;\n\t\tfor (const [k, v] of entries) {\n\t\t\tif (v === undefined) continue;\n\t\t\tcolSelectionMode = colSelectionMode || v;\n\n\t\t\tif (v) {\n\t\t\t\tconst column = columnContainer[k]!;\n\n\t\t\t\tselectedColumns.push({\n\t\t\t\t\tcolumn: column as Column | SQL | SQLWrapper | SQL.Aliased,\n\t\t\t\t\ttsName: k,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tif (colSelectionMode === false) {\n\t\t\tfor (const [k, v] of Object.entries(columnContainer)) {\n\t\t\t\tif (columns[k] === false) continue;\n\n\t\t\t\tselectedColumns.push({\n\t\t\t\t\tcolumn: v as Column | SQL | SQLWrapper | SQL.Aliased | Table,\n\t\t\t\t\ttsName: k,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\treturn selectedColumns;\n\t};\n\n\tprivate buildColumns = (\n\t\ttable: MySqlTable | MySqlView,\n\t\tselection: BuildRelationalQueryResult['selection'],\n\t\tparams?: DBQueryConfig<'many'>,\n\t) =>\n\t\tparams?.columns\n\t\t\t? (() => {\n\t\t\t\tconst columnIdentifiers: SQL[] = [];\n\n\t\t\t\tconst selectedColumns = this.getSelectedTableColumns(table, params.columns);\n\n\t\t\t\tfor (const { column, tsName } of selectedColumns) {\n\t\t\t\t\tcolumnIdentifiers.push(this.buildRqbColumn(table, column, tsName));\n\n\t\t\t\t\tselection.push({\n\t\t\t\t\t\tkey: tsName,\n\t\t\t\t\t\tfield: column,\n\t\t\t\t\t});\n\t\t\t\t}\n\n\t\t\t\treturn columnIdentifiers.length\n\t\t\t\t\t? sql.join(columnIdentifiers, sql`, `)\n\t\t\t\t\t: undefined;\n\t\t\t})()\n\t\t\t: this.unwrapAllColumns(table, selection);\n\n\tbuildRelationalQuery(\n\t\t{\n\t\t\tschema,\n\t\t\ttable,\n\t\t\ttableConfig,\n\t\t\tqueryConfig: config,\n\t\t\trelationWhere,\n\t\t\tmode,\n\t\t\terrorPath,\n\t\t\tdepth,\n\t\t\tisNestedMany,\n\t\t\tthroughJoin,\n\t\t}: {\n\t\t\tschema: TablesRelationalConfig;\n\t\t\ttable: MySqlTable | MySqlView;\n\t\t\ttableConfig: TableRelationalConfig;\n\t\t\tqueryConfig?: DBQueryConfig<'many'> | true;\n\t\t\trelationWhere?: SQL;\n\t\t\tmode: 'first' | 'many';\n\t\t\terrorPath?: string;\n\t\t\tdepth?: number;\n\t\t\tisNestedMany?: boolean;\n\t\t\tthroughJoin?: SQL;\n\t\t},\n\t): BuildRelationalQueryResult {\n\t\tconst selection: BuildRelationalQueryResult['selection'] = [];\n\t\tconst isSingle = mode === 'first';\n\t\tconst params = config === true ? undefined : config;\n\t\tconst currentPath = errorPath ?? '';\n\t\tconst currentDepth = depth ?? 0;\n\t\tif (!currentDepth) table = aliasedTable(table, `d${currentDepth}`);\n\n\t\tconst limit = isSingle ? 1 : params?.limit;\n\t\tconst offset = params?.offset;\n\n\t\tconst columns = this.buildColumns(table, selection, params);\n\n\t\tconst where: SQL | undefined = (params?.where && relationWhere)\n\t\t\t? and(\n\t\t\t\trelationsFilterToSQL(table, params.where, tableConfig.relations, schema, this.casing),\n\t\t\t\trelationWhere,\n\t\t\t)\n\t\t\t: params?.where\n\t\t\t? relationsFilterToSQL(table, params.where, tableConfig.relations, schema, this.casing)\n\t\t\t: relationWhere;\n\t\tconst order = params?.orderBy ? relationsOrderToSQL(table, params.orderBy) : undefined;\n\t\tconst extras = params?.extras ? relationExtrasToSQL(table, params.extras) : undefined;\n\t\tif (extras) selection.push(...extras.selection);\n\n\t\tconst selectionArr: SQL[] = columns ? [columns] : [];\n\n\t\tconst joins = params\n\t\t\t? (() => {\n\t\t\t\tconst { with: joins } = params as WithContainer;\n\t\t\t\tif (!joins) return;\n\n\t\t\t\tconst withEntries = Object.entries(joins).filter(([_, v]) => v);\n\t\t\t\tif (!withEntries.length) return;\n\n\t\t\t\treturn sql.join(\n\t\t\t\t\twithEntries.map(([k, join]) => {\n\t\t\t\t\t\tselectionArr.push(sql`${sql.identifier(k)}.${sql.identifier('r')} as ${sql.identifier(k)}`);\n\n\t\t\t\t\t\t// if (is(tableConfig.relations[k]!, AggregatedField)) {\n\t\t\t\t\t\t// \tconst relation = tableConfig.relations[k]!;\n\t\t\t\t\t\t// \trelation.onTable(table);\n\t\t\t\t\t\t// \tconst query = relation.getSQL();\n\n\t\t\t\t\t\t// \tselection.push({\n\t\t\t\t\t\t// \t\tkey: k,\n\t\t\t\t\t\t// \t\tfield: relation,\n\t\t\t\t\t\t// \t});\n\n\t\t\t\t\t\t// \treturn sql` left join lateral (${query}) as ${sql.identifier(k)} on true`;\n\t\t\t\t\t\t// }\n\n\t\t\t\t\t\tconst relation = tableConfig.relations[k]! as Relation;\n\t\t\t\t\t\tconst isSingle = is(relation, One);\n\t\t\t\t\t\tconst targetTable = aliasedTable(relation.targetTable, `d${currentDepth + 1}`);\n\t\t\t\t\t\tconst throughTable = relation.throughTable\n\t\t\t\t\t\t\t? aliasedTable(relation.throughTable, `tr${currentDepth}`)\n\t\t\t\t\t\t\t: undefined;\n\t\t\t\t\t\tconst { filter, joinCondition } = relationToSQL(\n\t\t\t\t\t\t\tthis.casing,\n\t\t\t\t\t\t\trelation,\n\t\t\t\t\t\t\ttable,\n\t\t\t\t\t\t\ttargetTable,\n\t\t\t\t\t\t\tthroughTable,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tconst throughJoin = throughTable\n\t\t\t\t\t\t\t? sql` inner join ${getTableAsAliasSQL(throughTable)} on ${joinCondition!}`\n\t\t\t\t\t\t\t: undefined;\n\n\t\t\t\t\t\tconst innerQuery = this.buildRelationalQuery({\n\t\t\t\t\t\t\ttable: targetTable as MySqlTable,\n\t\t\t\t\t\t\tmode: isSingle ? 'first' : 'many',\n\t\t\t\t\t\t\tschema,\n\t\t\t\t\t\t\tqueryConfig: join as DBQueryConfig,\n\t\t\t\t\t\t\ttableConfig: schema[relation.targetTableName]!,\n\t\t\t\t\t\t\trelationWhere: filter,\n\t\t\t\t\t\t\terrorPath: `${currentPath.length ? `${currentPath}.` : ''}${k}`,\n\t\t\t\t\t\t\tdepth: currentDepth + 1,\n\t\t\t\t\t\t\tisNestedMany: !isSingle,\n\t\t\t\t\t\t\tthroughJoin,\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tselection.push({\n\t\t\t\t\t\t\tfield: targetTable,\n\t\t\t\t\t\t\tkey: k,\n\t\t\t\t\t\t\tselection: innerQuery.selection,\n\t\t\t\t\t\t\tisArray: !isSingle,\n\t\t\t\t\t\t\tisOptional: ((relation as AnyOne).optional ?? false)\n\t\t\t\t\t\t\t\t|| (join !== true && !!(join as Exclude<typeof join, boolean | undefined>).where),\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tconst jsonColumns = sql.join(\n\t\t\t\t\t\t\tinnerQuery.selection.map((s) => sql`${sql.raw(this.escapeString(s.key))}, ${sql.identifier(s.key)}`),\n\t\t\t\t\t\t\tsql`, `,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tconst joinQuery = sql` left join lateral(select ${sql`${\n\t\t\t\t\t\t\tisSingle\n\t\t\t\t\t\t\t\t? sql`json_object(${jsonColumns})`\n\t\t\t\t\t\t\t\t: sql`coalesce(json_arrayagg(json_object(${jsonColumns})), json_array())`\n\t\t\t\t\t\t} as ${sql.identifier('r')}`} from (${innerQuery.sql}) as ${sql.identifier('t')}) as ${\n\t\t\t\t\t\t\tsql.identifier(k)\n\t\t\t\t\t\t} on true`;\n\n\t\t\t\t\t\treturn joinQuery;\n\t\t\t\t\t}),\n\t\t\t\t);\n\t\t\t})()\n\t\t\t: undefined;\n\n\t\tif (extras?.sql) selectionArr.push(extras.sql);\n\t\tif (!selectionArr.length) {\n\t\t\tthrow new DrizzleError({\n\t\t\t\tmessage: `No fields selected for table \"${tableConfig.name}\"${currentPath ? ` (\"${currentPath}\")` : ''}`,\n\t\t\t});\n\t\t}\n\t\t// json_arrayagg() ignores order by clause otherwise\n\t\tif (isNestedMany && order) {\n\t\t\tselectionArr.push(sql`row_number() over (order by ${order})`);\n\t\t}\n\t\tconst selectionSet = sql.join(selectionArr, sql`, `);\n\n\t\tconst query = sql`select ${selectionSet} from ${getTableAsAliasSQL(table)}${throughJoin}${sql`${joins}`.if(joins)}${\n\t\t\tsql` where ${where}`.if(where)\n\t\t}${sql` order by ${order}`.if(order)}${sql` limit ${limit}`.if(limit !== undefined)}${\n\t\t\tsql` offset ${offset}`.if(offset !== undefined)\n\t\t}`;\n\n\t\treturn {\n\t\t\tsql: query,\n\t\t\tselection,\n\t\t};\n\t}\n}\n"],"mappings":"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","names":["import_table","table","useIndexSql","forceIndexSql","ignoreIndexSql","select","sql","joinOn","field","joins","isSingle","throughJoin"]}
@@ -15,6 +15,7 @@ import { MySqlTable } from "./table.cjs";
15
15
  import type { MySqlView } from "./view.cjs";
16
16
  export interface MySqlDialectConfig {
17
17
  casing?: Casing;
18
+ escapeParam?: (num: number) => string;
18
19
  }
19
20
  export declare class MySqlDialect {
20
21
  static readonly [entityKind]: string;
@@ -15,6 +15,7 @@ import { MySqlTable } from "./table.js";
15
15
  import type { MySqlView } from "./view.js";
16
16
  export interface MySqlDialectConfig {
17
17
  casing?: Casing;
18
+ escapeParam?: (num: number) => string;
18
19
  }
19
20
  export declare class MySqlDialect {
20
21
  static readonly [entityKind]: string;
@@ -1,5 +1,11 @@
1
1
  import * as V1 from "../_relations.js";
2
- import { aliasedTable, aliasedTableColumn, mapColumnsInAliasedSQLToAlias, mapColumnsInSQLToAlias } from "../alias.js";
2
+ import {
3
+ aliasedTable,
4
+ aliasedTableColumn,
5
+ getOriginalColumnFromAlias,
6
+ mapColumnsInAliasedSQLToAlias,
7
+ mapColumnsInSQLToAlias
8
+ } from "../alias.js";
3
9
  import { CasingCache } from "../casing.js";
4
10
  import { Column } from "../column.js";
5
11
  import { entityKind, is } from "../entity.js";
@@ -27,6 +33,9 @@ class MySqlDialect {
27
33
  casing;
28
34
  constructor(config) {
29
35
  this.casing = new CasingCache(config?.casing);
36
+ if (config?.escapeParam) {
37
+ this.escapeParam = config.escapeParam;
38
+ }
30
39
  }
31
40
  async migrate(migrations, session, config) {
32
41
  const migrationsTable = config.migrationsTable ?? "__drizzle_migrations";
@@ -162,9 +171,11 @@ class MySqlDialect {
162
171
  }
163
172
  } else if (is(field, Column)) {
164
173
  if (isSingleTable) {
165
- chunk.push(sql.identifier(this.casing.getColumnCasing(field)));
174
+ chunk.push(
175
+ field.isAlias ? sql`${sql.identifier(this.casing.getColumnCasing(getOriginalColumnFromAlias(field)))} as ${field}` : sql.identifier(this.casing.getColumnCasing(field))
176
+ );
166
177
  } else {
167
- chunk.push(field);
178
+ chunk.push(field.isAlias ? sql`${getOriginalColumnFromAlias(field)} as ${field}` : field);
168
179
  }
169
180
  } else if (is(field, Subquery)) {
170
181
  const entries = Object.entries(field._.selectedFields);