drizzle-orm 0.34.0-ff1e9a5 → 0.34.1-1f0b52f

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 (925) hide show
  1. package/aws-data-api/common/index.d.cts +1 -1
  2. package/aws-data-api/common/index.d.ts +1 -1
  3. package/aws-data-api/pg/driver.cjs +9 -8
  4. package/aws-data-api/pg/driver.cjs.map +1 -1
  5. package/aws-data-api/pg/driver.d.cts +1 -1
  6. package/aws-data-api/pg/driver.d.ts +1 -1
  7. package/aws-data-api/pg/driver.js +3 -2
  8. package/aws-data-api/pg/driver.js.map +1 -1
  9. package/aws-data-api/pg/session.cjs.map +1 -1
  10. package/aws-data-api/pg/session.d.cts +1 -1
  11. package/aws-data-api/pg/session.d.ts +1 -1
  12. package/aws-data-api/pg/session.js.map +1 -1
  13. package/better-sqlite3/driver.cjs +1 -1
  14. package/better-sqlite3/driver.cjs.map +1 -1
  15. package/better-sqlite3/driver.js +1 -1
  16. package/better-sqlite3/driver.js.map +1 -1
  17. package/better-sqlite3/session.cjs.map +1 -1
  18. package/better-sqlite3/session.js.map +1 -1
  19. package/bun-sqlite/driver.cjs +1 -1
  20. package/bun-sqlite/driver.cjs.map +1 -1
  21. package/bun-sqlite/driver.d.cts +0 -1
  22. package/bun-sqlite/driver.d.ts +0 -1
  23. package/bun-sqlite/driver.js +1 -1
  24. package/bun-sqlite/driver.js.map +1 -1
  25. package/bun-sqlite/session.cjs.map +1 -1
  26. package/bun-sqlite/session.d.cts +0 -1
  27. package/bun-sqlite/session.d.ts +0 -1
  28. package/bun-sqlite/session.js.map +1 -1
  29. package/casing.cjs +85 -0
  30. package/casing.cjs.map +1 -0
  31. package/casing.d.cts +14 -0
  32. package/casing.d.ts +14 -0
  33. package/casing.js +59 -0
  34. package/casing.js.map +1 -0
  35. package/column-builder.cjs +7 -0
  36. package/column-builder.cjs.map +1 -1
  37. package/column-builder.d.cts +11 -6
  38. package/column-builder.d.ts +11 -6
  39. package/column-builder.js +7 -0
  40. package/column-builder.js.map +1 -1
  41. package/column.cjs +2 -0
  42. package/column.cjs.map +1 -1
  43. package/column.d.cts +1 -0
  44. package/column.d.ts +1 -0
  45. package/column.js +2 -0
  46. package/column.js.map +1 -1
  47. package/connect.cjs +25 -0
  48. package/connect.cjs.map +1 -0
  49. package/connect.d.cts +2 -0
  50. package/connect.d.ts +2 -0
  51. package/connect.js +3 -0
  52. package/connect.js.map +1 -0
  53. package/d1/driver.cjs +1 -1
  54. package/d1/driver.cjs.map +1 -1
  55. package/d1/driver.d.cts +0 -1
  56. package/d1/driver.d.ts +0 -1
  57. package/d1/driver.js +1 -1
  58. package/d1/driver.js.map +1 -1
  59. package/d1/session.cjs.map +1 -1
  60. package/d1/session.d.cts +0 -1
  61. package/d1/session.d.ts +0 -1
  62. package/d1/session.js.map +1 -1
  63. package/entity.cjs +1 -1
  64. package/entity.cjs.map +1 -1
  65. package/entity.js +1 -1
  66. package/entity.js.map +1 -1
  67. package/errors.cjs.map +1 -1
  68. package/errors.js.map +1 -1
  69. package/expo-sqlite/driver.cjs +1 -1
  70. package/expo-sqlite/driver.cjs.map +1 -1
  71. package/expo-sqlite/driver.js +1 -1
  72. package/expo-sqlite/driver.js.map +1 -1
  73. package/expo-sqlite/query.cjs +8 -6
  74. package/expo-sqlite/query.cjs.map +1 -1
  75. package/expo-sqlite/query.js +3 -1
  76. package/expo-sqlite/query.js.map +1 -1
  77. package/expo-sqlite/session.cjs.map +1 -1
  78. package/expo-sqlite/session.js.map +1 -1
  79. package/index.cjs +0 -4
  80. package/index.cjs.map +1 -1
  81. package/index.d.cts +0 -2
  82. package/index.d.ts +0 -2
  83. package/index.js +0 -2
  84. package/index.js.map +1 -1
  85. package/libsql/driver.cjs +1 -1
  86. package/libsql/driver.cjs.map +1 -1
  87. package/libsql/driver.js +1 -1
  88. package/libsql/driver.js.map +1 -1
  89. package/libsql/session.cjs.map +1 -1
  90. package/libsql/session.js.map +1 -1
  91. package/monodriver.cjs +14 -14
  92. package/monodriver.cjs.map +1 -1
  93. package/monodriver.d.cts +0 -2
  94. package/monodriver.d.ts +0 -2
  95. package/monodriver.js +14 -14
  96. package/monodriver.js.map +1 -1
  97. package/monomigrator.cjs +14 -14
  98. package/monomigrator.cjs.map +1 -1
  99. package/monomigrator.js +14 -14
  100. package/monomigrator.js.map +1 -1
  101. package/mysql-core/columns/all.cjs +80 -0
  102. package/mysql-core/columns/all.cjs.map +1 -0
  103. package/mysql-core/columns/all.d.cts +51 -0
  104. package/mysql-core/columns/all.d.ts +51 -0
  105. package/mysql-core/columns/all.js +56 -0
  106. package/mysql-core/columns/all.js.map +1 -0
  107. package/mysql-core/columns/bigint.cjs +3 -1
  108. package/mysql-core/columns/bigint.cjs.map +1 -1
  109. package/mysql-core/columns/bigint.d.cts +2 -2
  110. package/mysql-core/columns/bigint.d.ts +2 -2
  111. package/mysql-core/columns/bigint.js +3 -1
  112. package/mysql-core/columns/bigint.js.map +1 -1
  113. package/mysql-core/columns/binary.cjs +3 -1
  114. package/mysql-core/columns/binary.cjs.map +1 -1
  115. package/mysql-core/columns/binary.d.cts +2 -0
  116. package/mysql-core/columns/binary.d.ts +2 -0
  117. package/mysql-core/columns/binary.js +3 -1
  118. package/mysql-core/columns/binary.js.map +1 -1
  119. package/mysql-core/columns/boolean.cjs +1 -1
  120. package/mysql-core/columns/boolean.cjs.map +1 -1
  121. package/mysql-core/columns/boolean.d.cts +1 -0
  122. package/mysql-core/columns/boolean.d.ts +1 -0
  123. package/mysql-core/columns/boolean.js +1 -1
  124. package/mysql-core/columns/boolean.js.map +1 -1
  125. package/mysql-core/columns/char.cjs +3 -1
  126. package/mysql-core/columns/char.cjs.map +1 -1
  127. package/mysql-core/columns/char.d.cts +4 -2
  128. package/mysql-core/columns/char.d.ts +4 -2
  129. package/mysql-core/columns/char.js +3 -1
  130. package/mysql-core/columns/char.js.map +1 -1
  131. package/mysql-core/columns/common.cjs.map +1 -1
  132. package/mysql-core/columns/common.js.map +1 -1
  133. package/mysql-core/columns/custom.cjs +4 -2
  134. package/mysql-core/columns/custom.cjs.map +1 -1
  135. package/mysql-core/columns/custom.d.cts +10 -3
  136. package/mysql-core/columns/custom.d.ts +10 -3
  137. package/mysql-core/columns/custom.js +4 -2
  138. package/mysql-core/columns/custom.js.map +1 -1
  139. package/mysql-core/columns/date.cjs +4 -2
  140. package/mysql-core/columns/date.cjs.map +1 -1
  141. package/mysql-core/columns/date.common.cjs.map +1 -1
  142. package/mysql-core/columns/date.common.js.map +1 -1
  143. package/mysql-core/columns/date.d.cts +3 -1
  144. package/mysql-core/columns/date.d.ts +3 -1
  145. package/mysql-core/columns/date.js +4 -2
  146. package/mysql-core/columns/date.js.map +1 -1
  147. package/mysql-core/columns/datetime.cjs +4 -2
  148. package/mysql-core/columns/datetime.cjs.map +1 -1
  149. package/mysql-core/columns/datetime.d.cts +3 -1
  150. package/mysql-core/columns/datetime.d.ts +3 -1
  151. package/mysql-core/columns/datetime.js +4 -2
  152. package/mysql-core/columns/datetime.js.map +1 -1
  153. package/mysql-core/columns/decimal.cjs +3 -1
  154. package/mysql-core/columns/decimal.cjs.map +1 -1
  155. package/mysql-core/columns/decimal.d.cts +2 -0
  156. package/mysql-core/columns/decimal.d.ts +2 -0
  157. package/mysql-core/columns/decimal.js +3 -1
  158. package/mysql-core/columns/decimal.js.map +1 -1
  159. package/mysql-core/columns/double.cjs +3 -1
  160. package/mysql-core/columns/double.cjs.map +1 -1
  161. package/mysql-core/columns/double.d.cts +2 -0
  162. package/mysql-core/columns/double.d.ts +2 -0
  163. package/mysql-core/columns/double.js +3 -1
  164. package/mysql-core/columns/double.js.map +1 -1
  165. package/mysql-core/columns/enum.cjs +3 -1
  166. package/mysql-core/columns/enum.cjs.map +1 -1
  167. package/mysql-core/columns/enum.d.cts +2 -1
  168. package/mysql-core/columns/enum.d.ts +2 -1
  169. package/mysql-core/columns/enum.js +3 -1
  170. package/mysql-core/columns/enum.js.map +1 -1
  171. package/mysql-core/columns/float.cjs +1 -1
  172. package/mysql-core/columns/float.cjs.map +1 -1
  173. package/mysql-core/columns/float.d.cts +1 -0
  174. package/mysql-core/columns/float.d.ts +1 -0
  175. package/mysql-core/columns/float.js +1 -1
  176. package/mysql-core/columns/float.js.map +1 -1
  177. package/mysql-core/columns/int.cjs +3 -1
  178. package/mysql-core/columns/int.cjs.map +1 -1
  179. package/mysql-core/columns/int.d.cts +2 -0
  180. package/mysql-core/columns/int.d.ts +2 -0
  181. package/mysql-core/columns/int.js +3 -1
  182. package/mysql-core/columns/int.js.map +1 -1
  183. package/mysql-core/columns/json.cjs +1 -1
  184. package/mysql-core/columns/json.cjs.map +1 -1
  185. package/mysql-core/columns/json.d.cts +1 -0
  186. package/mysql-core/columns/json.d.ts +1 -0
  187. package/mysql-core/columns/json.js +1 -1
  188. package/mysql-core/columns/json.js.map +1 -1
  189. package/mysql-core/columns/mediumint.cjs +3 -1
  190. package/mysql-core/columns/mediumint.cjs.map +1 -1
  191. package/mysql-core/columns/mediumint.d.cts +2 -0
  192. package/mysql-core/columns/mediumint.d.ts +2 -0
  193. package/mysql-core/columns/mediumint.js +3 -1
  194. package/mysql-core/columns/mediumint.js.map +1 -1
  195. package/mysql-core/columns/real.cjs +3 -1
  196. package/mysql-core/columns/real.cjs.map +1 -1
  197. package/mysql-core/columns/real.d.cts +2 -0
  198. package/mysql-core/columns/real.d.ts +2 -0
  199. package/mysql-core/columns/real.js +3 -1
  200. package/mysql-core/columns/real.js.map +1 -1
  201. package/mysql-core/columns/serial.cjs +1 -1
  202. package/mysql-core/columns/serial.cjs.map +1 -1
  203. package/mysql-core/columns/serial.d.cts +1 -0
  204. package/mysql-core/columns/serial.d.ts +1 -0
  205. package/mysql-core/columns/serial.js +1 -1
  206. package/mysql-core/columns/serial.js.map +1 -1
  207. package/mysql-core/columns/smallint.cjs +3 -1
  208. package/mysql-core/columns/smallint.cjs.map +1 -1
  209. package/mysql-core/columns/smallint.d.cts +2 -0
  210. package/mysql-core/columns/smallint.d.ts +2 -0
  211. package/mysql-core/columns/smallint.js +3 -1
  212. package/mysql-core/columns/smallint.js.map +1 -1
  213. package/mysql-core/columns/text.cjs +9 -4
  214. package/mysql-core/columns/text.cjs.map +1 -1
  215. package/mysql-core/columns/text.d.cts +10 -2
  216. package/mysql-core/columns/text.d.ts +10 -2
  217. package/mysql-core/columns/text.js +9 -4
  218. package/mysql-core/columns/text.js.map +1 -1
  219. package/mysql-core/columns/time.cjs +3 -1
  220. package/mysql-core/columns/time.cjs.map +1 -1
  221. package/mysql-core/columns/time.d.cts +2 -0
  222. package/mysql-core/columns/time.d.ts +2 -0
  223. package/mysql-core/columns/time.js +3 -1
  224. package/mysql-core/columns/time.js.map +1 -1
  225. package/mysql-core/columns/timestamp.cjs +4 -2
  226. package/mysql-core/columns/timestamp.cjs.map +1 -1
  227. package/mysql-core/columns/timestamp.d.cts +3 -1
  228. package/mysql-core/columns/timestamp.d.ts +3 -1
  229. package/mysql-core/columns/timestamp.js +4 -2
  230. package/mysql-core/columns/timestamp.js.map +1 -1
  231. package/mysql-core/columns/tinyint.cjs +3 -1
  232. package/mysql-core/columns/tinyint.cjs.map +1 -1
  233. package/mysql-core/columns/tinyint.d.cts +2 -0
  234. package/mysql-core/columns/tinyint.d.ts +2 -0
  235. package/mysql-core/columns/tinyint.js +3 -1
  236. package/mysql-core/columns/tinyint.js.map +1 -1
  237. package/mysql-core/columns/varbinary.cjs +4 -2
  238. package/mysql-core/columns/varbinary.cjs.map +1 -1
  239. package/mysql-core/columns/varbinary.d.cts +2 -1
  240. package/mysql-core/columns/varbinary.d.ts +2 -1
  241. package/mysql-core/columns/varbinary.js +4 -2
  242. package/mysql-core/columns/varbinary.js.map +1 -1
  243. package/mysql-core/columns/varchar.cjs +3 -1
  244. package/mysql-core/columns/varchar.cjs.map +1 -1
  245. package/mysql-core/columns/varchar.d.cts +3 -2
  246. package/mysql-core/columns/varchar.d.ts +3 -2
  247. package/mysql-core/columns/varchar.js +3 -1
  248. package/mysql-core/columns/varchar.js.map +1 -1
  249. package/mysql-core/columns/year.cjs +1 -1
  250. package/mysql-core/columns/year.cjs.map +1 -1
  251. package/mysql-core/columns/year.d.cts +1 -0
  252. package/mysql-core/columns/year.d.ts +1 -0
  253. package/mysql-core/columns/year.js +1 -1
  254. package/mysql-core/columns/year.js.map +1 -1
  255. package/mysql-core/db.cjs +2 -1
  256. package/mysql-core/db.cjs.map +1 -1
  257. package/mysql-core/db.d.cts +3 -3
  258. package/mysql-core/db.d.ts +3 -3
  259. package/mysql-core/db.js +2 -1
  260. package/mysql-core/db.js.map +1 -1
  261. package/mysql-core/dialect.cjs +31 -20
  262. package/mysql-core/dialect.cjs.map +1 -1
  263. package/mysql-core/dialect.d.cts +9 -3
  264. package/mysql-core/dialect.d.ts +9 -3
  265. package/mysql-core/dialect.js +31 -20
  266. package/mysql-core/dialect.js.map +1 -1
  267. package/mysql-core/foreign-keys.cjs +3 -3
  268. package/mysql-core/foreign-keys.cjs.map +1 -1
  269. package/mysql-core/foreign-keys.d.cts +1 -1
  270. package/mysql-core/foreign-keys.d.ts +1 -1
  271. package/mysql-core/foreign-keys.js +3 -3
  272. package/mysql-core/foreign-keys.js.map +1 -1
  273. package/mysql-core/query-builders/count.cjs +4 -4
  274. package/mysql-core/query-builders/count.cjs.map +1 -1
  275. package/mysql-core/query-builders/count.d.cts +2 -3
  276. package/mysql-core/query-builders/count.d.ts +2 -3
  277. package/mysql-core/query-builders/count.js +2 -2
  278. package/mysql-core/query-builders/count.js.map +1 -1
  279. package/mysql-core/query-builders/delete.cjs +22 -0
  280. package/mysql-core/query-builders/delete.cjs.map +1 -1
  281. package/mysql-core/query-builders/delete.d.cts +8 -1
  282. package/mysql-core/query-builders/delete.d.ts +8 -1
  283. package/mysql-core/query-builders/delete.js +22 -0
  284. package/mysql-core/query-builders/delete.js.map +1 -1
  285. package/mysql-core/query-builders/insert.cjs.map +1 -1
  286. package/mysql-core/query-builders/insert.js.map +1 -1
  287. package/mysql-core/query-builders/query-builder.cjs +6 -1
  288. package/mysql-core/query-builders/query-builder.cjs.map +1 -1
  289. package/mysql-core/query-builders/query-builder.d.cts +8 -4
  290. package/mysql-core/query-builders/query-builder.d.ts +8 -4
  291. package/mysql-core/query-builders/query-builder.js +7 -2
  292. package/mysql-core/query-builders/query-builder.js.map +1 -1
  293. package/mysql-core/query-builders/query.cjs.map +1 -1
  294. package/mysql-core/query-builders/query.d.cts +3 -7
  295. package/mysql-core/query-builders/query.d.ts +3 -7
  296. package/mysql-core/query-builders/query.js.map +1 -1
  297. package/mysql-core/query-builders/select.cjs.map +1 -1
  298. package/mysql-core/query-builders/select.js.map +1 -1
  299. package/mysql-core/query-builders/update.cjs +22 -0
  300. package/mysql-core/query-builders/update.cjs.map +1 -1
  301. package/mysql-core/query-builders/update.d.cts +9 -3
  302. package/mysql-core/query-builders/update.d.ts +9 -3
  303. package/mysql-core/query-builders/update.js +22 -0
  304. package/mysql-core/query-builders/update.js.map +1 -1
  305. package/mysql-core/session.cjs.map +1 -1
  306. package/mysql-core/session.js.map +1 -1
  307. package/mysql-core/table.cjs +4 -1
  308. package/mysql-core/table.cjs.map +1 -1
  309. package/mysql-core/table.d.cts +8 -1
  310. package/mysql-core/table.d.ts +8 -1
  311. package/mysql-core/table.js +4 -1
  312. package/mysql-core/table.js.map +1 -1
  313. package/mysql-core/unique-constraint.cjs +2 -2
  314. package/mysql-core/unique-constraint.cjs.map +1 -1
  315. package/mysql-core/unique-constraint.d.cts +1 -1
  316. package/mysql-core/unique-constraint.d.ts +1 -1
  317. package/mysql-core/unique-constraint.js +2 -2
  318. package/mysql-core/unique-constraint.js.map +1 -1
  319. package/mysql-core/utils.d.cts +4 -5
  320. package/mysql-core/utils.d.ts +4 -5
  321. package/mysql-core/view-base.cjs.map +1 -1
  322. package/mysql-core/view-base.js.map +1 -1
  323. package/mysql-core/view.cjs +0 -4
  324. package/mysql-core/view.cjs.map +1 -1
  325. package/mysql-core/view.d.cts +0 -2
  326. package/mysql-core/view.d.ts +0 -2
  327. package/mysql-core/view.js +0 -4
  328. package/mysql-core/view.js.map +1 -1
  329. package/mysql-proxy/driver.cjs +1 -1
  330. package/mysql-proxy/driver.cjs.map +1 -1
  331. package/mysql-proxy/driver.js +1 -1
  332. package/mysql-proxy/driver.js.map +1 -1
  333. package/mysql-proxy/session.cjs.map +1 -1
  334. package/mysql-proxy/session.d.cts +1 -1
  335. package/mysql-proxy/session.d.ts +1 -1
  336. package/mysql-proxy/session.js.map +1 -1
  337. package/mysql2/driver.cjs +3 -3
  338. package/mysql2/driver.cjs.map +1 -1
  339. package/mysql2/driver.js +2 -2
  340. package/mysql2/driver.js.map +1 -1
  341. package/mysql2/session.cjs.map +1 -1
  342. package/mysql2/session.d.cts +1 -1
  343. package/mysql2/session.d.ts +1 -1
  344. package/mysql2/session.js.map +1 -1
  345. package/neon-http/driver.cjs +1 -1
  346. package/neon-http/driver.cjs.map +1 -1
  347. package/neon-http/driver.js +1 -1
  348. package/neon-http/driver.js.map +1 -1
  349. package/neon-http/session.cjs.map +1 -1
  350. package/neon-http/session.d.cts +1 -1
  351. package/neon-http/session.d.ts +1 -1
  352. package/neon-http/session.js.map +1 -1
  353. package/neon-serverless/driver.cjs +1 -9
  354. package/neon-serverless/driver.cjs.map +1 -1
  355. package/neon-serverless/driver.d.cts +0 -1
  356. package/neon-serverless/driver.d.ts +0 -1
  357. package/neon-serverless/driver.js +1 -9
  358. package/neon-serverless/driver.js.map +1 -1
  359. package/neon-serverless/session.cjs +44 -2
  360. package/neon-serverless/session.cjs.map +1 -1
  361. package/neon-serverless/session.d.cts +3 -2
  362. package/neon-serverless/session.d.ts +3 -2
  363. package/neon-serverless/session.js +46 -3
  364. package/neon-serverless/session.js.map +1 -1
  365. package/node-postgres/driver.cjs +1 -20
  366. package/node-postgres/driver.cjs.map +1 -1
  367. package/node-postgres/driver.d.cts +0 -1
  368. package/node-postgres/driver.d.ts +0 -1
  369. package/node-postgres/driver.js +1 -10
  370. package/node-postgres/driver.js.map +1 -1
  371. package/node-postgres/session.cjs +39 -3
  372. package/node-postgres/session.cjs.map +1 -1
  373. package/node-postgres/session.d.cts +1 -1
  374. package/node-postgres/session.d.ts +1 -1
  375. package/node-postgres/session.js +39 -3
  376. package/node-postgres/session.js.map +1 -1
  377. package/op-sqlite/driver.cjs +1 -1
  378. package/op-sqlite/driver.cjs.map +1 -1
  379. package/op-sqlite/driver.js +1 -1
  380. package/op-sqlite/driver.js.map +1 -1
  381. package/op-sqlite/session.cjs.map +1 -1
  382. package/op-sqlite/session.js.map +1 -1
  383. package/package.json +122 -50
  384. package/pg-core/columns/all.cjs +96 -0
  385. package/pg-core/columns/all.cjs.map +1 -0
  386. package/pg-core/columns/all.d.cts +67 -0
  387. package/pg-core/columns/all.d.ts +67 -0
  388. package/pg-core/columns/all.js +72 -0
  389. package/pg-core/columns/all.js.map +1 -0
  390. package/pg-core/columns/bigint.cjs +3 -1
  391. package/pg-core/columns/bigint.cjs.map +1 -1
  392. package/pg-core/columns/bigint.d.cts +2 -2
  393. package/pg-core/columns/bigint.d.ts +2 -2
  394. package/pg-core/columns/bigint.js +3 -1
  395. package/pg-core/columns/bigint.js.map +1 -1
  396. package/pg-core/columns/bigserial.cjs +4 -2
  397. package/pg-core/columns/bigserial.cjs.map +1 -1
  398. package/pg-core/columns/bigserial.d.cts +2 -2
  399. package/pg-core/columns/bigserial.d.ts +2 -2
  400. package/pg-core/columns/bigserial.js +4 -2
  401. package/pg-core/columns/bigserial.js.map +1 -1
  402. package/pg-core/columns/boolean.cjs +1 -1
  403. package/pg-core/columns/boolean.cjs.map +1 -1
  404. package/pg-core/columns/boolean.d.cts +1 -0
  405. package/pg-core/columns/boolean.d.ts +1 -0
  406. package/pg-core/columns/boolean.js +1 -1
  407. package/pg-core/columns/boolean.js.map +1 -1
  408. package/pg-core/columns/char.cjs +3 -1
  409. package/pg-core/columns/char.cjs.map +1 -1
  410. package/pg-core/columns/char.d.cts +5 -3
  411. package/pg-core/columns/char.d.ts +5 -3
  412. package/pg-core/columns/char.js +3 -1
  413. package/pg-core/columns/char.js.map +1 -1
  414. package/pg-core/columns/cidr.cjs +1 -1
  415. package/pg-core/columns/cidr.cjs.map +1 -1
  416. package/pg-core/columns/cidr.d.cts +1 -0
  417. package/pg-core/columns/cidr.d.ts +1 -0
  418. package/pg-core/columns/cidr.js +1 -1
  419. package/pg-core/columns/cidr.js.map +1 -1
  420. package/pg-core/columns/common.cjs +3 -1
  421. package/pg-core/columns/common.cjs.map +1 -1
  422. package/pg-core/columns/common.d.cts +3 -2
  423. package/pg-core/columns/common.d.ts +3 -2
  424. package/pg-core/columns/common.js +3 -1
  425. package/pg-core/columns/common.js.map +1 -1
  426. package/pg-core/columns/custom.cjs +4 -2
  427. package/pg-core/columns/custom.cjs.map +1 -1
  428. package/pg-core/columns/custom.d.cts +10 -3
  429. package/pg-core/columns/custom.d.ts +10 -3
  430. package/pg-core/columns/custom.js +4 -2
  431. package/pg-core/columns/custom.js.map +1 -1
  432. package/pg-core/columns/date.cjs +3 -1
  433. package/pg-core/columns/date.cjs.map +1 -1
  434. package/pg-core/columns/date.common.cjs.map +1 -1
  435. package/pg-core/columns/date.common.js.map +1 -1
  436. package/pg-core/columns/date.d.cts +7 -6
  437. package/pg-core/columns/date.d.ts +7 -6
  438. package/pg-core/columns/date.js +3 -1
  439. package/pg-core/columns/date.js.map +1 -1
  440. package/pg-core/columns/double-precision.cjs +1 -1
  441. package/pg-core/columns/double-precision.cjs.map +1 -1
  442. package/pg-core/columns/double-precision.d.cts +1 -0
  443. package/pg-core/columns/double-precision.d.ts +1 -0
  444. package/pg-core/columns/double-precision.js +1 -1
  445. package/pg-core/columns/double-precision.js.map +1 -1
  446. package/pg-core/columns/enum.cjs +1 -1
  447. package/pg-core/columns/enum.cjs.map +1 -1
  448. package/pg-core/columns/enum.d.cts +3 -1
  449. package/pg-core/columns/enum.d.ts +3 -1
  450. package/pg-core/columns/enum.js +1 -1
  451. package/pg-core/columns/enum.js.map +1 -1
  452. package/pg-core/columns/index.cjs +2 -0
  453. package/pg-core/columns/index.cjs.map +1 -1
  454. package/pg-core/columns/index.d.cts +1 -0
  455. package/pg-core/columns/index.d.ts +1 -0
  456. package/pg-core/columns/index.js +1 -0
  457. package/pg-core/columns/index.js.map +1 -1
  458. package/pg-core/columns/inet.cjs +1 -1
  459. package/pg-core/columns/inet.cjs.map +1 -1
  460. package/pg-core/columns/inet.d.cts +1 -0
  461. package/pg-core/columns/inet.d.ts +1 -0
  462. package/pg-core/columns/inet.js +1 -1
  463. package/pg-core/columns/inet.js.map +1 -1
  464. package/pg-core/columns/int.common.cjs.map +1 -1
  465. package/pg-core/columns/int.common.js.map +1 -1
  466. package/pg-core/columns/integer.cjs +1 -1
  467. package/pg-core/columns/integer.cjs.map +1 -1
  468. package/pg-core/columns/integer.d.cts +1 -0
  469. package/pg-core/columns/integer.d.ts +1 -0
  470. package/pg-core/columns/integer.js +1 -1
  471. package/pg-core/columns/integer.js.map +1 -1
  472. package/pg-core/columns/interval.cjs +3 -1
  473. package/pg-core/columns/interval.cjs.map +1 -1
  474. package/pg-core/columns/interval.d.cts +2 -0
  475. package/pg-core/columns/interval.d.ts +2 -0
  476. package/pg-core/columns/interval.js +3 -1
  477. package/pg-core/columns/interval.js.map +1 -1
  478. package/pg-core/columns/json.cjs +1 -1
  479. package/pg-core/columns/json.cjs.map +1 -1
  480. package/pg-core/columns/json.d.cts +1 -0
  481. package/pg-core/columns/json.d.ts +1 -0
  482. package/pg-core/columns/json.js +1 -1
  483. package/pg-core/columns/json.js.map +1 -1
  484. package/pg-core/columns/jsonb.cjs +1 -1
  485. package/pg-core/columns/jsonb.cjs.map +1 -1
  486. package/pg-core/columns/jsonb.d.cts +1 -0
  487. package/pg-core/columns/jsonb.d.ts +1 -0
  488. package/pg-core/columns/jsonb.js +1 -1
  489. package/pg-core/columns/jsonb.js.map +1 -1
  490. package/pg-core/columns/line.cjs +3 -1
  491. package/pg-core/columns/line.cjs.map +1 -1
  492. package/pg-core/columns/line.d.cts +3 -1
  493. package/pg-core/columns/line.d.ts +3 -1
  494. package/pg-core/columns/line.js +3 -1
  495. package/pg-core/columns/line.js.map +1 -1
  496. package/pg-core/columns/macaddr.cjs +1 -1
  497. package/pg-core/columns/macaddr.cjs.map +1 -1
  498. package/pg-core/columns/macaddr.d.cts +1 -0
  499. package/pg-core/columns/macaddr.d.ts +1 -0
  500. package/pg-core/columns/macaddr.js +1 -1
  501. package/pg-core/columns/macaddr.js.map +1 -1
  502. package/pg-core/columns/macaddr8.cjs +1 -1
  503. package/pg-core/columns/macaddr8.cjs.map +1 -1
  504. package/pg-core/columns/macaddr8.d.cts +1 -0
  505. package/pg-core/columns/macaddr8.d.ts +1 -0
  506. package/pg-core/columns/macaddr8.js +1 -1
  507. package/pg-core/columns/macaddr8.js.map +1 -1
  508. package/pg-core/columns/numeric.cjs +3 -1
  509. package/pg-core/columns/numeric.cjs.map +1 -1
  510. package/pg-core/columns/numeric.d.cts +6 -3
  511. package/pg-core/columns/numeric.d.ts +6 -3
  512. package/pg-core/columns/numeric.js +3 -1
  513. package/pg-core/columns/numeric.js.map +1 -1
  514. package/pg-core/columns/point.cjs +3 -1
  515. package/pg-core/columns/point.cjs.map +1 -1
  516. package/pg-core/columns/point.d.cts +5 -3
  517. package/pg-core/columns/point.d.ts +5 -3
  518. package/pg-core/columns/point.js +3 -1
  519. package/pg-core/columns/point.js.map +1 -1
  520. package/pg-core/columns/postgis_extension/geometry.cjs +6 -4
  521. package/pg-core/columns/postgis_extension/geometry.cjs.map +1 -1
  522. package/pg-core/columns/postgis_extension/geometry.d.cts +4 -3
  523. package/pg-core/columns/postgis_extension/geometry.d.ts +4 -3
  524. package/pg-core/columns/postgis_extension/geometry.js +3 -1
  525. package/pg-core/columns/postgis_extension/geometry.js.map +1 -1
  526. package/pg-core/columns/real.cjs +1 -1
  527. package/pg-core/columns/real.cjs.map +1 -1
  528. package/pg-core/columns/real.d.cts +2 -1
  529. package/pg-core/columns/real.d.ts +2 -1
  530. package/pg-core/columns/real.js +1 -1
  531. package/pg-core/columns/real.js.map +1 -1
  532. package/pg-core/columns/serial.cjs +1 -1
  533. package/pg-core/columns/serial.cjs.map +1 -1
  534. package/pg-core/columns/serial.d.cts +2 -1
  535. package/pg-core/columns/serial.d.ts +2 -1
  536. package/pg-core/columns/serial.js +1 -1
  537. package/pg-core/columns/serial.js.map +1 -1
  538. package/pg-core/columns/smallint.cjs +1 -1
  539. package/pg-core/columns/smallint.cjs.map +1 -1
  540. package/pg-core/columns/smallint.d.cts +1 -0
  541. package/pg-core/columns/smallint.d.ts +1 -0
  542. package/pg-core/columns/smallint.js +1 -1
  543. package/pg-core/columns/smallint.js.map +1 -1
  544. package/pg-core/columns/smallserial.cjs +1 -1
  545. package/pg-core/columns/smallserial.cjs.map +1 -1
  546. package/pg-core/columns/smallserial.d.cts +2 -1
  547. package/pg-core/columns/smallserial.d.ts +2 -1
  548. package/pg-core/columns/smallserial.js +1 -1
  549. package/pg-core/columns/smallserial.js.map +1 -1
  550. package/pg-core/columns/text.cjs +3 -1
  551. package/pg-core/columns/text.cjs.map +1 -1
  552. package/pg-core/columns/text.d.cts +4 -2
  553. package/pg-core/columns/text.d.ts +4 -2
  554. package/pg-core/columns/text.js +3 -1
  555. package/pg-core/columns/text.js.map +1 -1
  556. package/pg-core/columns/time.cjs +3 -1
  557. package/pg-core/columns/time.cjs.map +1 -1
  558. package/pg-core/columns/time.d.cts +2 -0
  559. package/pg-core/columns/time.d.ts +2 -0
  560. package/pg-core/columns/time.js +3 -1
  561. package/pg-core/columns/time.js.map +1 -1
  562. package/pg-core/columns/timestamp.cjs +5 -3
  563. package/pg-core/columns/timestamp.cjs.map +1 -1
  564. package/pg-core/columns/timestamp.d.cts +5 -3
  565. package/pg-core/columns/timestamp.d.ts +5 -3
  566. package/pg-core/columns/timestamp.js +5 -3
  567. package/pg-core/columns/timestamp.js.map +1 -1
  568. package/pg-core/columns/uuid.cjs +1 -1
  569. package/pg-core/columns/uuid.cjs.map +1 -1
  570. package/pg-core/columns/uuid.d.cts +1 -0
  571. package/pg-core/columns/uuid.d.ts +1 -0
  572. package/pg-core/columns/uuid.js +1 -1
  573. package/pg-core/columns/uuid.js.map +1 -1
  574. package/pg-core/columns/varchar.cjs +3 -1
  575. package/pg-core/columns/varchar.cjs.map +1 -1
  576. package/pg-core/columns/varchar.d.cts +5 -3
  577. package/pg-core/columns/varchar.d.ts +5 -3
  578. package/pg-core/columns/varchar.js +3 -1
  579. package/pg-core/columns/varchar.js.map +1 -1
  580. package/pg-core/columns/vector_extension/bit.cjs +3 -1
  581. package/pg-core/columns/vector_extension/bit.cjs.map +1 -1
  582. package/pg-core/columns/vector_extension/bit.d.cts +1 -0
  583. package/pg-core/columns/vector_extension/bit.d.ts +1 -0
  584. package/pg-core/columns/vector_extension/bit.js +3 -1
  585. package/pg-core/columns/vector_extension/bit.js.map +1 -1
  586. package/pg-core/columns/vector_extension/halfvec.cjs +3 -1
  587. package/pg-core/columns/vector_extension/halfvec.cjs.map +1 -1
  588. package/pg-core/columns/vector_extension/halfvec.d.cts +1 -0
  589. package/pg-core/columns/vector_extension/halfvec.d.ts +1 -0
  590. package/pg-core/columns/vector_extension/halfvec.js +3 -1
  591. package/pg-core/columns/vector_extension/halfvec.js.map +1 -1
  592. package/pg-core/columns/vector_extension/sparsevec.cjs +3 -1
  593. package/pg-core/columns/vector_extension/sparsevec.cjs.map +1 -1
  594. package/pg-core/columns/vector_extension/sparsevec.d.cts +1 -0
  595. package/pg-core/columns/vector_extension/sparsevec.d.ts +1 -0
  596. package/pg-core/columns/vector_extension/sparsevec.js +3 -1
  597. package/pg-core/columns/vector_extension/sparsevec.js.map +1 -1
  598. package/pg-core/columns/vector_extension/vector.cjs +3 -1
  599. package/pg-core/columns/vector_extension/vector.cjs.map +1 -1
  600. package/pg-core/columns/vector_extension/vector.d.cts +1 -0
  601. package/pg-core/columns/vector_extension/vector.d.ts +1 -0
  602. package/pg-core/columns/vector_extension/vector.js +3 -1
  603. package/pg-core/columns/vector_extension/vector.js.map +1 -1
  604. package/pg-core/db.cjs +2 -1
  605. package/pg-core/db.cjs.map +1 -1
  606. package/pg-core/db.d.cts +5 -5
  607. package/pg-core/db.d.ts +5 -5
  608. package/pg-core/db.js +2 -1
  609. package/pg-core/db.js.map +1 -1
  610. package/pg-core/dialect.cjs +13 -4
  611. package/pg-core/dialect.cjs.map +1 -1
  612. package/pg-core/dialect.d.cts +5 -1
  613. package/pg-core/dialect.d.ts +5 -1
  614. package/pg-core/dialect.js +13 -4
  615. package/pg-core/dialect.js.map +1 -1
  616. package/pg-core/foreign-keys.cjs +3 -3
  617. package/pg-core/foreign-keys.cjs.map +1 -1
  618. package/pg-core/foreign-keys.d.cts +1 -1
  619. package/pg-core/foreign-keys.d.ts +1 -1
  620. package/pg-core/foreign-keys.js +3 -3
  621. package/pg-core/foreign-keys.js.map +1 -1
  622. package/pg-core/indexes.cjs +3 -3
  623. package/pg-core/indexes.cjs.map +1 -1
  624. package/pg-core/indexes.js +3 -3
  625. package/pg-core/indexes.js.map +1 -1
  626. package/pg-core/query-builders/count.cjs +4 -4
  627. package/pg-core/query-builders/count.cjs.map +1 -1
  628. package/pg-core/query-builders/count.d.cts +2 -3
  629. package/pg-core/query-builders/count.d.ts +2 -3
  630. package/pg-core/query-builders/count.js +2 -2
  631. package/pg-core/query-builders/count.js.map +1 -1
  632. package/pg-core/query-builders/delete.cjs.map +1 -1
  633. package/pg-core/query-builders/delete.js.map +1 -1
  634. package/pg-core/query-builders/insert.cjs +2 -2
  635. package/pg-core/query-builders/insert.cjs.map +1 -1
  636. package/pg-core/query-builders/insert.d.cts +1 -1
  637. package/pg-core/query-builders/insert.d.ts +1 -1
  638. package/pg-core/query-builders/insert.js +2 -2
  639. package/pg-core/query-builders/insert.js.map +1 -1
  640. package/pg-core/query-builders/query-builder.cjs +6 -1
  641. package/pg-core/query-builders/query-builder.cjs.map +1 -1
  642. package/pg-core/query-builders/query-builder.d.cts +10 -6
  643. package/pg-core/query-builders/query-builder.d.ts +10 -6
  644. package/pg-core/query-builders/query-builder.js +7 -2
  645. package/pg-core/query-builders/query-builder.js.map +1 -1
  646. package/pg-core/query-builders/query.cjs.map +1 -1
  647. package/pg-core/query-builders/query.js.map +1 -1
  648. package/pg-core/query-builders/raw.cjs.map +1 -1
  649. package/pg-core/query-builders/raw.js.map +1 -1
  650. package/pg-core/query-builders/refresh-materialized-view.cjs.map +1 -1
  651. package/pg-core/query-builders/refresh-materialized-view.js.map +1 -1
  652. package/pg-core/query-builders/select.cjs.map +1 -1
  653. package/pg-core/query-builders/select.js.map +1 -1
  654. package/pg-core/query-builders/update.cjs.map +1 -1
  655. package/pg-core/query-builders/update.d.cts +1 -1
  656. package/pg-core/query-builders/update.d.ts +1 -1
  657. package/pg-core/query-builders/update.js.map +1 -1
  658. package/pg-core/session.cjs.map +1 -1
  659. package/pg-core/session.js.map +1 -1
  660. package/pg-core/table.cjs +6 -2
  661. package/pg-core/table.cjs.map +1 -1
  662. package/pg-core/table.d.cts +7 -0
  663. package/pg-core/table.d.ts +7 -0
  664. package/pg-core/table.js +6 -2
  665. package/pg-core/table.js.map +1 -1
  666. package/pg-core/unique-constraint.cjs +2 -2
  667. package/pg-core/unique-constraint.cjs.map +1 -1
  668. package/pg-core/unique-constraint.d.cts +1 -1
  669. package/pg-core/unique-constraint.d.ts +1 -1
  670. package/pg-core/unique-constraint.js +2 -2
  671. package/pg-core/unique-constraint.js.map +1 -1
  672. package/pg-core/utils.d.cts +8 -8
  673. package/pg-core/utils.d.ts +8 -8
  674. package/pg-core/view-base.cjs.map +1 -1
  675. package/pg-core/view-base.js.map +1 -1
  676. package/pg-core/view.cjs +22 -2
  677. package/pg-core/view.cjs.map +1 -1
  678. package/pg-core/view.d.cts +25 -5
  679. package/pg-core/view.d.ts +25 -5
  680. package/pg-core/view.js +21 -3
  681. package/pg-core/view.js.map +1 -1
  682. package/pg-proxy/driver.cjs +1 -1
  683. package/pg-proxy/driver.cjs.map +1 -1
  684. package/pg-proxy/driver.js +1 -1
  685. package/pg-proxy/driver.js.map +1 -1
  686. package/pg-proxy/session.cjs.map +1 -1
  687. package/pg-proxy/session.d.cts +1 -1
  688. package/pg-proxy/session.d.ts +1 -1
  689. package/pg-proxy/session.js.map +1 -1
  690. package/pglite/driver.cjs +1 -1
  691. package/pglite/driver.cjs.map +1 -1
  692. package/pglite/driver.js +1 -1
  693. package/pglite/driver.js.map +1 -1
  694. package/pglite/session.cjs.map +1 -1
  695. package/pglite/session.d.cts +1 -1
  696. package/pglite/session.d.ts +1 -1
  697. package/pglite/session.js.map +1 -1
  698. package/planetscale-serverless/driver.cjs +1 -1
  699. package/planetscale-serverless/driver.cjs.map +1 -1
  700. package/planetscale-serverless/driver.js +1 -1
  701. package/planetscale-serverless/driver.js.map +1 -1
  702. package/planetscale-serverless/session.cjs.map +1 -1
  703. package/planetscale-serverless/session.d.cts +1 -1
  704. package/planetscale-serverless/session.d.ts +1 -1
  705. package/planetscale-serverless/session.js.map +1 -1
  706. package/postgres-js/driver.cjs +1 -1
  707. package/postgres-js/driver.cjs.map +1 -1
  708. package/postgres-js/driver.js +1 -1
  709. package/postgres-js/driver.js.map +1 -1
  710. package/postgres-js/session.cjs.map +1 -1
  711. package/postgres-js/session.d.cts +1 -1
  712. package/postgres-js/session.d.ts +1 -1
  713. package/postgres-js/session.js.map +1 -1
  714. package/prisma/mysql/driver.cjs.map +1 -1
  715. package/prisma/mysql/driver.js.map +1 -1
  716. package/prisma/mysql/session.cjs.map +1 -1
  717. package/prisma/mysql/session.js.map +1 -1
  718. package/prisma/pg/driver.cjs.map +1 -1
  719. package/prisma/pg/driver.js.map +1 -1
  720. package/prisma/pg/session.cjs.map +1 -1
  721. package/prisma/pg/session.js.map +1 -1
  722. package/prisma/sqlite/session.cjs.map +1 -1
  723. package/prisma/sqlite/session.js.map +1 -1
  724. package/relations.cjs.map +1 -1
  725. package/relations.d.cts +13 -13
  726. package/relations.d.ts +13 -13
  727. package/relations.js.map +1 -1
  728. package/sql/functions/vector.cjs.map +1 -1
  729. package/sql/functions/vector.d.cts +1 -1
  730. package/sql/functions/vector.d.ts +1 -1
  731. package/sql/functions/vector.js.map +1 -1
  732. package/sql/sql.cjs +4 -2
  733. package/sql/sql.cjs.map +1 -1
  734. package/sql/sql.d.cts +2 -0
  735. package/sql/sql.d.ts +2 -0
  736. package/sql/sql.js +4 -2
  737. package/sql/sql.js.map +1 -1
  738. package/sql-js/driver.cjs +1 -1
  739. package/sql-js/driver.cjs.map +1 -1
  740. package/sql-js/driver.js +1 -1
  741. package/sql-js/driver.js.map +1 -1
  742. package/sql-js/session.cjs.map +1 -1
  743. package/sql-js/session.js.map +1 -1
  744. package/sqlite-core/columns/all.cjs +44 -0
  745. package/sqlite-core/columns/all.cjs.map +1 -0
  746. package/sqlite-core/columns/all.d.cts +15 -0
  747. package/sqlite-core/columns/all.d.ts +15 -0
  748. package/sqlite-core/columns/all.js +20 -0
  749. package/sqlite-core/columns/all.js.map +1 -0
  750. package/sqlite-core/columns/blob.cjs +3 -1
  751. package/sqlite-core/columns/blob.cjs.map +1 -1
  752. package/sqlite-core/columns/blob.d.cts +3 -3
  753. package/sqlite-core/columns/blob.d.ts +3 -3
  754. package/sqlite-core/columns/blob.js +3 -1
  755. package/sqlite-core/columns/blob.js.map +1 -1
  756. package/sqlite-core/columns/common.cjs.map +1 -1
  757. package/sqlite-core/columns/common.js.map +1 -1
  758. package/sqlite-core/columns/custom.cjs +5 -3
  759. package/sqlite-core/columns/custom.cjs.map +1 -1
  760. package/sqlite-core/columns/custom.d.cts +10 -3
  761. package/sqlite-core/columns/custom.d.ts +10 -3
  762. package/sqlite-core/columns/custom.js +5 -3
  763. package/sqlite-core/columns/custom.js.map +1 -1
  764. package/sqlite-core/columns/integer.cjs +3 -1
  765. package/sqlite-core/columns/integer.cjs.map +1 -1
  766. package/sqlite-core/columns/integer.d.cts +3 -1
  767. package/sqlite-core/columns/integer.d.ts +3 -1
  768. package/sqlite-core/columns/integer.js +3 -1
  769. package/sqlite-core/columns/integer.js.map +1 -1
  770. package/sqlite-core/columns/numeric.cjs +1 -1
  771. package/sqlite-core/columns/numeric.cjs.map +1 -1
  772. package/sqlite-core/columns/numeric.d.cts +1 -0
  773. package/sqlite-core/columns/numeric.d.ts +1 -0
  774. package/sqlite-core/columns/numeric.js +1 -1
  775. package/sqlite-core/columns/numeric.js.map +1 -1
  776. package/sqlite-core/columns/real.cjs +1 -1
  777. package/sqlite-core/columns/real.cjs.map +1 -1
  778. package/sqlite-core/columns/real.d.cts +1 -0
  779. package/sqlite-core/columns/real.d.ts +1 -0
  780. package/sqlite-core/columns/real.js +1 -1
  781. package/sqlite-core/columns/real.js.map +1 -1
  782. package/sqlite-core/columns/text.cjs +7 -2
  783. package/sqlite-core/columns/text.cjs.map +1 -1
  784. package/sqlite-core/columns/text.d.cts +4 -2
  785. package/sqlite-core/columns/text.d.ts +4 -2
  786. package/sqlite-core/columns/text.js +7 -2
  787. package/sqlite-core/columns/text.js.map +1 -1
  788. package/sqlite-core/db.cjs +2 -1
  789. package/sqlite-core/db.cjs.map +1 -1
  790. package/sqlite-core/db.d.cts +4 -4
  791. package/sqlite-core/db.d.ts +4 -4
  792. package/sqlite-core/db.js +2 -1
  793. package/sqlite-core/db.js.map +1 -1
  794. package/sqlite-core/dialect.cjs +39 -23
  795. package/sqlite-core/dialect.cjs.map +1 -1
  796. package/sqlite-core/dialect.d.cts +9 -3
  797. package/sqlite-core/dialect.d.ts +9 -3
  798. package/sqlite-core/dialect.js +39 -23
  799. package/sqlite-core/dialect.js.map +1 -1
  800. package/sqlite-core/foreign-keys.cjs +3 -3
  801. package/sqlite-core/foreign-keys.cjs.map +1 -1
  802. package/sqlite-core/foreign-keys.d.cts +1 -1
  803. package/sqlite-core/foreign-keys.d.ts +1 -1
  804. package/sqlite-core/foreign-keys.js +3 -3
  805. package/sqlite-core/foreign-keys.js.map +1 -1
  806. package/sqlite-core/query-builders/count.cjs +4 -4
  807. package/sqlite-core/query-builders/count.cjs.map +1 -1
  808. package/sqlite-core/query-builders/count.d.cts +2 -3
  809. package/sqlite-core/query-builders/count.d.ts +2 -3
  810. package/sqlite-core/query-builders/count.js +2 -2
  811. package/sqlite-core/query-builders/count.js.map +1 -1
  812. package/sqlite-core/query-builders/delete.cjs +22 -0
  813. package/sqlite-core/query-builders/delete.cjs.map +1 -1
  814. package/sqlite-core/query-builders/delete.d.cts +8 -2
  815. package/sqlite-core/query-builders/delete.d.ts +8 -2
  816. package/sqlite-core/query-builders/delete.js +22 -0
  817. package/sqlite-core/query-builders/delete.js.map +1 -1
  818. package/sqlite-core/query-builders/insert.cjs.map +1 -1
  819. package/sqlite-core/query-builders/insert.d.cts +1 -1
  820. package/sqlite-core/query-builders/insert.d.ts +1 -1
  821. package/sqlite-core/query-builders/insert.js.map +1 -1
  822. package/sqlite-core/query-builders/query-builder.cjs +6 -1
  823. package/sqlite-core/query-builders/query-builder.cjs.map +1 -1
  824. package/sqlite-core/query-builders/query-builder.d.cts +8 -4
  825. package/sqlite-core/query-builders/query-builder.d.ts +8 -4
  826. package/sqlite-core/query-builders/query-builder.js +8 -3
  827. package/sqlite-core/query-builders/query-builder.js.map +1 -1
  828. package/sqlite-core/query-builders/query.cjs.map +1 -1
  829. package/sqlite-core/query-builders/query.js.map +1 -1
  830. package/sqlite-core/query-builders/raw.cjs.map +1 -1
  831. package/sqlite-core/query-builders/raw.d.cts +2 -2
  832. package/sqlite-core/query-builders/raw.d.ts +2 -2
  833. package/sqlite-core/query-builders/raw.js.map +1 -1
  834. package/sqlite-core/query-builders/select.cjs.map +1 -1
  835. package/sqlite-core/query-builders/select.js.map +1 -1
  836. package/sqlite-core/query-builders/update.cjs +22 -0
  837. package/sqlite-core/query-builders/update.cjs.map +1 -1
  838. package/sqlite-core/query-builders/update.d.cts +9 -3
  839. package/sqlite-core/query-builders/update.d.ts +9 -3
  840. package/sqlite-core/query-builders/update.js +26 -1
  841. package/sqlite-core/query-builders/update.js.map +1 -1
  842. package/sqlite-core/session.cjs.map +1 -1
  843. package/sqlite-core/session.js.map +1 -1
  844. package/sqlite-core/table.cjs +4 -1
  845. package/sqlite-core/table.cjs.map +1 -1
  846. package/sqlite-core/table.d.cts +7 -0
  847. package/sqlite-core/table.d.ts +7 -0
  848. package/sqlite-core/table.js +4 -1
  849. package/sqlite-core/table.js.map +1 -1
  850. package/sqlite-core/unique-constraint.cjs +2 -2
  851. package/sqlite-core/unique-constraint.cjs.map +1 -1
  852. package/sqlite-core/unique-constraint.d.cts +1 -1
  853. package/sqlite-core/unique-constraint.d.ts +1 -1
  854. package/sqlite-core/unique-constraint.js +2 -2
  855. package/sqlite-core/unique-constraint.js.map +1 -1
  856. package/sqlite-core/utils.cjs +2 -3
  857. package/sqlite-core/utils.cjs.map +1 -1
  858. package/sqlite-core/utils.d.cts +1 -5
  859. package/sqlite-core/utils.d.ts +1 -5
  860. package/sqlite-core/utils.js +2 -3
  861. package/sqlite-core/utils.js.map +1 -1
  862. package/sqlite-core/view-base.cjs.map +1 -1
  863. package/sqlite-core/view-base.js.map +1 -1
  864. package/sqlite-core/view.cjs +2 -8
  865. package/sqlite-core/view.cjs.map +1 -1
  866. package/sqlite-core/view.d.cts +1 -2
  867. package/sqlite-core/view.d.ts +1 -2
  868. package/sqlite-core/view.js +2 -8
  869. package/sqlite-core/view.js.map +1 -1
  870. package/sqlite-proxy/driver.cjs +1 -1
  871. package/sqlite-proxy/driver.cjs.map +1 -1
  872. package/sqlite-proxy/driver.js +1 -1
  873. package/sqlite-proxy/driver.js.map +1 -1
  874. package/sqlite-proxy/session.cjs.map +1 -1
  875. package/sqlite-proxy/session.js.map +1 -1
  876. package/subquery.cjs.map +1 -1
  877. package/subquery.js.map +1 -1
  878. package/table.cjs +6 -8
  879. package/table.cjs.map +1 -1
  880. package/table.js +1 -2
  881. package/table.js.map +1 -1
  882. package/table.utils.cjs +29 -0
  883. package/table.utils.cjs.map +1 -0
  884. package/table.utils.d.cts +1 -0
  885. package/table.utils.d.ts +1 -0
  886. package/table.utils.js +5 -0
  887. package/table.utils.js.map +1 -0
  888. package/tidb-serverless/driver.cjs +1 -1
  889. package/tidb-serverless/driver.cjs.map +1 -1
  890. package/tidb-serverless/driver.js +1 -1
  891. package/tidb-serverless/driver.js.map +1 -1
  892. package/tidb-serverless/session.cjs.map +1 -1
  893. package/tidb-serverless/session.d.cts +1 -1
  894. package/tidb-serverless/session.d.ts +1 -1
  895. package/tidb-serverless/session.js.map +1 -1
  896. package/utils.cjs +8 -0
  897. package/utils.cjs.map +1 -1
  898. package/utils.d.cts +3 -0
  899. package/utils.d.ts +3 -0
  900. package/utils.js +7 -0
  901. package/utils.js.map +1 -1
  902. package/vercel-postgres/driver.cjs +1 -9
  903. package/vercel-postgres/driver.cjs.map +1 -1
  904. package/vercel-postgres/driver.d.cts +0 -1
  905. package/vercel-postgres/driver.d.ts +0 -1
  906. package/vercel-postgres/driver.js +1 -9
  907. package/vercel-postgres/driver.js.map +1 -1
  908. package/vercel-postgres/session.cjs +38 -2
  909. package/vercel-postgres/session.cjs.map +1 -1
  910. package/vercel-postgres/session.d.cts +1 -1
  911. package/vercel-postgres/session.d.ts +1 -1
  912. package/vercel-postgres/session.js +39 -2
  913. package/vercel-postgres/session.js.map +1 -1
  914. package/version.cjs +1 -1
  915. package/version.d.cts +1 -1
  916. package/version.d.ts +1 -1
  917. package/version.js +1 -1
  918. package/xata-http/driver.cjs +1 -1
  919. package/xata-http/driver.cjs.map +1 -1
  920. package/xata-http/driver.js +1 -1
  921. package/xata-http/driver.js.map +1 -1
  922. package/xata-http/session.cjs.map +1 -1
  923. package/xata-http/session.d.cts +1 -1
  924. package/xata-http/session.d.ts +1 -1
  925. package/xata-http/session.js.map +1 -1
@@ -24,6 +24,7 @@ __export(dialect_exports, {
24
24
  });
25
25
  module.exports = __toCommonJS(dialect_exports);
26
26
  var import_alias = require("../alias.cjs");
27
+ var import_casing = require("../casing.cjs");
27
28
  var import_column = require("../column.cjs");
28
29
  var import_entity = require("../entity.cjs");
29
30
  var import_errors = require("../errors.cjs");
@@ -39,6 +40,11 @@ var import_view_common = require("../view-common.cjs");
39
40
  var import_view_base = require("./view-base.cjs");
40
41
  class SQLiteDialect {
41
42
  static [import_entity.entityKind] = "SQLiteDialect";
43
+ /** @internal */
44
+ casing;
45
+ constructor(config) {
46
+ this.casing = new import_casing.CasingCache(config?.casing);
47
+ }
42
48
  escapeName(name) {
43
49
  return `"${name}"`;
44
50
  }
@@ -61,11 +67,13 @@ class SQLiteDialect {
61
67
  withSqlChunks.push(import_sql2.sql` `);
62
68
  return import_sql2.sql.join(withSqlChunks);
63
69
  }
64
- buildDeleteQuery({ table, where, returning, withList }) {
70
+ buildDeleteQuery({ table, where, returning, withList, limit, orderBy }) {
65
71
  const withSql = this.buildWithCTE(withList);
66
72
  const returningSql = returning ? import_sql2.sql` returning ${this.buildSelection(returning, { isSingleTable: true })}` : void 0;
67
73
  const whereSql = where ? import_sql2.sql` where ${where}` : void 0;
68
- return import_sql2.sql`${withSql}delete from ${table}${whereSql}${returningSql}`;
74
+ const orderBySql = this.buildOrderBy(orderBy);
75
+ const limitSql = this.buildLimit(limit);
76
+ return import_sql2.sql`${withSql}delete from ${table}${whereSql}${returningSql}${orderBySql}${limitSql}`;
69
77
  }
70
78
  buildUpdateSet(table, set) {
71
79
  const tableColumns = table[import_table2.Table.Symbol.Columns];
@@ -76,19 +84,21 @@ class SQLiteDialect {
76
84
  return import_sql2.sql.join(columnNames.flatMap((colName, i) => {
77
85
  const col = tableColumns[colName];
78
86
  const value = set[colName] ?? import_sql2.sql.param(col.onUpdateFn(), col);
79
- const res = import_sql2.sql`${import_sql2.sql.identifier(col.name)} = ${value}`;
87
+ const res = import_sql2.sql`${import_sql2.sql.identifier(this.casing.getColumnCasing(col))} = ${value}`;
80
88
  if (i < setSize - 1) {
81
89
  return [res, import_sql2.sql.raw(", ")];
82
90
  }
83
91
  return [res];
84
92
  }));
85
93
  }
86
- buildUpdateQuery({ table, set, where, returning, withList }) {
94
+ buildUpdateQuery({ table, set, where, returning, withList, limit, orderBy }) {
87
95
  const withSql = this.buildWithCTE(withList);
88
96
  const setSql = this.buildUpdateSet(table, set);
89
97
  const returningSql = returning ? import_sql2.sql` returning ${this.buildSelection(returning, { isSingleTable: true })}` : void 0;
90
98
  const whereSql = where ? import_sql2.sql` where ${where}` : void 0;
91
- return import_sql2.sql`${withSql}update ${table} set ${setSql}${whereSql}${returningSql}`;
99
+ const orderBySql = this.buildOrderBy(orderBy);
100
+ const limitSql = this.buildLimit(limit);
101
+ return import_sql2.sql`${withSql}update ${table} set ${setSql}${whereSql}${returningSql}${orderBySql}${limitSql}`;
92
102
  }
93
103
  /**
94
104
  * Builds selection SQL with provided fields/expressions
@@ -114,7 +124,7 @@ class SQLiteDialect {
114
124
  new import_sql2.SQL(
115
125
  query.queryChunks.map((c) => {
116
126
  if ((0, import_entity.is)(c, import_column.Column)) {
117
- return import_sql2.sql.identifier(c.name);
127
+ return import_sql2.sql.identifier(this.casing.getColumnCasing(c));
118
128
  }
119
129
  return c;
120
130
  })
@@ -128,11 +138,10 @@ class SQLiteDialect {
128
138
  }
129
139
  } else if ((0, import_entity.is)(field, import_column.Column)) {
130
140
  const tableName = field.table[import_table2.Table.Symbol.Name];
131
- const columnName = field.name;
132
141
  if (isSingleTable) {
133
- chunk.push(import_sql2.sql.identifier(columnName));
142
+ chunk.push(import_sql2.sql.identifier(this.casing.getColumnCasing(field)));
134
143
  } else {
135
- chunk.push(import_sql2.sql`${import_sql2.sql.identifier(tableName)}.${import_sql2.sql.identifier(columnName)}`);
144
+ chunk.push(import_sql2.sql`${import_sql2.sql.identifier(tableName)}.${import_sql2.sql.identifier(this.casing.getColumnCasing(field))}`);
136
145
  }
137
146
  }
138
147
  if (i < columnsLen - 1) {
@@ -142,6 +151,21 @@ class SQLiteDialect {
142
151
  });
143
152
  return import_sql2.sql.join(chunks);
144
153
  }
154
+ buildLimit(limit) {
155
+ return typeof limit === "object" || typeof limit === "number" && limit >= 0 ? import_sql2.sql` limit ${limit}` : void 0;
156
+ }
157
+ buildOrderBy(orderBy) {
158
+ const orderByList = [];
159
+ if (orderBy) {
160
+ for (const [index, orderByValue] of orderBy.entries()) {
161
+ orderByList.push(orderByValue);
162
+ if (index < orderBy.length - 1) {
163
+ orderByList.push(import_sql2.sql`, `);
164
+ }
165
+ }
166
+ }
167
+ return orderByList.length > 0 ? import_sql2.sql` order by ${import_sql2.sql.join(orderByList)}` : void 0;
168
+ }
145
169
  buildSelectQuery({
146
170
  withList,
147
171
  fields,
@@ -206,15 +230,6 @@ class SQLiteDialect {
206
230
  const joinsSql = import_sql2.sql.join(joinsArray);
207
231
  const whereSql = where ? import_sql2.sql` where ${where}` : void 0;
208
232
  const havingSql = having ? import_sql2.sql` having ${having}` : void 0;
209
- const orderByList = [];
210
- if (orderBy) {
211
- for (const [index, orderByValue] of orderBy.entries()) {
212
- orderByList.push(orderByValue);
213
- if (index < orderBy.length - 1) {
214
- orderByList.push(import_sql2.sql`, `);
215
- }
216
- }
217
- }
218
233
  const groupByList = [];
219
234
  if (groupBy) {
220
235
  for (const [index, groupByValue] of groupBy.entries()) {
@@ -225,8 +240,8 @@ class SQLiteDialect {
225
240
  }
226
241
  }
227
242
  const groupBySql = groupByList.length > 0 ? import_sql2.sql` group by ${import_sql2.sql.join(groupByList)}` : void 0;
228
- const orderBySql = orderByList.length > 0 ? import_sql2.sql` order by ${import_sql2.sql.join(orderByList)}` : void 0;
229
- const limitSql = typeof limit === "object" || typeof limit === "number" && limit >= 0 ? import_sql2.sql` limit ${limit}` : void 0;
243
+ const orderBySql = this.buildOrderBy(orderBy);
244
+ const limitSql = this.buildLimit(limit);
230
245
  const offsetSql = offset ? import_sql2.sql` offset ${offset}` : void 0;
231
246
  const finalQuery = import_sql2.sql`${withSql}select${distinctSql} ${selection} from ${tableSql}${joinsSql}${whereSql}${groupBySql}${havingSql}${orderBySql}${limitSql}${offsetSql}`;
232
247
  if (setOperators.length > 0) {
@@ -263,7 +278,7 @@ class SQLiteDialect {
263
278
  for (let i = 0; i < singleOrderBy.queryChunks.length; i++) {
264
279
  const chunk = singleOrderBy.queryChunks[i];
265
280
  if ((0, import_entity.is)(chunk, import_columns.SQLiteColumn)) {
266
- singleOrderBy.queryChunks[i] = import_sql2.sql.identifier(chunk.name);
281
+ singleOrderBy.queryChunks[i] = import_sql2.sql.identifier(this.casing.getColumnCasing(chunk));
267
282
  }
268
283
  }
269
284
  orderByValues.push(import_sql2.sql`${singleOrderBy}`);
@@ -284,7 +299,7 @@ class SQLiteDialect {
284
299
  const colEntries = Object.entries(columns).filter(
285
300
  ([_, col]) => !col.shouldDisableInsert()
286
301
  );
287
- const insertOrder = colEntries.map(([, column]) => import_sql2.sql.identifier(column.name));
302
+ const insertOrder = colEntries.map(([, column]) => import_sql2.sql.identifier(this.casing.getColumnCasing(column)));
288
303
  for (const [valueIndex, value] of values.entries()) {
289
304
  const valueList = [];
290
305
  for (const [fieldName, col] of colEntries) {
@@ -320,6 +335,7 @@ class SQLiteDialect {
320
335
  }
321
336
  sqlToQuery(sql2, invokeSource) {
322
337
  return sql2.toQuery({
338
+ casing: this.casing,
323
339
  escapeName: this.escapeName,
324
340
  escapeParam: this.escapeParam,
325
341
  escapeString: this.escapeString,
@@ -468,7 +484,7 @@ class SQLiteDialect {
468
484
  if (nestedQueryRelation) {
469
485
  let field = import_sql2.sql`json_array(${import_sql2.sql.join(
470
486
  selection.map(
471
- ({ field: field2 }) => (0, import_entity.is)(field2, import_columns.SQLiteColumn) ? import_sql2.sql.identifier(field2.name) : (0, import_entity.is)(field2, import_sql2.SQL.Aliased) ? field2.sql : field2
487
+ ({ field: field2 }) => (0, import_entity.is)(field2, import_columns.SQLiteColumn) ? import_sql2.sql.identifier(this.casing.getColumnCasing(field2)) : (0, import_entity.is)(field2, import_sql2.SQL.Aliased) ? field2.sql : field2
472
488
  ),
473
489
  import_sql2.sql`, `
474
490
  )})`;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/sqlite-core/dialect.ts"],"sourcesContent":["import { aliasedTable, aliasedTableColumn, mapColumnsInAliasedSQLToAlias, mapColumnsInSQLToAlias } from '~/alias.ts';\nimport type { AnyColumn } from '~/column.ts';\nimport { Column } from '~/column.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { DrizzleError } from '~/errors.ts';\nimport type { MigrationConfig, MigrationMeta } from '~/migrator.ts';\nimport {\n\ttype BuildRelationalQueryResult,\n\ttype DBQueryConfig,\n\tgetOperators,\n\tgetOrderByOperators,\n\tMany,\n\tnormalizeRelation,\n\tOne,\n\ttype Relation,\n\ttype TableRelationalConfig,\n\ttype TablesRelationalConfig,\n} from '~/relations.ts';\nimport type { Name } from '~/sql/index.ts';\nimport { and, eq } from '~/sql/index.ts';\nimport { Param, type QueryWithTypings, SQL, sql, type SQLChunk } from '~/sql/sql.ts';\nimport { SQLiteColumn } from '~/sqlite-core/columns/index.ts';\nimport type { SQLiteDeleteConfig, SQLiteInsertConfig, SQLiteUpdateConfig } from '~/sqlite-core/query-builders/index.ts';\nimport { SQLiteTable } from '~/sqlite-core/table.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { getTableName, getTableUniqueName, Table } from '~/table.ts';\nimport { orderSelectedFields, type UpdateSet } from '~/utils.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport type {\n\tSelectedFieldsOrdered,\n\tSQLiteSelectConfig,\n\tSQLiteSelectJoinConfig,\n} from './query-builders/select.types.ts';\nimport type { SQLiteSession } from './session.ts';\nimport { SQLiteViewBase } from './view-base.ts';\n\nexport abstract class SQLiteDialect {\n\tstatic readonly [entityKind]: string = 'SQLiteDialect';\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 }: SQLiteDeleteConfig): 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\treturn sql`${withSql}delete from ${table}${whereSql}${returningSql}`;\n\t}\n\n\tbuildUpdateSet(table: SQLiteTable, 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 setSize = columnNames.length;\n\t\treturn sql.join(columnNames.flatMap((colName, i) => {\n\t\t\tconst col = tableColumns[colName]!;\n\n\t\t\tconst value = set[colName] ?? sql.param(col.onUpdateFn!(), col);\n\t\t\tconst res = sql`${sql.identifier(col.name)} = ${value}`;\n\n\t\t\tif (i < setSize - 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 }: SQLiteUpdateConfig): 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\treturn sql`${withSql}update ${table} set ${setSql}${whereSql}${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, Column)) {\n\t\t\t\t\t\t\t\t\t\treturn sql.identifier(c.name);\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\tconst tableName = field.table[Table.Symbol.Name];\n\t\t\t\t\tconst columnName = field.name;\n\t\t\t\t\tif (isSingleTable) {\n\t\t\t\t\t\tchunk.push(sql.identifier(columnName));\n\t\t\t\t\t} else {\n\t\t\t\t\t\tchunk.push(sql`${sql.identifier(tableName)}.${sql.identifier(columnName)}`);\n\t\t\t\t\t}\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\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\tdistinct,\n\t\t\tsetOperators,\n\t\t}: SQLiteSelectConfig,\n\t): SQL {\n\t\tconst fieldsList = fieldsFlat ?? orderSelectedFields<SQLiteColumn>(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, SQLiteViewBase)\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.OriginalName] !== table[Table.Symbol.Name]) {\n\t\t\t\treturn sql`${sql.identifier(table[Table.Symbol.OriginalName])} ${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\n\t\t\t\tif (is(table, SQLiteTable)) {\n\t\t\t\t\tconst tableName = table[SQLiteTable.Symbol.Name];\n\t\t\t\t\tconst tableSchema = table[SQLiteTable.Symbol.Schema];\n\t\t\t\t\tconst origTableName = table[SQLiteTable.Symbol.OriginalName];\n\t\t\t\t\tconst alias = tableName === origTableName ? undefined : joinMeta.alias;\n\t\t\t\t\tjoinsArray.push(\n\t\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join ${tableSchema ? sql`${sql.identifier(tableSchema)}.` : undefined}${\n\t\t\t\t\t\t\tsql.identifier(origTableName)\n\t\t\t\t\t\t}${alias && sql` ${sql.identifier(alias)}`} on ${joinMeta.on}`,\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 ${table} on ${joinMeta.on}`,\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 orderByList: (SQLiteColumn | SQL | SQL.Aliased)[] = [];\n\t\tif (orderBy) {\n\t\t\tfor (const [index, orderByValue] of orderBy.entries()) {\n\t\t\t\torderByList.push(orderByValue);\n\n\t\t\t\tif (index < orderBy.length - 1) {\n\t\t\t\t\torderByList.push(sql`, `);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tconst groupByList: (SQL | AnyColumn | SQL.Aliased)[] = [];\n\t\tif (groupBy) {\n\t\t\tfor (const [index, groupByValue] of groupBy.entries()) {\n\t\t\t\tgroupByList.push(groupByValue);\n\n\t\t\t\tif (index < groupBy.length - 1) {\n\t\t\t\t\tgroupByList.push(sql`, `);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tconst groupBySql = groupByList.length > 0 ? sql` group by ${sql.join(groupByList)}` : undefined;\n\n\t\tconst orderBySql = orderByList.length > 0 ? sql` order by ${sql.join(orderByList)}` : undefined;\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 offsetSql = offset ? sql` offset ${offset}` : undefined;\n\n\t\tconst finalQuery =\n\t\t\tsql`${withSql}select${distinctSql} ${selection} from ${tableSql}${joinsSql}${whereSql}${groupBySql}${havingSql}${orderBySql}${limitSql}${offsetSql}`;\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: SQLiteSelectConfig['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: SQLiteSelectConfig['setOperators'][number] }): SQL {\n\t\t// SQLite doesn't support parenthesis in set operations\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 Sql syntax, Table from one of the SELECTs cannot be used in global ORDER clause\n\t\t\tfor (const singleOrderBy of orderBy) {\n\t\t\t\tif (is(singleOrderBy, SQLiteColumn)) {\n\t\t\t\t\torderByValues.push(sql.identifier(singleOrderBy.name));\n\t\t\t\t} else if (is(singleOrderBy, SQL)) {\n\t\t\t\t\tfor (let i = 0; i < singleOrderBy.queryChunks.length; i++) {\n\t\t\t\t\t\tconst chunk = singleOrderBy.queryChunks[i];\n\n\t\t\t\t\t\tif (is(chunk, SQLiteColumn)) {\n\t\t\t\t\t\t\tsingleOrderBy.queryChunks[i] = sql.identifier(chunk.name);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\torderByValues.push(sql`${singleOrderBy}`);\n\t\t\t\t} else {\n\t\t\t\t\torderByValues.push(sql`${singleOrderBy}`);\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({ table, values, onConflict, returning, withList }: SQLiteInsertConfig): SQL {\n\t\t// const isSingleValue = values.length === 1;\n\t\tconst valuesSqlList: ((SQLChunk | SQL)[] | SQL)[] = [];\n\t\tconst columns: Record<string, SQLiteColumn> = table[Table.Symbol.Columns];\n\n\t\tconst colEntries: [string, SQLiteColumn][] = Object.entries(columns).filter(([_, col]) =>\n\t\t\t!col.shouldDisableInsert()\n\t\t);\n\t\tconst insertOrder = colEntries.map(([, column]) => sql.identifier(column.name));\n\n\t\tfor (const [valueIndex, value] of values.entries()) {\n\t\t\tconst valueList: (SQLChunk | SQL)[] = [];\n\t\t\tfor (const [fieldName, col] of colEntries) {\n\t\t\t\tconst colValue = value[fieldName];\n\t\t\t\tif (colValue === undefined || (is(colValue, Param) && colValue.value === undefined)) {\n\t\t\t\t\tlet defaultValue;\n\t\t\t\t\tif (col.default !== null && col.default !== undefined) {\n\t\t\t\t\t\tdefaultValue = is(col.default, SQL) ? col.default : sql.param(col.default, col);\n\t\t\t\t\t\t// eslint-disable-next-line unicorn/no-negated-condition\n\t\t\t\t\t} else if (col.defaultFn !== undefined) {\n\t\t\t\t\t\tconst defaultFnResult = col.defaultFn();\n\t\t\t\t\t\tdefaultValue = is(defaultFnResult, SQL) ? defaultFnResult : sql.param(defaultFnResult, col);\n\t\t\t\t\t\t// eslint-disable-next-line unicorn/no-negated-condition\n\t\t\t\t\t} else if (!col.default && col.onUpdateFn !== undefined) {\n\t\t\t\t\t\tconst onUpdateFnResult = col.onUpdateFn();\n\t\t\t\t\t\tdefaultValue = is(onUpdateFnResult, SQL) ? onUpdateFnResult : sql.param(onUpdateFnResult, col);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tdefaultValue = sql`null`;\n\t\t\t\t\t}\n\t\t\t\t\tvalueList.push(defaultValue);\n\t\t\t\t} else {\n\t\t\t\t\tvalueList.push(colValue);\n\t\t\t\t}\n\t\t\t}\n\t\t\tvaluesSqlList.push(valueList);\n\t\t\tif (valueIndex < values.length - 1) {\n\t\t\t\tvaluesSqlList.push(sql`, `);\n\t\t\t}\n\t\t}\n\n\t\tconst withSql = this.buildWithCTE(withList);\n\n\t\tconst valuesSql = sql.join(valuesSqlList);\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 onConflictSql = onConflict ? sql` on conflict ${onConflict}` : undefined;\n\n\t\t// if (isSingleValue && valuesSqlList.length === 0){\n\t\t// \treturn sql`insert into ${table} default values ${onConflictSql}${returningSql}`;\n\t\t// }\n\n\t\treturn sql`${withSql}insert into ${table} ${insertOrder} values ${valuesSql}${onConflictSql}${returningSql}`;\n\t}\n\n\tsqlToQuery(sql: SQL, invokeSource?: 'indexes' | undefined): QueryWithTypings {\n\t\treturn sql.toQuery({\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\tbuildRelationalQuery({\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: TablesRelationalConfig;\n\t\ttableNamesMap: Record<string, string>;\n\t\ttable: SQLiteTable;\n\t\ttableConfig: TableRelationalConfig;\n\t\tqueryConfig: true | DBQueryConfig<'many', true>;\n\t\ttableAlias: string;\n\t\tnestedQueryRelation?: Relation;\n\t\tjoinOn?: SQL;\n\t}): BuildRelationalQueryResult<SQLiteTable, SQLiteColumn> {\n\t\tlet selection: BuildRelationalQueryResult<SQLiteTable, SQLiteColumn>['selection'] = [];\n\t\tlet limit, offset, orderBy: SQLiteSelectConfig['orderBy'] = [], where;\n\t\tconst joins: SQLiteSelectJoinConfig[] = [];\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 SQLiteColumn, 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, 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: SQLiteColumn | 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 SQLiteColumn;\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 | DBQueryConfig<'many', false>;\n\t\t\t\trelation: Relation;\n\t\t\t}[] = [];\n\n\t\t\t// Figure out which 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, 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 SQLiteColumn;\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 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 = 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\t// const relationTable = schema[relationTableTsName]!;\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 SQLiteTable,\n\t\t\t\t\ttableConfig: schema[relationTableTsName]!,\n\t\t\t\t\tqueryConfig: is(relation, 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`(${builtRelation.sql})`).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, SQLiteColumn) ? sql.identifier(field.name) : is(field, SQL.Aliased) ? field.sql : 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, Many)) {\n\t\t\t\tfield = sql`coalesce(json_group_array(${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;\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],\n\t\t\t\t\twhere,\n\t\t\t\t\tlimit,\n\t\t\t\t\toffset,\n\t\t\t\t\torderBy,\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, SQLiteTable) ? 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\nexport class SQLiteSyncDialect extends SQLiteDialect {\n\tstatic readonly [entityKind]: string = 'SQLiteSyncDialect';\n\n\tmigrate(\n\t\tmigrations: MigrationMeta[],\n\t\tsession: SQLiteSession<'sync', unknown, Record<string, unknown>, TablesRelationalConfig>,\n\t\tconfig?: string | MigrationConfig,\n\t): void {\n\t\tconst migrationsTable = config === undefined\n\t\t\t? '__drizzle_migrations'\n\t\t\t: typeof config === 'string'\n\t\t\t? '__drizzle_migrations'\n\t\t\t: config.migrationsTable ?? '__drizzle_migrations';\n\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 numeric\n\t\t\t)\n\t\t`;\n\t\tsession.run(migrationTableCreate);\n\n\t\tconst dbMigrations = session.values<[number, string, 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\tconst lastDbMigration = dbMigrations[0] ?? undefined;\n\t\tsession.run(sql`BEGIN`);\n\n\t\ttry {\n\t\t\tfor (const migration of migrations) {\n\t\t\t\tif (!lastDbMigration || Number(lastDbMigration[2])! < migration.folderMillis) {\n\t\t\t\t\tfor (const stmt of migration.sql) {\n\t\t\t\t\t\tsession.run(sql.raw(stmt));\n\t\t\t\t\t}\n\t\t\t\t\tsession.run(\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\n\t\t\tsession.run(sql`COMMIT`);\n\t\t} catch (e) {\n\t\t\tsession.run(sql`ROLLBACK`);\n\t\t\tthrow e;\n\t\t}\n\t}\n}\n\nexport class SQLiteAsyncDialect extends SQLiteDialect {\n\tstatic readonly [entityKind]: string = 'SQLiteAsyncDialect';\n\n\tasync migrate(\n\t\tmigrations: MigrationMeta[],\n\t\tsession: SQLiteSession<'async', any, any, any>,\n\t\tconfig?: string | MigrationConfig,\n\t): Promise<void> {\n\t\tconst migrationsTable = config === undefined\n\t\t\t? '__drizzle_migrations'\n\t\t\t: typeof config === 'string'\n\t\t\t? '__drizzle_migrations'\n\t\t\t: config.migrationsTable ?? '__drizzle_migrations';\n\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 numeric\n\t\t\t)\n\t\t`;\n\t\tawait session.run(migrationTableCreate);\n\n\t\tconst dbMigrations = await session.values<[number, string, 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\tconst lastDbMigration = dbMigrations[0] ?? undefined;\n\n\t\tawait session.transaction(async (tx) => {\n\t\t\tfor (const migration of migrations) {\n\t\t\t\tif (!lastDbMigration || Number(lastDbMigration[2])! < migration.folderMillis) {\n\t\t\t\t\tfor (const stmt of migration.sql) {\n\t\t\t\t\t\tawait tx.run(sql.raw(stmt));\n\t\t\t\t\t}\n\t\t\t\t\tawait tx.run(\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"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAwG;AAExG,oBAAuB;AACvB,oBAA+B;AAC/B,oBAA6B;AAE7B,uBAWO;AAEP,iBAAwB;AACxB,IAAAA,cAAsE;AACtE,qBAA6B;AAE7B,mBAA4B;AAC5B,sBAAyB;AACzB,IAAAC,gBAAwD;AACxD,mBAAoD;AACpD,yBAA+B;AAO/B,uBAA+B;AAExB,MAAe,cAAc;AAAA,EACnC,QAAiB,wBAAU,IAAY;AAAA,EAEvC,WAAW,MAAsB;AAChC,WAAO,IAAI,IAAI;AAAA,EAChB;AAAA,EAEA,YAAY,MAAsB;AACjC,WAAO;AAAA,EACR;AAAA,EAEA,aAAa,KAAqB;AACjC,WAAO,IAAI,IAAI,QAAQ,MAAM,IAAI,CAAC;AAAA,EACnC;AAAA,EAEQ,aAAa,SAAkD;AACtE,QAAI,CAAC,SAAS;AAAQ,aAAO;AAE7B,UAAM,gBAAgB,CAAC,sBAAU;AACjC,eAAW,CAAC,GAAG,CAAC,KAAK,QAAQ,QAAQ,GAAG;AACvC,oBAAc,KAAK,kBAAM,gBAAI,WAAW,EAAE,EAAE,KAAK,CAAC,QAAQ,EAAE,EAAE,GAAG,GAAG;AACpE,UAAI,IAAI,QAAQ,SAAS,GAAG;AAC3B,sBAAc,KAAK,mBAAO;AAAA,MAC3B;AAAA,IACD;AACA,kBAAc,KAAK,kBAAM;AACzB,WAAO,gBAAI,KAAK,aAAa;AAAA,EAC9B;AAAA,EAEA,iBAAiB,EAAE,OAAO,OAAO,WAAW,SAAS,GAA4B;AAChF,UAAM,UAAU,KAAK,aAAa,QAAQ;AAE1C,UAAM,eAAe,YAClB,6BAAiB,KAAK,eAAe,WAAW,EAAE,eAAe,KAAK,CAAC,CAAC,KACxE;AAEH,UAAM,WAAW,QAAQ,yBAAa,KAAK,KAAK;AAEhD,WAAO,kBAAM,OAAO,eAAe,KAAK,GAAG,QAAQ,GAAG,YAAY;AAAA,EACnE;AAAA,EAEA,eAAe,OAAoB,KAAqB;AACvD,UAAM,eAAe,MAAM,oBAAM,OAAO,OAAO;AAE/C,UAAM,cAAc,OAAO,KAAK,YAAY,EAAE;AAAA,MAAO,CAAC,YACrD,IAAI,OAAO,MAAM,UAAa,aAAa,OAAO,GAAG,eAAe;AAAA,IACrE;AAEA,UAAM,UAAU,YAAY;AAC5B,WAAO,gBAAI,KAAK,YAAY,QAAQ,CAAC,SAAS,MAAM;AACnD,YAAM,MAAM,aAAa,OAAO;AAEhC,YAAM,QAAQ,IAAI,OAAO,KAAK,gBAAI,MAAM,IAAI,WAAY,GAAG,GAAG;AAC9D,YAAM,MAAM,kBAAM,gBAAI,WAAW,IAAI,IAAI,CAAC,MAAM,KAAK;AAErD,UAAI,IAAI,UAAU,GAAG;AACpB,eAAO,CAAC,KAAK,gBAAI,IAAI,IAAI,CAAC;AAAA,MAC3B;AACA,aAAO,CAAC,GAAG;AAAA,IACZ,CAAC,CAAC;AAAA,EACH;AAAA,EAEA,iBAAiB,EAAE,OAAO,KAAK,OAAO,WAAW,SAAS,GAA4B;AACrF,UAAM,UAAU,KAAK,aAAa,QAAQ;AAE1C,UAAM,SAAS,KAAK,eAAe,OAAO,GAAG;AAE7C,UAAM,eAAe,YAClB,6BAAiB,KAAK,eAAe,WAAW,EAAE,eAAe,KAAK,CAAC,CAAC,KACxE;AAEH,UAAM,WAAW,QAAQ,yBAAa,KAAK,KAAK;AAEhD,WAAO,kBAAM,OAAO,UAAU,KAAK,QAAQ,MAAM,GAAG,QAAQ,GAAG,YAAY;AAAA,EAC5E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAaQ,eACP,QACA,EAAE,gBAAgB,MAAM,IAAiC,CAAC,GACpD;AACN,UAAM,aAAa,OAAO;AAE1B,UAAM,SAAS,OACb,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM;AAC1B,YAAM,QAAoB,CAAC;AAE3B,cAAI,kBAAG,OAAO,gBAAI,OAAO,KAAK,MAAM,kBAAkB;AACrD,cAAM,KAAK,gBAAI,WAAW,MAAM,UAAU,CAAC;AAAA,MAC5C,eAAW,kBAAG,OAAO,gBAAI,OAAO,SAAK,kBAAG,OAAO,eAAG,GAAG;AACpD,cAAM,YAAQ,kBAAG,OAAO,gBAAI,OAAO,IAAI,MAAM,MAAM;AAEnD,YAAI,eAAe;AAClB,gBAAM;AAAA,YACL,IAAI;AAAA,cACH,MAAM,YAAY,IAAI,CAAC,MAAM;AAC5B,wBAAI,kBAAG,GAAG,oBAAM,GAAG;AAClB,yBAAO,gBAAI,WAAW,EAAE,IAAI;AAAA,gBAC7B;AACA,uBAAO;AAAA,cACR,CAAC;AAAA,YACF;AAAA,UACD;AAAA,QACD,OAAO;AACN,gBAAM,KAAK,KAAK;AAAA,QACjB;AAEA,gBAAI,kBAAG,OAAO,gBAAI,OAAO,GAAG;AAC3B,gBAAM,KAAK,sBAAU,gBAAI,WAAW,MAAM,UAAU,CAAC,EAAE;AAAA,QACxD;AAAA,MACD,eAAW,kBAAG,OAAO,oBAAM,GAAG;AAC7B,cAAM,YAAY,MAAM,MAAM,oBAAM,OAAO,IAAI;AAC/C,cAAM,aAAa,MAAM;AACzB,YAAI,eAAe;AAClB,gBAAM,KAAK,gBAAI,WAAW,UAAU,CAAC;AAAA,QACtC,OAAO;AACN,gBAAM,KAAK,kBAAM,gBAAI,WAAW,SAAS,CAAC,IAAI,gBAAI,WAAW,UAAU,CAAC,EAAE;AAAA,QAC3E;AAAA,MACD;AAEA,UAAI,IAAI,aAAa,GAAG;AACvB,cAAM,KAAK,mBAAO;AAAA,MACnB;AAEA,aAAO;AAAA,IACR,CAAC;AAEF,WAAO,gBAAI,KAAK,MAAM;AAAA,EACvB;AAAA,EAEA,iBACC;AAAA,IACC;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACD,GACM;AACN,UAAM,aAAa,kBAAc,kCAAkC,MAAM;AACzE,eAAW,KAAK,YAAY;AAC3B,cACC,kBAAG,EAAE,OAAO,oBAAM,SACf,4BAAa,EAAE,MAAM,KAAK,WACvB,kBAAG,OAAO,wBAAQ,IACpB,MAAM,EAAE,YACR,kBAAG,OAAO,+BAAc,IACxB,MAAM,iCAAc,EAAE,WACtB,kBAAG,OAAO,eAAG,IACb,aACA,4BAAa,KAAK,MACnB,EAAE,CAACC,WACL,OAAO;AAAA,QAAK,CAAC,EAAE,MAAM,MACpB,WAAWA,OAAM,oBAAM,OAAO,OAAO,QAAI,4BAAaA,MAAK,IAAIA,OAAM,oBAAM,OAAO,QAAQ;AAAA,MAC3F,GAAG,EAAE,MAAM,KAAK,GAChB;AACD,cAAM,gBAAY,4BAAa,EAAE,MAAM,KAAK;AAC5C,cAAM,IAAI;AAAA,UACT,SACC,EAAE,KAAK,KAAK,IAAI,CACjB,gCAAgC,SAAS,MAAM,EAAE,MAAM,IAAI,qBAAqB,SAAS;AAAA,QAC1F;AAAA,MACD;AAAA,IACD;AAEA,UAAM,gBAAgB,CAAC,SAAS,MAAM,WAAW;AAEjD,UAAM,UAAU,KAAK,aAAa,QAAQ;AAE1C,UAAM,cAAc,WAAW,6BAAiB;AAEhD,UAAM,YAAY,KAAK,eAAe,YAAY,EAAE,cAAc,CAAC;AAEnE,UAAM,YAAY,MAAM;AACvB,cAAI,kBAAG,OAAO,mBAAK,KAAK,MAAM,oBAAM,OAAO,YAAY,MAAM,MAAM,oBAAM,OAAO,IAAI,GAAG;AACtF,eAAO,kBAAM,gBAAI,WAAW,MAAM,oBAAM,OAAO,YAAY,CAAC,CAAC,IAAI,gBAAI,WAAW,MAAM,oBAAM,OAAO,IAAI,CAAC,CAAC;AAAA,MAC1G;AAEA,aAAO;AAAA,IACR,GAAG;AAEH,UAAM,aAAoB,CAAC;AAE3B,QAAI,OAAO;AACV,iBAAW,CAAC,OAAO,QAAQ,KAAK,MAAM,QAAQ,GAAG;AAChD,YAAI,UAAU,GAAG;AAChB,qBAAW,KAAK,kBAAM;AAAA,QACvB;AACA,cAAMA,SAAQ,SAAS;AAEvB,gBAAI,kBAAGA,QAAO,wBAAW,GAAG;AAC3B,gBAAM,YAAYA,OAAM,yBAAY,OAAO,IAAI;AAC/C,gBAAM,cAAcA,OAAM,yBAAY,OAAO,MAAM;AACnD,gBAAM,gBAAgBA,OAAM,yBAAY,OAAO,YAAY;AAC3D,gBAAM,QAAQ,cAAc,gBAAgB,SAAY,SAAS;AACjE,qBAAW;AAAA,YACV,kBAAM,gBAAI,IAAI,SAAS,QAAQ,CAAC,SAAS,cAAc,kBAAM,gBAAI,WAAW,WAAW,CAAC,MAAM,MAAS,GACtG,gBAAI,WAAW,aAAa,CAC7B,GAAG,SAAS,mBAAO,gBAAI,WAAW,KAAK,CAAC,EAAE,OAAO,SAAS,EAAE;AAAA,UAC7D;AAAA,QACD,OAAO;AACN,qBAAW;AAAA,YACV,kBAAM,gBAAI,IAAI,SAAS,QAAQ,CAAC,SAASA,MAAK,OAAO,SAAS,EAAE;AAAA,UACjE;AAAA,QACD;AACA,YAAI,QAAQ,MAAM,SAAS,GAAG;AAC7B,qBAAW,KAAK,kBAAM;AAAA,QACvB;AAAA,MACD;AAAA,IACD;AAEA,UAAM,WAAW,gBAAI,KAAK,UAAU;AAEpC,UAAM,WAAW,QAAQ,yBAAa,KAAK,KAAK;AAEhD,UAAM,YAAY,SAAS,0BAAc,MAAM,KAAK;AAEpD,UAAM,cAAoD,CAAC;AAC3D,QAAI,SAAS;AACZ,iBAAW,CAAC,OAAO,YAAY,KAAK,QAAQ,QAAQ,GAAG;AACtD,oBAAY,KAAK,YAAY;AAE7B,YAAI,QAAQ,QAAQ,SAAS,GAAG;AAC/B,sBAAY,KAAK,mBAAO;AAAA,QACzB;AAAA,MACD;AAAA,IACD;AAEA,UAAM,cAAiD,CAAC;AACxD,QAAI,SAAS;AACZ,iBAAW,CAAC,OAAO,YAAY,KAAK,QAAQ,QAAQ,GAAG;AACtD,oBAAY,KAAK,YAAY;AAE7B,YAAI,QAAQ,QAAQ,SAAS,GAAG;AAC/B,sBAAY,KAAK,mBAAO;AAAA,QACzB;AAAA,MACD;AAAA,IACD;AAEA,UAAM,aAAa,YAAY,SAAS,IAAI,4BAAgB,gBAAI,KAAK,WAAW,CAAC,KAAK;AAEtF,UAAM,aAAa,YAAY,SAAS,IAAI,4BAAgB,gBAAI,KAAK,WAAW,CAAC,KAAK;AAEtF,UAAM,WAAW,OAAO,UAAU,YAAa,OAAO,UAAU,YAAY,SAAS,IAClF,yBAAa,KAAK,KAClB;AAEH,UAAM,YAAY,SAAS,0BAAc,MAAM,KAAK;AAEpD,UAAM,aACL,kBAAM,OAAO,SAAS,WAAW,IAAI,SAAS,SAAS,QAAQ,GAAG,QAAQ,GAAG,QAAQ,GAAG,UAAU,GAAG,SAAS,GAAG,UAAU,GAAG,QAAQ,GAAG,SAAS;AAEnJ,QAAI,aAAa,SAAS,GAAG;AAC5B,aAAO,KAAK,mBAAmB,YAAY,YAAY;AAAA,IACxD;AAEA,WAAO;AAAA,EACR;AAAA,EAEA,mBAAmB,YAAiB,cAAuD;AAC1F,UAAM,CAAC,aAAa,GAAG,IAAI,IAAI;AAE/B,QAAI,CAAC,aAAa;AACjB,YAAM,IAAI,MAAM,kDAAkD;AAAA,IACnE;AAEA,QAAI,KAAK,WAAW,GAAG;AACtB,aAAO,KAAK,uBAAuB,EAAE,YAAY,YAAY,CAAC;AAAA,IAC/D;AAGA,WAAO,KAAK;AAAA,MACX,KAAK,uBAAuB,EAAE,YAAY,YAAY,CAAC;AAAA,MACvD;AAAA,IACD;AAAA,EACD;AAAA,EAEA,uBAAuB;AAAA,IACtB;AAAA,IACA,aAAa,EAAE,MAAM,OAAO,aAAa,OAAO,SAAS,OAAO;AAAA,EACjE,GAAsF;AAErF,UAAM,YAAY,kBAAM,WAAW,OAAO,CAAC;AAC3C,UAAM,aAAa,kBAAM,YAAY,OAAO,CAAC;AAE7C,QAAI;AACJ,QAAI,WAAW,QAAQ,SAAS,GAAG;AAClC,YAAM,gBAAyC,CAAC;AAIhD,iBAAW,iBAAiB,SAAS;AACpC,gBAAI,kBAAG,eAAe,2BAAY,GAAG;AACpC,wBAAc,KAAK,gBAAI,WAAW,cAAc,IAAI,CAAC;AAAA,QACtD,eAAW,kBAAG,eAAe,eAAG,GAAG;AAClC,mBAAS,IAAI,GAAG,IAAI,cAAc,YAAY,QAAQ,KAAK;AAC1D,kBAAM,QAAQ,cAAc,YAAY,CAAC;AAEzC,oBAAI,kBAAG,OAAO,2BAAY,GAAG;AAC5B,4BAAc,YAAY,CAAC,IAAI,gBAAI,WAAW,MAAM,IAAI;AAAA,YACzD;AAAA,UACD;AAEA,wBAAc,KAAK,kBAAM,aAAa,EAAE;AAAA,QACzC,OAAO;AACN,wBAAc,KAAK,kBAAM,aAAa,EAAE;AAAA,QACzC;AAAA,MACD;AAEA,mBAAa,4BAAgB,gBAAI,KAAK,eAAe,mBAAO,CAAC;AAAA,IAC9D;AAEA,UAAM,WAAW,OAAO,UAAU,YAAa,OAAO,UAAU,YAAY,SAAS,IAClF,yBAAa,KAAK,KAClB;AAEH,UAAM,gBAAgB,gBAAI,IAAI,GAAG,IAAI,IAAI,QAAQ,SAAS,EAAE,EAAE;AAE9D,UAAM,YAAY,SAAS,0BAAc,MAAM,KAAK;AAEpD,WAAO,kBAAM,SAAS,GAAG,aAAa,GAAG,UAAU,GAAG,UAAU,GAAG,QAAQ,GAAG,SAAS;AAAA,EACxF;AAAA,EAEA,iBAAiB,EAAE,OAAO,QAAQ,YAAY,WAAW,SAAS,GAA4B;AAE7F,UAAM,gBAA8C,CAAC;AACrD,UAAM,UAAwC,MAAM,oBAAM,OAAO,OAAO;AAExE,UAAM,aAAuC,OAAO,QAAQ,OAAO,EAAE;AAAA,MAAO,CAAC,CAAC,GAAG,GAAG,MACnF,CAAC,IAAI,oBAAoB;AAAA,IAC1B;AACA,UAAM,cAAc,WAAW,IAAI,CAAC,CAAC,EAAE,MAAM,MAAM,gBAAI,WAAW,OAAO,IAAI,CAAC;AAE9E,eAAW,CAAC,YAAY,KAAK,KAAK,OAAO,QAAQ,GAAG;AACnD,YAAM,YAAgC,CAAC;AACvC,iBAAW,CAAC,WAAW,GAAG,KAAK,YAAY;AAC1C,cAAM,WAAW,MAAM,SAAS;AAChC,YAAI,aAAa,cAAc,kBAAG,UAAU,iBAAK,KAAK,SAAS,UAAU,QAAY;AACpF,cAAI;AACJ,cAAI,IAAI,YAAY,QAAQ,IAAI,YAAY,QAAW;AACtD,+BAAe,kBAAG,IAAI,SAAS,eAAG,IAAI,IAAI,UAAU,gBAAI,MAAM,IAAI,SAAS,GAAG;AAAA,UAE/E,WAAW,IAAI,cAAc,QAAW;AACvC,kBAAM,kBAAkB,IAAI,UAAU;AACtC,+BAAe,kBAAG,iBAAiB,eAAG,IAAI,kBAAkB,gBAAI,MAAM,iBAAiB,GAAG;AAAA,UAE3F,WAAW,CAAC,IAAI,WAAW,IAAI,eAAe,QAAW;AACxD,kBAAM,mBAAmB,IAAI,WAAW;AACxC,+BAAe,kBAAG,kBAAkB,eAAG,IAAI,mBAAmB,gBAAI,MAAM,kBAAkB,GAAG;AAAA,UAC9F,OAAO;AACN,2BAAe;AAAA,UAChB;AACA,oBAAU,KAAK,YAAY;AAAA,QAC5B,OAAO;AACN,oBAAU,KAAK,QAAQ;AAAA,QACxB;AAAA,MACD;AACA,oBAAc,KAAK,SAAS;AAC5B,UAAI,aAAa,OAAO,SAAS,GAAG;AACnC,sBAAc,KAAK,mBAAO;AAAA,MAC3B;AAAA,IACD;AAEA,UAAM,UAAU,KAAK,aAAa,QAAQ;AAE1C,UAAM,YAAY,gBAAI,KAAK,aAAa;AAExC,UAAM,eAAe,YAClB,6BAAiB,KAAK,eAAe,WAAW,EAAE,eAAe,KAAK,CAAC,CAAC,KACxE;AAEH,UAAM,gBAAgB,aAAa,+BAAmB,UAAU,KAAK;AAMrE,WAAO,kBAAM,OAAO,eAAe,KAAK,IAAI,WAAW,WAAW,SAAS,GAAG,aAAa,GAAG,YAAY;AAAA,EAC3G;AAAA,EAEA,WAAWC,MAAU,cAAwD;AAC5E,WAAOA,KAAI,QAAQ;AAAA,MAClB,YAAY,KAAK;AAAA,MACjB,aAAa,KAAK;AAAA,MAClB,cAAc,KAAK;AAAA,MACnB;AAAA,IACD,CAAC;AAAA,EACF;AAAA,EAEA,qBAAqB;AAAA,IACpB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,aAAa;AAAA,IACb;AAAA,IACA;AAAA,IACA;AAAA,EACD,GAU0D;AACzD,QAAI,YAAgF,CAAC;AACrF,QAAI,OAAO,QAAQ,UAAyC,CAAC,GAAG;AAChE,UAAM,QAAkC,CAAC;AAEzC,QAAI,WAAW,MAAM;AACpB,YAAM,mBAAmB,OAAO,QAAQ,YAAY,OAAO;AAC3D,kBAAY,iBAAiB,IAAI,CAChC,CAAC,KAAK,KAAK,OACN;AAAA,QACL,OAAO,MAAM;AAAA,QACb,OAAO;AAAA,QACP,WAAO,iCAAmB,OAAuB,UAAU;AAAA,QAC3D,oBAAoB;AAAA,QACpB,QAAQ;AAAA,QACR,WAAW,CAAC;AAAA,MACb,EAAE;AAAA,IACH,OAAO;AACN,YAAM,iBAAiB,OAAO;AAAA,QAC7B,OAAO,QAAQ,YAAY,OAAO,EAAE,IAAI,CAAC,CAAC,KAAK,KAAK,MAAM,CAAC,SAAK,iCAAmB,OAAO,UAAU,CAAC,CAAC;AAAA,MACvG;AAEA,UAAI,OAAO,OAAO;AACjB,cAAM,WAAW,OAAO,OAAO,UAAU,aACtC,OAAO,MAAM,oBAAgB,+BAAa,CAAC,IAC3C,OAAO;AACV,gBAAQ,gBAAY,qCAAuB,UAAU,UAAU;AAAA,MAChE;AAEA,YAAM,kBAA0E,CAAC;AACjF,UAAI,kBAA4B,CAAC;AAGjC,UAAI,OAAO,SAAS;AACnB,YAAI,gBAAgB;AAEpB,mBAAW,CAAC,OAAO,KAAK,KAAK,OAAO,QAAQ,OAAO,OAAO,GAAG;AAC5D,cAAI,UAAU,QAAW;AACxB;AAAA,UACD;AAEA,cAAI,SAAS,YAAY,SAAS;AACjC,gBAAI,CAAC,iBAAiB,UAAU,MAAM;AACrC,8BAAgB;AAAA,YACjB;AACA,4BAAgB,KAAK,KAAK;AAAA,UAC3B;AAAA,QACD;AAEA,YAAI,gBAAgB,SAAS,GAAG;AAC/B,4BAAkB,gBACf,gBAAgB,OAAO,CAAC,MAAM,OAAO,UAAU,CAAC,MAAM,IAAI,IAC1D,OAAO,KAAK,YAAY,OAAO,EAAE,OAAO,CAAC,QAAQ,CAAC,gBAAgB,SAAS,GAAG,CAAC;AAAA,QACnF;AAAA,MACD,OAAO;AAEN,0BAAkB,OAAO,KAAK,YAAY,OAAO;AAAA,MAClD;AAEA,iBAAW,SAAS,iBAAiB;AACpC,cAAM,SAAS,YAAY,QAAQ,KAAK;AACxC,wBAAgB,KAAK,EAAE,OAAO,OAAO,OAAO,OAAO,CAAC;AAAA,MACrD;AAEA,UAAI,oBAIE,CAAC;AAGP,UAAI,OAAO,MAAM;AAChB,4BAAoB,OAAO,QAAQ,OAAO,IAAI,EAC5C,OAAO,CAAC,UAAoE,CAAC,CAAC,MAAM,CAAC,CAAC,EACtF,IAAI,CAAC,CAAC,OAAO,WAAW,OAAO,EAAE,OAAO,aAAa,UAAU,YAAY,UAAU,KAAK,EAAG,EAAE;AAAA,MAClG;AAEA,UAAI;AAGJ,UAAI,OAAO,QAAQ;AAClB,iBAAS,OAAO,OAAO,WAAW,aAC/B,OAAO,OAAO,gBAAgB,EAAE,qBAAI,CAAC,IACrC,OAAO;AACV,mBAAW,CAAC,OAAO,KAAK,KAAK,OAAO,QAAQ,MAAM,GAAG;AACpD,0BAAgB,KAAK;AAAA,YACpB;AAAA,YACA,WAAO,4CAA8B,OAAO,UAAU;AAAA,UACvD,CAAC;AAAA,QACF;AAAA,MACD;AAIA,iBAAW,EAAE,OAAO,MAAM,KAAK,iBAAiB;AAC/C,kBAAU,KAAK;AAAA,UACd,WAAO,kBAAG,OAAO,gBAAI,OAAO,IAAI,MAAM,aAAa,YAAY,QAAQ,KAAK,EAAG;AAAA,UAC/E;AAAA,UACA,WAAO,kBAAG,OAAO,oBAAM,QAAI,iCAAmB,OAAO,UAAU,IAAI;AAAA,UACnE,oBAAoB;AAAA,UACpB,QAAQ;AAAA,UACR,WAAW,CAAC;AAAA,QACb,CAAC;AAAA,MACF;AAEA,UAAI,cAAc,OAAO,OAAO,YAAY,aACzC,OAAO,QAAQ,oBAAgB,sCAAoB,CAAC,IACpD,OAAO,WAAW,CAAC;AACtB,UAAI,CAAC,MAAM,QAAQ,WAAW,GAAG;AAChC,sBAAc,CAAC,WAAW;AAAA,MAC3B;AACA,gBAAU,YAAY,IAAI,CAAC,iBAAiB;AAC3C,gBAAI,kBAAG,cAAc,oBAAM,GAAG;AAC7B,qBAAO,iCAAmB,cAAc,UAAU;AAAA,QACnD;AACA,mBAAO,qCAAuB,cAAc,UAAU;AAAA,MACvD,CAAC;AAED,cAAQ,OAAO;AACf,eAAS,OAAO;AAGhB,iBACO;AAAA,QACL,OAAO;AAAA,QACP,aAAa;AAAA,QACb;AAAA,MACD,KAAK,mBACJ;AACD,cAAM,yBAAqB,oCAAkB,QAAQ,eAAe,QAAQ;AAC5E,cAAM,wBAAoB,kCAAmB,SAAS,eAAe;AACrE,cAAM,sBAAsB,cAAc,iBAAiB;AAC3D,cAAM,qBAAqB,GAAG,UAAU,IAAI,qBAAqB;AAEjE,cAAMC,cAAS;AAAA,UACd,GAAG,mBAAmB,OAAO;AAAA,YAAI,CAACC,QAAO,UACxC;AAAA,kBACC,iCAAmB,mBAAmB,WAAW,CAAC,GAAI,kBAAkB;AAAA,kBACxE,iCAAmBA,QAAO,UAAU;AAAA,YACrC;AAAA,UACD;AAAA,QACD;AACA,cAAM,gBAAgB,KAAK,qBAAqB;AAAA,UAC/C;AAAA,UACA;AAAA,UACA;AAAA,UACA,OAAO,WAAW,mBAAmB;AAAA,UACrC,aAAa,OAAO,mBAAmB;AAAA,UACvC,iBAAa,kBAAG,UAAU,oBAAG,IACzB,gCAAgC,OAChC,EAAE,OAAO,EAAE,IACX,EAAE,GAAG,6BAA6B,OAAO,EAAE,IAC5C;AAAA,UACH,YAAY;AAAA,UACZ,QAAAD;AAAA,UACA,qBAAqB;AAAA,QACtB,CAAC;AACD,cAAM,QAAS,mBAAO,cAAc,GAAG,IAAK,GAAG,qBAAqB;AACpE,kBAAU,KAAK;AAAA,UACd,OAAO;AAAA,UACP,OAAO;AAAA,UACP;AAAA,UACA,oBAAoB;AAAA,UACpB,QAAQ;AAAA,UACR,WAAW,cAAc;AAAA,QAC1B,CAAC;AAAA,MACF;AAAA,IACD;AAEA,QAAI,UAAU,WAAW,GAAG;AAC3B,YAAM,IAAI,2BAAa;AAAA,QACtB,SACC,iCAAiC,YAAY,MAAM,OAAO,UAAU;AAAA,MACtE,CAAC;AAAA,IACF;AAEA,QAAI;AAEJ,gBAAQ,gBAAI,QAAQ,KAAK;AAEzB,QAAI,qBAAqB;AACxB,UAAI,QAAQ,6BACX,gBAAI;AAAA,QACH,UAAU;AAAA,UAAI,CAAC,EAAE,OAAAC,OAAM,UACtB,kBAAGA,QAAO,2BAAY,IAAI,gBAAI,WAAWA,OAAM,IAAI,QAAI,kBAAGA,QAAO,gBAAI,OAAO,IAAIA,OAAM,MAAMA;AAAA,QAC7F;AAAA,QACA;AAAA,MACD,CACD;AACA,cAAI,kBAAG,qBAAqB,qBAAI,GAAG;AAClC,gBAAQ,4CAAgC,KAAK;AAAA,MAC9C;AACA,YAAM,kBAAkB,CAAC;AAAA,QACxB,OAAO;AAAA,QACP,OAAO;AAAA,QACP,OAAO,MAAM,GAAG,MAAM;AAAA,QACtB,QAAQ;AAAA,QACR,oBAAoB,YAAY;AAAA,QAChC;AAAA,MACD,CAAC;AAED,YAAM,gBAAgB,UAAU,UAAa,WAAW,UAAa,QAAQ,SAAS;AAEtF,UAAI,eAAe;AAClB,iBAAS,KAAK,iBAAiB;AAAA,UAC9B,WAAO,2BAAa,OAAO,UAAU;AAAA,UACrC,QAAQ,CAAC;AAAA,UACT,YAAY;AAAA,YACX;AAAA,cACC,MAAM,CAAC;AAAA,cACP,OAAO,gBAAI,IAAI,GAAG;AAAA,YACnB;AAAA,UACD;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA,cAAc,CAAC;AAAA,QAChB,CAAC;AAED,gBAAQ;AACR,gBAAQ;AACR,iBAAS;AACT,kBAAU;AAAA,MACX,OAAO;AACN,qBAAS,2BAAa,OAAO,UAAU;AAAA,MACxC;AAEA,eAAS,KAAK,iBAAiB;AAAA,QAC9B,WAAO,kBAAG,QAAQ,wBAAW,IAAI,SAAS,IAAI,yBAAS,QAAQ,CAAC,GAAG,UAAU;AAAA,QAC7E,QAAQ,CAAC;AAAA,QACT,YAAY,gBAAgB,IAAI,CAAC,EAAE,OAAAA,OAAM,OAAO;AAAA,UAC/C,MAAM,CAAC;AAAA,UACP,WAAO,kBAAGA,QAAO,oBAAM,QAAI,iCAAmBA,QAAO,UAAU,IAAIA;AAAA,QACpE,EAAE;AAAA,QACF;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA,cAAc,CAAC;AAAA,MAChB,CAAC;AAAA,IACF,OAAO;AACN,eAAS,KAAK,iBAAiB;AAAA,QAC9B,WAAO,2BAAa,OAAO,UAAU;AAAA,QACrC,QAAQ,CAAC;AAAA,QACT,YAAY,UAAU,IAAI,CAAC,EAAE,MAAM,OAAO;AAAA,UACzC,MAAM,CAAC;AAAA,UACP,WAAO,kBAAG,OAAO,oBAAM,QAAI,iCAAmB,OAAO,UAAU,IAAI;AAAA,QACpE,EAAE;AAAA,QACF;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA,cAAc,CAAC;AAAA,MAChB,CAAC;AAAA,IACF;AAEA,WAAO;AAAA,MACN,YAAY,YAAY;AAAA,MACxB,KAAK;AAAA,MACL;AAAA,IACD;AAAA,EACD;AACD;AAEO,MAAM,0BAA0B,cAAc;AAAA,EACpD,QAAiB,wBAAU,IAAY;AAAA,EAEvC,QACC,YACA,SACA,QACO;AACP,UAAM,kBAAkB,WAAW,SAChC,yBACA,OAAO,WAAW,WAClB,yBACA,OAAO,mBAAmB;AAE7B,UAAM,uBAAuB;AAAA,gCACC,gBAAI,WAAW,eAAe,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAM7D,YAAQ,IAAI,oBAAoB;AAEhC,UAAM,eAAe,QAAQ;AAAA,MAC5B,mDAAuC,gBAAI,WAAW,eAAe,CAAC;AAAA,IACvE;AAEA,UAAM,kBAAkB,aAAa,CAAC,KAAK;AAC3C,YAAQ,IAAI,sBAAU;AAEtB,QAAI;AACH,iBAAW,aAAa,YAAY;AACnC,YAAI,CAAC,mBAAmB,OAAO,gBAAgB,CAAC,CAAC,IAAK,UAAU,cAAc;AAC7E,qBAAW,QAAQ,UAAU,KAAK;AACjC,oBAAQ,IAAI,gBAAI,IAAI,IAAI,CAAC;AAAA,UAC1B;AACA,kBAAQ;AAAA,YACP,8BACC,gBAAI,WAAW,eAAe,CAC/B,kCAAkC,UAAU,IAAI,KAAK,UAAU,YAAY;AAAA,UAC5E;AAAA,QACD;AAAA,MACD;AAEA,cAAQ,IAAI,uBAAW;AAAA,IACxB,SAAS,GAAG;AACX,cAAQ,IAAI,yBAAa;AACzB,YAAM;AAAA,IACP;AAAA,EACD;AACD;AAEO,MAAM,2BAA2B,cAAc;AAAA,EACrD,QAAiB,wBAAU,IAAY;AAAA,EAEvC,MAAM,QACL,YACA,SACA,QACgB;AAChB,UAAM,kBAAkB,WAAW,SAChC,yBACA,OAAO,WAAW,WAClB,yBACA,OAAO,mBAAmB;AAE7B,UAAM,uBAAuB;AAAA,gCACC,gBAAI,WAAW,eAAe,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAM7D,UAAM,QAAQ,IAAI,oBAAoB;AAEtC,UAAM,eAAe,MAAM,QAAQ;AAAA,MAClC,mDAAuC,gBAAI,WAAW,eAAe,CAAC;AAAA,IACvE;AAEA,UAAM,kBAAkB,aAAa,CAAC,KAAK;AAE3C,UAAM,QAAQ,YAAY,OAAO,OAAO;AACvC,iBAAW,aAAa,YAAY;AACnC,YAAI,CAAC,mBAAmB,OAAO,gBAAgB,CAAC,CAAC,IAAK,UAAU,cAAc;AAC7E,qBAAW,QAAQ,UAAU,KAAK;AACjC,kBAAM,GAAG,IAAI,gBAAI,IAAI,IAAI,CAAC;AAAA,UAC3B;AACA,gBAAM,GAAG;AAAA,YACR,8BACC,gBAAI,WAAW,eAAe,CAC/B,kCAAkC,UAAU,IAAI,KAAK,UAAU,YAAY;AAAA,UAC5E;AAAA,QACD;AAAA,MACD;AAAA,IACD,CAAC;AAAA,EACF;AACD;","names":["import_sql","import_table","table","sql","joinOn","field"]}
1
+ {"version":3,"sources":["../../src/sqlite-core/dialect.ts"],"sourcesContent":["import { aliasedTable, aliasedTableColumn, mapColumnsInAliasedSQLToAlias, mapColumnsInSQLToAlias } from '~/alias.ts';\nimport { CasingCache } from '~/casing.ts';\nimport type { AnyColumn } from '~/column.ts';\nimport { Column } from '~/column.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { DrizzleError } from '~/errors.ts';\nimport type { MigrationConfig, MigrationMeta } from '~/migrator.ts';\nimport {\n\ttype BuildRelationalQueryResult,\n\ttype DBQueryConfig,\n\tgetOperators,\n\tgetOrderByOperators,\n\tMany,\n\tnormalizeRelation,\n\tOne,\n\ttype Relation,\n\ttype TableRelationalConfig,\n\ttype TablesRelationalConfig,\n} from '~/relations.ts';\nimport type { Name, Placeholder } from '~/sql/index.ts';\nimport { and, eq } from '~/sql/index.ts';\nimport { Param, type QueryWithTypings, SQL, sql, type SQLChunk } from '~/sql/sql.ts';\nimport { SQLiteColumn } from '~/sqlite-core/columns/index.ts';\nimport type { SQLiteDeleteConfig, SQLiteInsertConfig, SQLiteUpdateConfig } from '~/sqlite-core/query-builders/index.ts';\nimport { SQLiteTable } from '~/sqlite-core/table.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { getTableName, getTableUniqueName, Table } from '~/table.ts';\nimport { type Casing, orderSelectedFields, type UpdateSet } from '~/utils.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport type {\n\tSelectedFieldsOrdered,\n\tSQLiteSelectConfig,\n\tSQLiteSelectJoinConfig,\n} from './query-builders/select.types.ts';\nimport type { SQLiteSession } from './session.ts';\nimport { SQLiteViewBase } from './view-base.ts';\n\nexport interface SQLiteDialectConfig {\n\tcasing?: Casing;\n}\n\nexport abstract class SQLiteDialect {\n\tstatic readonly [entityKind]: string = 'SQLiteDialect';\n\n\t/** @internal */\n\treadonly casing: CasingCache;\n\n\tconstructor(config?: SQLiteDialectConfig) {\n\t\tthis.casing = new CasingCache(config?.casing);\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 }: SQLiteDeleteConfig): 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}${returningSql}${orderBySql}${limitSql}`;\n\t}\n\n\tbuildUpdateSet(table: SQLiteTable, 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 setSize = columnNames.length;\n\t\treturn sql.join(columnNames.flatMap((colName, i) => {\n\t\t\tconst col = tableColumns[colName]!;\n\n\t\t\tconst value = set[colName] ?? sql.param(col.onUpdateFn!(), col);\n\t\t\tconst res = sql`${sql.identifier(this.casing.getColumnCasing(col))} = ${value}`;\n\n\t\t\tif (i < setSize - 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 }: SQLiteUpdateConfig): 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}${returningSql}${orderBySql}${limitSql}`;\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, Column)) {\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\tconst tableName = field.table[Table.Symbol.Name];\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(sql`${sql.identifier(tableName)}.${sql.identifier(this.casing.getColumnCasing(field))}`);\n\t\t\t\t\t}\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: (SQLiteColumn | SQL | SQL.Aliased)[] | undefined): SQL | undefined {\n\t\tconst orderByList: (SQLiteColumn | SQL | SQL.Aliased)[] = [];\n\n\t\tif (orderBy) {\n\t\t\tfor (const [index, orderByValue] of orderBy.entries()) {\n\t\t\t\torderByList.push(orderByValue);\n\n\t\t\t\tif (index < orderBy.length - 1) {\n\t\t\t\t\torderByList.push(sql`, `);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn orderByList.length > 0 ? sql` order by ${sql.join(orderByList)}` : 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\tdistinct,\n\t\t\tsetOperators,\n\t\t}: SQLiteSelectConfig,\n\t): SQL {\n\t\tconst fieldsList = fieldsFlat ?? orderSelectedFields<SQLiteColumn>(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, SQLiteViewBase)\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.OriginalName] !== table[Table.Symbol.Name]) {\n\t\t\t\treturn sql`${sql.identifier(table[Table.Symbol.OriginalName])} ${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\n\t\t\t\tif (is(table, SQLiteTable)) {\n\t\t\t\t\tconst tableName = table[SQLiteTable.Symbol.Name];\n\t\t\t\t\tconst tableSchema = table[SQLiteTable.Symbol.Schema];\n\t\t\t\t\tconst origTableName = table[SQLiteTable.Symbol.OriginalName];\n\t\t\t\t\tconst alias = tableName === origTableName ? undefined : joinMeta.alias;\n\t\t\t\t\tjoinsArray.push(\n\t\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join ${tableSchema ? sql`${sql.identifier(tableSchema)}.` : undefined}${\n\t\t\t\t\t\t\tsql.identifier(origTableName)\n\t\t\t\t\t\t}${alias && sql` ${sql.identifier(alias)}`} on ${joinMeta.on}`,\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 ${table} on ${joinMeta.on}`,\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 groupByList: (SQL | AnyColumn | SQL.Aliased)[] = [];\n\t\tif (groupBy) {\n\t\t\tfor (const [index, groupByValue] of groupBy.entries()) {\n\t\t\t\tgroupByList.push(groupByValue);\n\n\t\t\t\tif (index < groupBy.length - 1) {\n\t\t\t\t\tgroupByList.push(sql`, `);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tconst groupBySql = groupByList.length > 0 ? sql` group by ${sql.join(groupByList)}` : undefined;\n\n\t\tconst orderBySql = this.buildOrderBy(orderBy);\n\n\t\tconst limitSql = this.buildLimit(limit);\n\n\t\tconst offsetSql = offset ? sql` offset ${offset}` : undefined;\n\n\t\tconst finalQuery =\n\t\t\tsql`${withSql}select${distinctSql} ${selection} from ${tableSql}${joinsSql}${whereSql}${groupBySql}${havingSql}${orderBySql}${limitSql}${offsetSql}`;\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: SQLiteSelectConfig['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: SQLiteSelectConfig['setOperators'][number] }): SQL {\n\t\t// SQLite doesn't support parenthesis in set operations\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 Sql syntax, Table from one of the SELECTs cannot be used in global ORDER clause\n\t\t\tfor (const singleOrderBy of orderBy) {\n\t\t\t\tif (is(singleOrderBy, SQLiteColumn)) {\n\t\t\t\t\torderByValues.push(sql.identifier(singleOrderBy.name));\n\t\t\t\t} else if (is(singleOrderBy, SQL)) {\n\t\t\t\t\tfor (let i = 0; i < singleOrderBy.queryChunks.length; i++) {\n\t\t\t\t\t\tconst chunk = singleOrderBy.queryChunks[i];\n\n\t\t\t\t\t\tif (is(chunk, SQLiteColumn)) {\n\t\t\t\t\t\t\tsingleOrderBy.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`${singleOrderBy}`);\n\t\t\t\t} else {\n\t\t\t\t\torderByValues.push(sql`${singleOrderBy}`);\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({ table, values, onConflict, returning, withList }: SQLiteInsertConfig): SQL {\n\t\t// const isSingleValue = values.length === 1;\n\t\tconst valuesSqlList: ((SQLChunk | SQL)[] | SQL)[] = [];\n\t\tconst columns: Record<string, SQLiteColumn> = table[Table.Symbol.Columns];\n\n\t\tconst colEntries: [string, SQLiteColumn][] = Object.entries(columns).filter(([_, col]) =>\n\t\t\t!col.shouldDisableInsert()\n\t\t);\n\t\tconst insertOrder = colEntries.map(([, column]) => sql.identifier(this.casing.getColumnCasing(column)));\n\n\t\tfor (const [valueIndex, value] of values.entries()) {\n\t\t\tconst valueList: (SQLChunk | SQL)[] = [];\n\t\t\tfor (const [fieldName, col] of colEntries) {\n\t\t\t\tconst colValue = value[fieldName];\n\t\t\t\tif (colValue === undefined || (is(colValue, Param) && colValue.value === undefined)) {\n\t\t\t\t\tlet defaultValue;\n\t\t\t\t\tif (col.default !== null && col.default !== undefined) {\n\t\t\t\t\t\tdefaultValue = is(col.default, SQL) ? col.default : sql.param(col.default, col);\n\t\t\t\t\t\t// eslint-disable-next-line unicorn/no-negated-condition\n\t\t\t\t\t} else if (col.defaultFn !== undefined) {\n\t\t\t\t\t\tconst defaultFnResult = col.defaultFn();\n\t\t\t\t\t\tdefaultValue = is(defaultFnResult, SQL) ? defaultFnResult : sql.param(defaultFnResult, col);\n\t\t\t\t\t\t// eslint-disable-next-line unicorn/no-negated-condition\n\t\t\t\t\t} else if (!col.default && col.onUpdateFn !== undefined) {\n\t\t\t\t\t\tconst onUpdateFnResult = col.onUpdateFn();\n\t\t\t\t\t\tdefaultValue = is(onUpdateFnResult, SQL) ? onUpdateFnResult : sql.param(onUpdateFnResult, col);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tdefaultValue = sql`null`;\n\t\t\t\t\t}\n\t\t\t\t\tvalueList.push(defaultValue);\n\t\t\t\t} else {\n\t\t\t\t\tvalueList.push(colValue);\n\t\t\t\t}\n\t\t\t}\n\t\t\tvaluesSqlList.push(valueList);\n\t\t\tif (valueIndex < values.length - 1) {\n\t\t\t\tvaluesSqlList.push(sql`, `);\n\t\t\t}\n\t\t}\n\n\t\tconst withSql = this.buildWithCTE(withList);\n\n\t\tconst valuesSql = sql.join(valuesSqlList);\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 onConflictSql = onConflict ? sql` on conflict ${onConflict}` : undefined;\n\n\t\t// if (isSingleValue && valuesSqlList.length === 0){\n\t\t// \treturn sql`insert into ${table} default values ${onConflictSql}${returningSql}`;\n\t\t// }\n\n\t\treturn sql`${withSql}insert into ${table} ${insertOrder} values ${valuesSql}${onConflictSql}${returningSql}`;\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\tbuildRelationalQuery({\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: TablesRelationalConfig;\n\t\ttableNamesMap: Record<string, string>;\n\t\ttable: SQLiteTable;\n\t\ttableConfig: TableRelationalConfig;\n\t\tqueryConfig: true | DBQueryConfig<'many', true>;\n\t\ttableAlias: string;\n\t\tnestedQueryRelation?: Relation;\n\t\tjoinOn?: SQL;\n\t}): BuildRelationalQueryResult<SQLiteTable, SQLiteColumn> {\n\t\tlet selection: BuildRelationalQueryResult<SQLiteTable, SQLiteColumn>['selection'] = [];\n\t\tlet limit, offset, orderBy: SQLiteSelectConfig['orderBy'] = [], where;\n\t\tconst joins: SQLiteSelectJoinConfig[] = [];\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 SQLiteColumn, 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, 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: SQLiteColumn | 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 SQLiteColumn;\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 | DBQueryConfig<'many', false>;\n\t\t\t\trelation: Relation;\n\t\t\t}[] = [];\n\n\t\t\t// Figure out which 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, 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 SQLiteColumn;\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 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 = 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\t// const relationTable = schema[relationTableTsName]!;\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 SQLiteTable,\n\t\t\t\t\ttableConfig: schema[relationTableTsName]!,\n\t\t\t\t\tqueryConfig: is(relation, 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`(${builtRelation.sql})`).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, SQLiteColumn)\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, Many)) {\n\t\t\t\tfield = sql`coalesce(json_group_array(${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;\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],\n\t\t\t\t\twhere,\n\t\t\t\t\tlimit,\n\t\t\t\t\toffset,\n\t\t\t\t\torderBy,\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, SQLiteTable) ? 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\nexport class SQLiteSyncDialect extends SQLiteDialect {\n\tstatic override readonly [entityKind]: string = 'SQLiteSyncDialect';\n\n\tmigrate(\n\t\tmigrations: MigrationMeta[],\n\t\tsession: SQLiteSession<'sync', unknown, Record<string, unknown>, TablesRelationalConfig>,\n\t\tconfig?: string | MigrationConfig,\n\t): void {\n\t\tconst migrationsTable = config === undefined\n\t\t\t? '__drizzle_migrations'\n\t\t\t: typeof config === 'string'\n\t\t\t? '__drizzle_migrations'\n\t\t\t: config.migrationsTable ?? '__drizzle_migrations';\n\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 numeric\n\t\t\t)\n\t\t`;\n\t\tsession.run(migrationTableCreate);\n\n\t\tconst dbMigrations = session.values<[number, string, 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\tconst lastDbMigration = dbMigrations[0] ?? undefined;\n\t\tsession.run(sql`BEGIN`);\n\n\t\ttry {\n\t\t\tfor (const migration of migrations) {\n\t\t\t\tif (!lastDbMigration || Number(lastDbMigration[2])! < migration.folderMillis) {\n\t\t\t\t\tfor (const stmt of migration.sql) {\n\t\t\t\t\t\tsession.run(sql.raw(stmt));\n\t\t\t\t\t}\n\t\t\t\t\tsession.run(\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\n\t\t\tsession.run(sql`COMMIT`);\n\t\t} catch (e) {\n\t\t\tsession.run(sql`ROLLBACK`);\n\t\t\tthrow e;\n\t\t}\n\t}\n}\n\nexport class SQLiteAsyncDialect extends SQLiteDialect {\n\tstatic override readonly [entityKind]: string = 'SQLiteAsyncDialect';\n\n\tasync migrate(\n\t\tmigrations: MigrationMeta[],\n\t\tsession: SQLiteSession<'async', any, any, any>,\n\t\tconfig?: string | MigrationConfig,\n\t): Promise<void> {\n\t\tconst migrationsTable = config === undefined\n\t\t\t? '__drizzle_migrations'\n\t\t\t: typeof config === 'string'\n\t\t\t? '__drizzle_migrations'\n\t\t\t: config.migrationsTable ?? '__drizzle_migrations';\n\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 numeric\n\t\t\t)\n\t\t`;\n\t\tawait session.run(migrationTableCreate);\n\n\t\tconst dbMigrations = await session.values<[number, string, 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\tconst lastDbMigration = dbMigrations[0] ?? undefined;\n\n\t\tawait session.transaction(async (tx) => {\n\t\t\tfor (const migration of migrations) {\n\t\t\t\tif (!lastDbMigration || Number(lastDbMigration[2])! < migration.folderMillis) {\n\t\t\t\t\tfor (const stmt of migration.sql) {\n\t\t\t\t\t\tawait tx.run(sql.raw(stmt));\n\t\t\t\t\t}\n\t\t\t\t\tawait tx.run(\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"],"mappings":"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","names":["import_sql","import_table","table","sql","joinOn","field"]}
@@ -5,18 +5,22 @@ import { type QueryWithTypings, SQL } from "../sql/sql.cjs";
5
5
  import { SQLiteColumn } from "./columns/index.cjs";
6
6
  import type { SQLiteDeleteConfig, SQLiteInsertConfig, SQLiteUpdateConfig } from "./query-builders/index.cjs";
7
7
  import { SQLiteTable } from "./table.cjs";
8
- import { type UpdateSet } from "../utils.cjs";
8
+ import { type Casing, type UpdateSet } from "../utils.cjs";
9
9
  import type { SQLiteSelectConfig } from "./query-builders/select.types.cjs";
10
10
  import type { SQLiteSession } from "./session.cjs";
11
+ export interface SQLiteDialectConfig {
12
+ casing?: Casing;
13
+ }
11
14
  export declare abstract class SQLiteDialect {
12
15
  static readonly [entityKind]: string;
16
+ constructor(config?: SQLiteDialectConfig);
13
17
  escapeName(name: string): string;
14
18
  escapeParam(_num: number): string;
15
19
  escapeString(str: string): string;
16
20
  private buildWithCTE;
17
- buildDeleteQuery({ table, where, returning, withList }: SQLiteDeleteConfig): SQL;
21
+ buildDeleteQuery({ table, where, returning, withList, limit, orderBy }: SQLiteDeleteConfig): SQL;
18
22
  buildUpdateSet(table: SQLiteTable, set: UpdateSet): SQL;
19
- buildUpdateQuery({ table, set, where, returning, withList }: SQLiteUpdateConfig): SQL;
23
+ buildUpdateQuery({ table, set, where, returning, withList, limit, orderBy }: SQLiteUpdateConfig): SQL;
20
24
  /**
21
25
  * Builds selection SQL with provided fields/expressions
22
26
  *
@@ -29,6 +33,8 @@ export declare abstract class SQLiteDialect {
29
33
  * If `isSingleTable` is true, then columns won't be prefixed with table name
30
34
  */
31
35
  private buildSelection;
36
+ private buildLimit;
37
+ private buildOrderBy;
32
38
  buildSelectQuery({ withList, fields, fieldsFlat, where, having, table, joins, orderBy, groupBy, limit, offset, distinct, setOperators, }: SQLiteSelectConfig): SQL;
33
39
  buildSetOperations(leftSelect: SQL, setOperators: SQLiteSelectConfig['setOperators']): SQL;
34
40
  buildSetOperationQuery({ leftSelect, setOperator: { type, isAll, rightSelect, limit, orderBy, offset }, }: {
@@ -5,18 +5,22 @@ import { type QueryWithTypings, SQL } from "../sql/sql.js";
5
5
  import { SQLiteColumn } from "./columns/index.js";
6
6
  import type { SQLiteDeleteConfig, SQLiteInsertConfig, SQLiteUpdateConfig } from "./query-builders/index.js";
7
7
  import { SQLiteTable } from "./table.js";
8
- import { type UpdateSet } from "../utils.js";
8
+ import { type Casing, type UpdateSet } from "../utils.js";
9
9
  import type { SQLiteSelectConfig } from "./query-builders/select.types.js";
10
10
  import type { SQLiteSession } from "./session.js";
11
+ export interface SQLiteDialectConfig {
12
+ casing?: Casing;
13
+ }
11
14
  export declare abstract class SQLiteDialect {
12
15
  static readonly [entityKind]: string;
16
+ constructor(config?: SQLiteDialectConfig);
13
17
  escapeName(name: string): string;
14
18
  escapeParam(_num: number): string;
15
19
  escapeString(str: string): string;
16
20
  private buildWithCTE;
17
- buildDeleteQuery({ table, where, returning, withList }: SQLiteDeleteConfig): SQL;
21
+ buildDeleteQuery({ table, where, returning, withList, limit, orderBy }: SQLiteDeleteConfig): SQL;
18
22
  buildUpdateSet(table: SQLiteTable, set: UpdateSet): SQL;
19
- buildUpdateQuery({ table, set, where, returning, withList }: SQLiteUpdateConfig): SQL;
23
+ buildUpdateQuery({ table, set, where, returning, withList, limit, orderBy }: SQLiteUpdateConfig): SQL;
20
24
  /**
21
25
  * Builds selection SQL with provided fields/expressions
22
26
  *
@@ -29,6 +33,8 @@ export declare abstract class SQLiteDialect {
29
33
  * If `isSingleTable` is true, then columns won't be prefixed with table name
30
34
  */
31
35
  private buildSelection;
36
+ private buildLimit;
37
+ private buildOrderBy;
32
38
  buildSelectQuery({ withList, fields, fieldsFlat, where, having, table, joins, orderBy, groupBy, limit, offset, distinct, setOperators, }: SQLiteSelectConfig): SQL;
33
39
  buildSetOperations(leftSelect: SQL, setOperators: SQLiteSelectConfig['setOperators']): SQL;
34
40
  buildSetOperationQuery({ leftSelect, setOperator: { type, isAll, rightSelect, limit, orderBy, offset }, }: {
@@ -1,4 +1,5 @@
1
1
  import { aliasedTable, aliasedTableColumn, mapColumnsInAliasedSQLToAlias, mapColumnsInSQLToAlias } from "../alias.js";
2
+ import { CasingCache } from "../casing.js";
2
3
  import { Column } from "../column.js";
3
4
  import { entityKind, is } from "../entity.js";
4
5
  import { DrizzleError } from "../errors.js";
@@ -20,6 +21,11 @@ import { ViewBaseConfig } from "../view-common.js";
20
21
  import { SQLiteViewBase } from "./view-base.js";
21
22
  class SQLiteDialect {
22
23
  static [entityKind] = "SQLiteDialect";
24
+ /** @internal */
25
+ casing;
26
+ constructor(config) {
27
+ this.casing = new CasingCache(config?.casing);
28
+ }
23
29
  escapeName(name) {
24
30
  return `"${name}"`;
25
31
  }
@@ -42,11 +48,13 @@ class SQLiteDialect {
42
48
  withSqlChunks.push(sql` `);
43
49
  return sql.join(withSqlChunks);
44
50
  }
45
- buildDeleteQuery({ table, where, returning, withList }) {
51
+ buildDeleteQuery({ table, where, returning, withList, limit, orderBy }) {
46
52
  const withSql = this.buildWithCTE(withList);
47
53
  const returningSql = returning ? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}` : void 0;
48
54
  const whereSql = where ? sql` where ${where}` : void 0;
49
- return sql`${withSql}delete from ${table}${whereSql}${returningSql}`;
55
+ const orderBySql = this.buildOrderBy(orderBy);
56
+ const limitSql = this.buildLimit(limit);
57
+ return sql`${withSql}delete from ${table}${whereSql}${returningSql}${orderBySql}${limitSql}`;
50
58
  }
51
59
  buildUpdateSet(table, set) {
52
60
  const tableColumns = table[Table.Symbol.Columns];
@@ -57,19 +65,21 @@ class SQLiteDialect {
57
65
  return sql.join(columnNames.flatMap((colName, i) => {
58
66
  const col = tableColumns[colName];
59
67
  const value = set[colName] ?? sql.param(col.onUpdateFn(), col);
60
- const res = sql`${sql.identifier(col.name)} = ${value}`;
68
+ const res = sql`${sql.identifier(this.casing.getColumnCasing(col))} = ${value}`;
61
69
  if (i < setSize - 1) {
62
70
  return [res, sql.raw(", ")];
63
71
  }
64
72
  return [res];
65
73
  }));
66
74
  }
67
- buildUpdateQuery({ table, set, where, returning, withList }) {
75
+ buildUpdateQuery({ table, set, where, returning, withList, limit, orderBy }) {
68
76
  const withSql = this.buildWithCTE(withList);
69
77
  const setSql = this.buildUpdateSet(table, set);
70
78
  const returningSql = returning ? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}` : void 0;
71
79
  const whereSql = where ? sql` where ${where}` : void 0;
72
- return sql`${withSql}update ${table} set ${setSql}${whereSql}${returningSql}`;
80
+ const orderBySql = this.buildOrderBy(orderBy);
81
+ const limitSql = this.buildLimit(limit);
82
+ return sql`${withSql}update ${table} set ${setSql}${whereSql}${returningSql}${orderBySql}${limitSql}`;
73
83
  }
74
84
  /**
75
85
  * Builds selection SQL with provided fields/expressions
@@ -95,7 +105,7 @@ class SQLiteDialect {
95
105
  new SQL(
96
106
  query.queryChunks.map((c) => {
97
107
  if (is(c, Column)) {
98
- return sql.identifier(c.name);
108
+ return sql.identifier(this.casing.getColumnCasing(c));
99
109
  }
100
110
  return c;
101
111
  })
@@ -109,11 +119,10 @@ class SQLiteDialect {
109
119
  }
110
120
  } else if (is(field, Column)) {
111
121
  const tableName = field.table[Table.Symbol.Name];
112
- const columnName = field.name;
113
122
  if (isSingleTable) {
114
- chunk.push(sql.identifier(columnName));
123
+ chunk.push(sql.identifier(this.casing.getColumnCasing(field)));
115
124
  } else {
116
- chunk.push(sql`${sql.identifier(tableName)}.${sql.identifier(columnName)}`);
125
+ chunk.push(sql`${sql.identifier(tableName)}.${sql.identifier(this.casing.getColumnCasing(field))}`);
117
126
  }
118
127
  }
119
128
  if (i < columnsLen - 1) {
@@ -123,6 +132,21 @@ class SQLiteDialect {
123
132
  });
124
133
  return sql.join(chunks);
125
134
  }
135
+ buildLimit(limit) {
136
+ return typeof limit === "object" || typeof limit === "number" && limit >= 0 ? sql` limit ${limit}` : void 0;
137
+ }
138
+ buildOrderBy(orderBy) {
139
+ const orderByList = [];
140
+ if (orderBy) {
141
+ for (const [index, orderByValue] of orderBy.entries()) {
142
+ orderByList.push(orderByValue);
143
+ if (index < orderBy.length - 1) {
144
+ orderByList.push(sql`, `);
145
+ }
146
+ }
147
+ }
148
+ return orderByList.length > 0 ? sql` order by ${sql.join(orderByList)}` : void 0;
149
+ }
126
150
  buildSelectQuery({
127
151
  withList,
128
152
  fields,
@@ -187,15 +211,6 @@ class SQLiteDialect {
187
211
  const joinsSql = sql.join(joinsArray);
188
212
  const whereSql = where ? sql` where ${where}` : void 0;
189
213
  const havingSql = having ? sql` having ${having}` : void 0;
190
- const orderByList = [];
191
- if (orderBy) {
192
- for (const [index, orderByValue] of orderBy.entries()) {
193
- orderByList.push(orderByValue);
194
- if (index < orderBy.length - 1) {
195
- orderByList.push(sql`, `);
196
- }
197
- }
198
- }
199
214
  const groupByList = [];
200
215
  if (groupBy) {
201
216
  for (const [index, groupByValue] of groupBy.entries()) {
@@ -206,8 +221,8 @@ class SQLiteDialect {
206
221
  }
207
222
  }
208
223
  const groupBySql = groupByList.length > 0 ? sql` group by ${sql.join(groupByList)}` : void 0;
209
- const orderBySql = orderByList.length > 0 ? sql` order by ${sql.join(orderByList)}` : void 0;
210
- const limitSql = typeof limit === "object" || typeof limit === "number" && limit >= 0 ? sql` limit ${limit}` : void 0;
224
+ const orderBySql = this.buildOrderBy(orderBy);
225
+ const limitSql = this.buildLimit(limit);
211
226
  const offsetSql = offset ? sql` offset ${offset}` : void 0;
212
227
  const finalQuery = sql`${withSql}select${distinctSql} ${selection} from ${tableSql}${joinsSql}${whereSql}${groupBySql}${havingSql}${orderBySql}${limitSql}${offsetSql}`;
213
228
  if (setOperators.length > 0) {
@@ -244,7 +259,7 @@ class SQLiteDialect {
244
259
  for (let i = 0; i < singleOrderBy.queryChunks.length; i++) {
245
260
  const chunk = singleOrderBy.queryChunks[i];
246
261
  if (is(chunk, SQLiteColumn)) {
247
- singleOrderBy.queryChunks[i] = sql.identifier(chunk.name);
262
+ singleOrderBy.queryChunks[i] = sql.identifier(this.casing.getColumnCasing(chunk));
248
263
  }
249
264
  }
250
265
  orderByValues.push(sql`${singleOrderBy}`);
@@ -265,7 +280,7 @@ class SQLiteDialect {
265
280
  const colEntries = Object.entries(columns).filter(
266
281
  ([_, col]) => !col.shouldDisableInsert()
267
282
  );
268
- const insertOrder = colEntries.map(([, column]) => sql.identifier(column.name));
283
+ const insertOrder = colEntries.map(([, column]) => sql.identifier(this.casing.getColumnCasing(column)));
269
284
  for (const [valueIndex, value] of values.entries()) {
270
285
  const valueList = [];
271
286
  for (const [fieldName, col] of colEntries) {
@@ -301,6 +316,7 @@ class SQLiteDialect {
301
316
  }
302
317
  sqlToQuery(sql2, invokeSource) {
303
318
  return sql2.toQuery({
319
+ casing: this.casing,
304
320
  escapeName: this.escapeName,
305
321
  escapeParam: this.escapeParam,
306
322
  escapeString: this.escapeString,
@@ -449,7 +465,7 @@ class SQLiteDialect {
449
465
  if (nestedQueryRelation) {
450
466
  let field = sql`json_array(${sql.join(
451
467
  selection.map(
452
- ({ field: field2 }) => is(field2, SQLiteColumn) ? sql.identifier(field2.name) : is(field2, SQL.Aliased) ? field2.sql : field2
468
+ ({ field: field2 }) => is(field2, SQLiteColumn) ? sql.identifier(this.casing.getColumnCasing(field2)) : is(field2, SQL.Aliased) ? field2.sql : field2
453
469
  ),
454
470
  sql`, `
455
471
  )})`;