drizzle-orm 1.0.0-beta.20-afec359 → 1.0.0-beta.21

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 (1633) hide show
  1. package/_relations.cjs.map +1 -1
  2. package/_relations.d.cts +13 -2
  3. package/_relations.d.ts +13 -2
  4. package/_relations.js.map +1 -1
  5. package/alias.cjs +1 -1
  6. package/alias.js +1 -1
  7. package/aws-data-api/common/index.cjs +0 -2
  8. package/aws-data-api/common/index.cjs.map +1 -1
  9. package/aws-data-api/common/index.js +0 -2
  10. package/aws-data-api/common/index.js.map +1 -1
  11. package/aws-data-api/pg/driver.cjs +20 -93
  12. package/aws-data-api/pg/driver.cjs.map +1 -1
  13. package/aws-data-api/pg/driver.d.cts +13 -17
  14. package/aws-data-api/pg/driver.d.ts +13 -17
  15. package/aws-data-api/pg/driver.js +20 -93
  16. package/aws-data-api/pg/driver.js.map +1 -1
  17. package/aws-data-api/pg/index.cjs +1 -1
  18. package/aws-data-api/pg/index.d.cts +3 -3
  19. package/aws-data-api/pg/index.d.ts +3 -3
  20. package/aws-data-api/pg/index.js +3 -3
  21. package/aws-data-api/pg/migrator.cjs.map +1 -1
  22. package/aws-data-api/pg/migrator.d.cts +1 -1
  23. package/aws-data-api/pg/migrator.d.ts +1 -1
  24. package/aws-data-api/pg/migrator.js.map +1 -1
  25. package/aws-data-api/pg/session.cjs +113 -44
  26. package/aws-data-api/pg/session.cjs.map +1 -1
  27. package/aws-data-api/pg/session.d.cts +42 -12
  28. package/aws-data-api/pg/session.d.ts +43 -13
  29. package/aws-data-api/pg/session.js +114 -46
  30. package/aws-data-api/pg/session.js.map +1 -1
  31. package/better-sqlite3/driver.cjs +2 -5
  32. package/better-sqlite3/driver.cjs.map +1 -1
  33. package/better-sqlite3/driver.d.ts +1 -1
  34. package/better-sqlite3/driver.js +2 -5
  35. package/better-sqlite3/driver.js.map +1 -1
  36. package/better-sqlite3/session.cjs +15 -16
  37. package/better-sqlite3/session.cjs.map +1 -1
  38. package/better-sqlite3/session.d.cts +6 -10
  39. package/better-sqlite3/session.d.ts +7 -11
  40. package/better-sqlite3/session.js +16 -17
  41. package/better-sqlite3/session.js.map +1 -1
  42. package/bun-sql/driver.cjs.map +1 -1
  43. package/bun-sql/driver.d.cts +6 -7
  44. package/bun-sql/driver.d.ts +6 -7
  45. package/bun-sql/driver.js.map +1 -1
  46. package/bun-sql/index.cjs +1 -0
  47. package/bun-sql/index.d.cts +2 -2
  48. package/bun-sql/index.d.ts +2 -2
  49. package/bun-sql/index.js +2 -2
  50. package/bun-sql/migrator.cjs.map +1 -1
  51. package/bun-sql/migrator.d.cts +2 -2
  52. package/bun-sql/migrator.d.ts +2 -2
  53. package/bun-sql/migrator.js.map +1 -1
  54. package/bun-sql/mysql/driver.cjs +3 -4
  55. package/bun-sql/mysql/driver.cjs.map +1 -1
  56. package/bun-sql/mysql/driver.js +2 -3
  57. package/bun-sql/mysql/driver.js.map +1 -1
  58. package/bun-sql/mysql/session.cjs +24 -37
  59. package/bun-sql/mysql/session.cjs.map +1 -1
  60. package/bun-sql/mysql/session.d.cts +4 -10
  61. package/bun-sql/mysql/session.d.ts +6 -12
  62. package/bun-sql/mysql/session.js +25 -38
  63. package/bun-sql/mysql/session.js.map +1 -1
  64. package/bun-sql/postgres/driver.cjs +20 -144
  65. package/bun-sql/postgres/driver.cjs.map +1 -1
  66. package/bun-sql/postgres/driver.d.cts +6 -10
  67. package/bun-sql/postgres/driver.d.ts +7 -11
  68. package/bun-sql/postgres/driver.js +20 -144
  69. package/bun-sql/postgres/driver.js.map +1 -1
  70. package/bun-sql/postgres/index.cjs +1 -1
  71. package/bun-sql/postgres/index.d.cts +3 -3
  72. package/bun-sql/postgres/index.d.ts +3 -3
  73. package/bun-sql/postgres/index.js +3 -3
  74. package/bun-sql/postgres/migrator.cjs.map +1 -1
  75. package/bun-sql/postgres/migrator.d.cts +1 -1
  76. package/bun-sql/postgres/migrator.d.ts +1 -1
  77. package/bun-sql/postgres/migrator.js.map +1 -1
  78. package/bun-sql/postgres/session.cjs +112 -17
  79. package/bun-sql/postgres/session.cjs.map +1 -1
  80. package/bun-sql/postgres/session.d.cts +33 -11
  81. package/bun-sql/postgres/session.d.ts +34 -12
  82. package/bun-sql/postgres/session.js +112 -18
  83. package/bun-sql/postgres/session.js.map +1 -1
  84. package/bun-sql/session.cjs +1 -0
  85. package/bun-sql/session.d.cts +2 -2
  86. package/bun-sql/session.d.ts +2 -2
  87. package/bun-sql/session.js +2 -2
  88. package/bun-sql/sqlite/driver.cjs +3 -4
  89. package/bun-sql/sqlite/driver.cjs.map +1 -1
  90. package/bun-sql/sqlite/driver.d.ts +1 -1
  91. package/bun-sql/sqlite/driver.js +2 -3
  92. package/bun-sql/sqlite/driver.js.map +1 -1
  93. package/bun-sql/sqlite/session.cjs +17 -18
  94. package/bun-sql/sqlite/session.cjs.map +1 -1
  95. package/bun-sql/sqlite/session.d.cts +6 -9
  96. package/bun-sql/sqlite/session.d.ts +7 -10
  97. package/bun-sql/sqlite/session.js +18 -19
  98. package/bun-sql/sqlite/session.js.map +1 -1
  99. package/bun-sqlite/driver.cjs +2 -5
  100. package/bun-sqlite/driver.cjs.map +1 -1
  101. package/bun-sqlite/driver.d.ts +1 -1
  102. package/bun-sqlite/driver.js +2 -5
  103. package/bun-sqlite/driver.js.map +1 -1
  104. package/bun-sqlite/session.cjs +14 -15
  105. package/bun-sqlite/session.cjs.map +1 -1
  106. package/bun-sqlite/session.d.cts +6 -10
  107. package/bun-sqlite/session.d.ts +6 -10
  108. package/bun-sqlite/session.js +15 -16
  109. package/bun-sqlite/session.js.map +1 -1
  110. package/cache/core/cache-effect.cjs +2 -2
  111. package/cache/core/cache-effect.d.ts +1 -1
  112. package/cache/core/cache-effect.js +1 -1
  113. package/cockroach/driver.cjs +4 -10
  114. package/cockroach/driver.cjs.map +1 -1
  115. package/cockroach/driver.d.cts +0 -1
  116. package/cockroach/driver.d.ts +2 -3
  117. package/cockroach/driver.js +4 -10
  118. package/cockroach/driver.js.map +1 -1
  119. package/cockroach/session.cjs +9 -7
  120. package/cockroach/session.cjs.map +1 -1
  121. package/cockroach/session.d.cts +3 -5
  122. package/cockroach/session.d.ts +5 -7
  123. package/cockroach/session.js +10 -8
  124. package/cockroach/session.js.map +1 -1
  125. package/cockroach-core/columns/bigint.cjs +4 -4
  126. package/cockroach-core/columns/bigint.cjs.map +1 -1
  127. package/cockroach-core/columns/bigint.d.cts +2 -2
  128. package/cockroach-core/columns/bigint.d.ts +2 -2
  129. package/cockroach-core/columns/bigint.js +4 -4
  130. package/cockroach-core/columns/bigint.js.map +1 -1
  131. package/cockroach-core/columns/common.cjs +5 -5
  132. package/cockroach-core/columns/common.cjs.map +1 -1
  133. package/cockroach-core/columns/common.d.cts +2 -2
  134. package/cockroach-core/columns/common.d.ts +3 -3
  135. package/cockroach-core/columns/common.js +5 -5
  136. package/cockroach-core/columns/common.js.map +1 -1
  137. package/cockroach-core/columns/custom.cjs +4 -4
  138. package/cockroach-core/columns/custom.cjs.map +1 -1
  139. package/cockroach-core/columns/custom.d.cts +2 -2
  140. package/cockroach-core/columns/custom.d.ts +2 -2
  141. package/cockroach-core/columns/custom.js +4 -4
  142. package/cockroach-core/columns/custom.js.map +1 -1
  143. package/cockroach-core/columns/date.cjs +6 -6
  144. package/cockroach-core/columns/date.cjs.map +1 -1
  145. package/cockroach-core/columns/date.d.cts +3 -3
  146. package/cockroach-core/columns/date.d.ts +3 -3
  147. package/cockroach-core/columns/date.js +6 -6
  148. package/cockroach-core/columns/date.js.map +1 -1
  149. package/cockroach-core/columns/decimal.cjs +4 -4
  150. package/cockroach-core/columns/decimal.cjs.map +1 -1
  151. package/cockroach-core/columns/decimal.d.cts +2 -2
  152. package/cockroach-core/columns/decimal.d.ts +2 -2
  153. package/cockroach-core/columns/decimal.js +4 -4
  154. package/cockroach-core/columns/decimal.js.map +1 -1
  155. package/cockroach-core/columns/float.cjs +2 -2
  156. package/cockroach-core/columns/float.cjs.map +1 -1
  157. package/cockroach-core/columns/float.d.cts +1 -1
  158. package/cockroach-core/columns/float.d.ts +1 -1
  159. package/cockroach-core/columns/float.js +2 -2
  160. package/cockroach-core/columns/float.js.map +1 -1
  161. package/cockroach-core/columns/geometry.cjs +8 -8
  162. package/cockroach-core/columns/geometry.cjs.map +1 -1
  163. package/cockroach-core/columns/geometry.d.cts +5 -5
  164. package/cockroach-core/columns/geometry.d.ts +5 -5
  165. package/cockroach-core/columns/geometry.js +8 -8
  166. package/cockroach-core/columns/geometry.js.map +1 -1
  167. package/cockroach-core/columns/integer.cjs +2 -2
  168. package/cockroach-core/columns/integer.cjs.map +1 -1
  169. package/cockroach-core/columns/integer.d.cts +1 -1
  170. package/cockroach-core/columns/integer.d.ts +1 -1
  171. package/cockroach-core/columns/integer.js +2 -2
  172. package/cockroach-core/columns/integer.js.map +1 -1
  173. package/cockroach-core/columns/jsonb.cjs +4 -4
  174. package/cockroach-core/columns/jsonb.cjs.map +1 -1
  175. package/cockroach-core/columns/jsonb.d.cts +2 -2
  176. package/cockroach-core/columns/jsonb.d.ts +2 -2
  177. package/cockroach-core/columns/jsonb.js +4 -4
  178. package/cockroach-core/columns/jsonb.js.map +1 -1
  179. package/cockroach-core/columns/vector.cjs +4 -4
  180. package/cockroach-core/columns/vector.cjs.map +1 -1
  181. package/cockroach-core/columns/vector.d.cts +2 -2
  182. package/cockroach-core/columns/vector.d.ts +2 -2
  183. package/cockroach-core/columns/vector.js +4 -4
  184. package/cockroach-core/columns/vector.js.map +1 -1
  185. package/cockroach-core/db.cjs +1 -1
  186. package/cockroach-core/db.cjs.map +1 -1
  187. package/cockroach-core/db.d.ts +2 -2
  188. package/cockroach-core/db.js +1 -1
  189. package/cockroach-core/db.js.map +1 -1
  190. package/cockroach-core/dialect.cjs +2 -2
  191. package/cockroach-core/dialect.d.ts +2 -2
  192. package/cockroach-core/dialect.js +2 -2
  193. package/cockroach-core/index.cjs +14 -14
  194. package/cockroach-core/index.js +14 -14
  195. package/cockroach-core/query-builders/delete.cjs +1 -1
  196. package/cockroach-core/query-builders/delete.cjs.map +1 -1
  197. package/cockroach-core/query-builders/delete.d.cts +1 -1
  198. package/cockroach-core/query-builders/delete.d.ts +2 -2
  199. package/cockroach-core/query-builders/delete.js +1 -1
  200. package/cockroach-core/query-builders/delete.js.map +1 -1
  201. package/cockroach-core/query-builders/index.cjs +2 -2
  202. package/cockroach-core/query-builders/index.js +2 -2
  203. package/cockroach-core/query-builders/insert.cjs +1 -1
  204. package/cockroach-core/query-builders/insert.cjs.map +1 -1
  205. package/cockroach-core/query-builders/insert.d.ts +1 -1
  206. package/cockroach-core/query-builders/insert.js +1 -1
  207. package/cockroach-core/query-builders/insert.js.map +1 -1
  208. package/cockroach-core/query-builders/query.cjs +1 -1
  209. package/cockroach-core/query-builders/query.cjs.map +1 -1
  210. package/cockroach-core/query-builders/query.js +1 -1
  211. package/cockroach-core/query-builders/query.js.map +1 -1
  212. package/cockroach-core/query-builders/raw.cjs +4 -0
  213. package/cockroach-core/query-builders/raw.cjs.map +1 -1
  214. package/cockroach-core/query-builders/raw.js +4 -0
  215. package/cockroach-core/query-builders/raw.js.map +1 -1
  216. package/cockroach-core/query-builders/refresh-materialized-view.cjs +1 -1
  217. package/cockroach-core/query-builders/refresh-materialized-view.cjs.map +1 -1
  218. package/cockroach-core/query-builders/refresh-materialized-view.js +1 -1
  219. package/cockroach-core/query-builders/refresh-materialized-view.js.map +1 -1
  220. package/cockroach-core/query-builders/select.cjs +2 -2
  221. package/cockroach-core/query-builders/select.cjs.map +1 -1
  222. package/cockroach-core/query-builders/select.d.ts +3 -3
  223. package/cockroach-core/query-builders/select.js +2 -2
  224. package/cockroach-core/query-builders/select.js.map +1 -1
  225. package/cockroach-core/query-builders/select.types.d.ts +1 -1
  226. package/cockroach-core/query-builders/update.cjs +2 -2
  227. package/cockroach-core/query-builders/update.cjs.map +1 -1
  228. package/cockroach-core/query-builders/update.d.ts +1 -1
  229. package/cockroach-core/query-builders/update.js +2 -2
  230. package/cockroach-core/query-builders/update.js.map +1 -1
  231. package/cockroach-core/schema.cjs +1 -1
  232. package/cockroach-core/schema.js +1 -1
  233. package/cockroach-core/session.cjs +2 -2
  234. package/cockroach-core/session.cjs.map +1 -1
  235. package/cockroach-core/session.d.cts +1 -1
  236. package/cockroach-core/session.d.ts +1 -1
  237. package/cockroach-core/session.js +2 -2
  238. package/cockroach-core/session.js.map +1 -1
  239. package/cockroach-core/table.cjs +1 -1
  240. package/cockroach-core/table.cjs.map +1 -1
  241. package/cockroach-core/table.js +1 -1
  242. package/cockroach-core/table.js.map +1 -1
  243. package/cockroach-core/utils.cjs +3 -3
  244. package/cockroach-core/utils.js +3 -3
  245. package/cockroach-core/view.cjs +1 -1
  246. package/cockroach-core/view.js +1 -1
  247. package/column.cjs +5 -10
  248. package/column.cjs.map +1 -1
  249. package/column.d.cts +3 -3
  250. package/column.d.ts +3 -3
  251. package/column.js +5 -10
  252. package/column.js.map +1 -1
  253. package/d1/driver.cjs +2 -3
  254. package/d1/driver.cjs.map +1 -1
  255. package/d1/driver.d.ts +1 -1
  256. package/d1/driver.js +2 -3
  257. package/d1/driver.js.map +1 -1
  258. package/d1/session.cjs +15 -17
  259. package/d1/session.cjs.map +1 -1
  260. package/d1/session.d.cts +6 -9
  261. package/d1/session.d.ts +7 -10
  262. package/d1/session.js +16 -18
  263. package/d1/session.js.map +1 -1
  264. package/durable-sqlite/driver.cjs +2 -5
  265. package/durable-sqlite/driver.cjs.map +1 -1
  266. package/durable-sqlite/driver.d.ts +1 -1
  267. package/durable-sqlite/driver.js +2 -5
  268. package/durable-sqlite/driver.js.map +1 -1
  269. package/durable-sqlite/migrator.cjs +1 -1
  270. package/durable-sqlite/migrator.js +1 -1
  271. package/durable-sqlite/session.cjs +14 -15
  272. package/durable-sqlite/session.cjs.map +1 -1
  273. package/durable-sqlite/session.d.cts +6 -10
  274. package/durable-sqlite/session.d.ts +6 -10
  275. package/durable-sqlite/session.js +15 -16
  276. package/durable-sqlite/session.js.map +1 -1
  277. package/effect-core/index.cjs +1 -1
  278. package/effect-core/index.js +1 -1
  279. package/effect-postgres/driver.cjs +14 -100
  280. package/effect-postgres/driver.cjs.map +1 -1
  281. package/effect-postgres/driver.d.cts +8 -12
  282. package/effect-postgres/driver.d.ts +10 -14
  283. package/effect-postgres/driver.js +14 -100
  284. package/effect-postgres/driver.js.map +1 -1
  285. package/effect-postgres/index.cjs +1 -1
  286. package/effect-postgres/index.d.cts +3 -3
  287. package/effect-postgres/index.d.ts +3 -3
  288. package/effect-postgres/index.js +3 -3
  289. package/effect-postgres/migrator.cjs.map +1 -1
  290. package/effect-postgres/migrator.d.cts +1 -1
  291. package/effect-postgres/migrator.d.ts +2 -2
  292. package/effect-postgres/migrator.js.map +1 -1
  293. package/effect-postgres/session.cjs +71 -12
  294. package/effect-postgres/session.cjs.map +1 -1
  295. package/effect-postgres/session.d.cts +31 -14
  296. package/effect-postgres/session.d.ts +34 -17
  297. package/effect-postgres/session.js +71 -13
  298. package/effect-postgres/session.js.map +1 -1
  299. package/effect-schema/column.cjs +1 -1
  300. package/effect-schema/column.d.ts +8 -8
  301. package/effect-schema/column.js +1 -1
  302. package/effect-schema/column.types.d.ts +14 -14
  303. package/effect-schema/schema.types.internal.d.ts +7 -7
  304. package/expo-sqlite/driver.cjs +2 -5
  305. package/expo-sqlite/driver.cjs.map +1 -1
  306. package/expo-sqlite/driver.d.ts +1 -1
  307. package/expo-sqlite/driver.js +2 -5
  308. package/expo-sqlite/driver.js.map +1 -1
  309. package/expo-sqlite/session.cjs +14 -15
  310. package/expo-sqlite/session.cjs.map +1 -1
  311. package/expo-sqlite/session.d.cts +6 -10
  312. package/expo-sqlite/session.d.ts +6 -10
  313. package/expo-sqlite/session.js +15 -16
  314. package/expo-sqlite/session.js.map +1 -1
  315. package/gel/driver.cjs +3 -5
  316. package/gel/driver.cjs.map +1 -1
  317. package/gel/driver.d.cts +0 -1
  318. package/gel/driver.d.ts +4 -5
  319. package/gel/driver.js +3 -5
  320. package/gel/driver.js.map +1 -1
  321. package/gel/session.cjs +13 -13
  322. package/gel/session.cjs.map +1 -1
  323. package/gel/session.d.cts +5 -8
  324. package/gel/session.d.ts +9 -12
  325. package/gel/session.js +14 -14
  326. package/gel/session.js.map +1 -1
  327. package/gel-core/columns/bigintT.cjs +2 -2
  328. package/gel-core/columns/bigintT.cjs.map +1 -1
  329. package/gel-core/columns/bigintT.d.cts +1 -1
  330. package/gel-core/columns/bigintT.d.ts +1 -1
  331. package/gel-core/columns/bigintT.js +2 -2
  332. package/gel-core/columns/bigintT.js.map +1 -1
  333. package/gel-core/columns/common.cjs +3 -3
  334. package/gel-core/columns/common.cjs.map +1 -1
  335. package/gel-core/columns/common.d.cts +1 -1
  336. package/gel-core/columns/common.d.ts +1 -1
  337. package/gel-core/columns/common.js +3 -3
  338. package/gel-core/columns/common.js.map +1 -1
  339. package/gel-core/columns/custom.cjs +4 -4
  340. package/gel-core/columns/custom.cjs.map +1 -1
  341. package/gel-core/columns/custom.d.cts +2 -2
  342. package/gel-core/columns/custom.d.ts +2 -2
  343. package/gel-core/columns/custom.js +4 -4
  344. package/gel-core/columns/custom.js.map +1 -1
  345. package/gel-core/columns/double-precision.cjs +2 -2
  346. package/gel-core/columns/double-precision.cjs.map +1 -1
  347. package/gel-core/columns/double-precision.d.cts +1 -1
  348. package/gel-core/columns/double-precision.d.ts +1 -1
  349. package/gel-core/columns/double-precision.js +2 -2
  350. package/gel-core/columns/double-precision.js.map +1 -1
  351. package/gel-core/columns/timestamp.d.ts +1 -1
  352. package/gel-core/columns/timestamptz.cjs +2 -2
  353. package/gel-core/columns/timestamptz.cjs.map +1 -1
  354. package/gel-core/columns/timestamptz.d.cts +1 -1
  355. package/gel-core/columns/timestamptz.d.ts +1 -1
  356. package/gel-core/columns/timestamptz.js +2 -2
  357. package/gel-core/columns/timestamptz.js.map +1 -1
  358. package/gel-core/db.cjs +1 -1
  359. package/gel-core/db.cjs.map +1 -1
  360. package/gel-core/db.d.ts +3 -3
  361. package/gel-core/db.js +1 -1
  362. package/gel-core/db.js.map +1 -1
  363. package/gel-core/index.cjs +13 -13
  364. package/gel-core/index.js +13 -13
  365. package/gel-core/query-builders/_query.cjs +1 -1
  366. package/gel-core/query-builders/_query.cjs.map +1 -1
  367. package/gel-core/query-builders/_query.js +1 -1
  368. package/gel-core/query-builders/_query.js.map +1 -1
  369. package/gel-core/query-builders/delete.cjs +1 -1
  370. package/gel-core/query-builders/delete.cjs.map +1 -1
  371. package/gel-core/query-builders/delete.d.ts +2 -2
  372. package/gel-core/query-builders/delete.js +1 -1
  373. package/gel-core/query-builders/delete.js.map +1 -1
  374. package/gel-core/query-builders/index.cjs +1 -1
  375. package/gel-core/query-builders/index.js +1 -1
  376. package/gel-core/query-builders/insert.cjs +1 -1
  377. package/gel-core/query-builders/insert.cjs.map +1 -1
  378. package/gel-core/query-builders/insert.d.ts +2 -2
  379. package/gel-core/query-builders/insert.js +1 -1
  380. package/gel-core/query-builders/insert.js.map +1 -1
  381. package/gel-core/query-builders/query.cjs +5 -13
  382. package/gel-core/query-builders/query.cjs.map +1 -1
  383. package/gel-core/query-builders/query.d.ts +1 -1
  384. package/gel-core/query-builders/query.js +5 -13
  385. package/gel-core/query-builders/query.js.map +1 -1
  386. package/gel-core/query-builders/raw.cjs +4 -0
  387. package/gel-core/query-builders/raw.cjs.map +1 -1
  388. package/gel-core/query-builders/raw.js +4 -0
  389. package/gel-core/query-builders/raw.js.map +1 -1
  390. package/gel-core/query-builders/refresh-materialized-view.cjs +1 -1
  391. package/gel-core/query-builders/refresh-materialized-view.cjs.map +1 -1
  392. package/gel-core/query-builders/refresh-materialized-view.d.ts +1 -1
  393. package/gel-core/query-builders/refresh-materialized-view.js +1 -1
  394. package/gel-core/query-builders/refresh-materialized-view.js.map +1 -1
  395. package/gel-core/query-builders/select.cjs +1 -1
  396. package/gel-core/query-builders/select.cjs.map +1 -1
  397. package/gel-core/query-builders/select.d.ts +3 -3
  398. package/gel-core/query-builders/select.js +1 -1
  399. package/gel-core/query-builders/select.js.map +1 -1
  400. package/gel-core/query-builders/select.types.d.ts +1 -1
  401. package/gel-core/query-builders/update.cjs +1 -1
  402. package/gel-core/query-builders/update.cjs.map +1 -1
  403. package/gel-core/query-builders/update.d.ts +2 -2
  404. package/gel-core/query-builders/update.js +1 -1
  405. package/gel-core/query-builders/update.js.map +1 -1
  406. package/gel-core/session.cjs +2 -2
  407. package/gel-core/session.cjs.map +1 -1
  408. package/gel-core/session.d.cts +3 -3
  409. package/gel-core/session.d.ts +3 -3
  410. package/gel-core/session.js +2 -2
  411. package/gel-core/session.js.map +1 -1
  412. package/gel-core/table.cjs +1 -1
  413. package/gel-core/table.cjs.map +1 -1
  414. package/gel-core/table.js +1 -1
  415. package/gel-core/table.js.map +1 -1
  416. package/gel-core/utils.cjs +4 -4
  417. package/gel-core/utils.js +4 -4
  418. package/gel-core/view.cjs +1 -1
  419. package/gel-core/view.js +1 -1
  420. package/index.cjs +6 -12
  421. package/index.d.cts +6 -6
  422. package/index.d.ts +6 -6
  423. package/index.js +9 -9
  424. package/libsql/driver-core.cjs +2 -3
  425. package/libsql/driver-core.cjs.map +1 -1
  426. package/libsql/driver-core.d.ts +1 -1
  427. package/libsql/driver-core.js +2 -3
  428. package/libsql/driver-core.js.map +1 -1
  429. package/libsql/session.cjs +15 -14
  430. package/libsql/session.cjs.map +1 -1
  431. package/libsql/session.d.cts +6 -9
  432. package/libsql/session.d.ts +7 -10
  433. package/libsql/session.js +16 -15
  434. package/libsql/session.js.map +1 -1
  435. package/mssql-core/columns/bigint.cjs +2 -2
  436. package/mssql-core/columns/bigint.cjs.map +1 -1
  437. package/mssql-core/columns/bigint.d.cts +1 -1
  438. package/mssql-core/columns/bigint.d.ts +1 -1
  439. package/mssql-core/columns/bigint.js +2 -2
  440. package/mssql-core/columns/bigint.js.map +1 -1
  441. package/mssql-core/columns/custom.cjs +4 -4
  442. package/mssql-core/columns/custom.cjs.map +1 -1
  443. package/mssql-core/columns/custom.d.cts +2 -2
  444. package/mssql-core/columns/custom.d.ts +2 -2
  445. package/mssql-core/columns/custom.js +4 -4
  446. package/mssql-core/columns/custom.js.map +1 -1
  447. package/mssql-core/columns/date.cjs +4 -4
  448. package/mssql-core/columns/date.cjs.map +1 -1
  449. package/mssql-core/columns/date.d.cts +2 -2
  450. package/mssql-core/columns/date.d.ts +2 -2
  451. package/mssql-core/columns/date.js +4 -4
  452. package/mssql-core/columns/date.js.map +1 -1
  453. package/mssql-core/columns/datetime.cjs +2 -2
  454. package/mssql-core/columns/datetime.cjs.map +1 -1
  455. package/mssql-core/columns/datetime.d.cts +1 -1
  456. package/mssql-core/columns/datetime.d.ts +1 -1
  457. package/mssql-core/columns/datetime.js +2 -2
  458. package/mssql-core/columns/datetime.js.map +1 -1
  459. package/mssql-core/columns/datetime2.cjs +2 -2
  460. package/mssql-core/columns/datetime2.cjs.map +1 -1
  461. package/mssql-core/columns/datetime2.d.cts +1 -1
  462. package/mssql-core/columns/datetime2.d.ts +1 -1
  463. package/mssql-core/columns/datetime2.js +2 -2
  464. package/mssql-core/columns/datetime2.js.map +1 -1
  465. package/mssql-core/columns/datetimeoffset.cjs +2 -2
  466. package/mssql-core/columns/datetimeoffset.cjs.map +1 -1
  467. package/mssql-core/columns/datetimeoffset.d.cts +1 -1
  468. package/mssql-core/columns/datetimeoffset.d.ts +1 -1
  469. package/mssql-core/columns/datetimeoffset.js +2 -2
  470. package/mssql-core/columns/datetimeoffset.js.map +1 -1
  471. package/mssql-core/columns/decimal.cjs +4 -4
  472. package/mssql-core/columns/decimal.cjs.map +1 -1
  473. package/mssql-core/columns/decimal.d.cts +2 -2
  474. package/mssql-core/columns/decimal.d.ts +2 -2
  475. package/mssql-core/columns/decimal.js +4 -4
  476. package/mssql-core/columns/decimal.js.map +1 -1
  477. package/mssql-core/columns/numeric.cjs +4 -4
  478. package/mssql-core/columns/numeric.cjs.map +1 -1
  479. package/mssql-core/columns/numeric.d.cts +2 -2
  480. package/mssql-core/columns/numeric.d.ts +2 -2
  481. package/mssql-core/columns/numeric.js +4 -4
  482. package/mssql-core/columns/numeric.js.map +1 -1
  483. package/mssql-core/columns/smallint.cjs +2 -2
  484. package/mssql-core/columns/smallint.cjs.map +1 -1
  485. package/mssql-core/columns/smallint.d.cts +1 -1
  486. package/mssql-core/columns/smallint.d.ts +1 -1
  487. package/mssql-core/columns/smallint.js +2 -2
  488. package/mssql-core/columns/smallint.js.map +1 -1
  489. package/mssql-core/columns/time.cjs +2 -2
  490. package/mssql-core/columns/time.cjs.map +1 -1
  491. package/mssql-core/columns/time.d.cts +1 -1
  492. package/mssql-core/columns/time.d.ts +1 -1
  493. package/mssql-core/columns/time.js +2 -2
  494. package/mssql-core/columns/time.js.map +1 -1
  495. package/mssql-core/columns/tinyint.cjs +2 -2
  496. package/mssql-core/columns/tinyint.cjs.map +1 -1
  497. package/mssql-core/columns/tinyint.d.cts +1 -1
  498. package/mssql-core/columns/tinyint.d.ts +1 -1
  499. package/mssql-core/columns/tinyint.js +2 -2
  500. package/mssql-core/columns/tinyint.js.map +1 -1
  501. package/mssql-core/columns/varchar.cjs +4 -4
  502. package/mssql-core/columns/varchar.cjs.map +1 -1
  503. package/mssql-core/columns/varchar.d.cts +2 -2
  504. package/mssql-core/columns/varchar.d.ts +2 -2
  505. package/mssql-core/columns/varchar.js +4 -4
  506. package/mssql-core/columns/varchar.js.map +1 -1
  507. package/mssql-core/dialect.cjs +2 -2
  508. package/mssql-core/dialect.d.ts +1 -1
  509. package/mssql-core/dialect.js +2 -2
  510. package/mssql-core/index.cjs +13 -13
  511. package/mssql-core/index.js +13 -13
  512. package/mssql-core/query-builders/delete.d.ts +1 -1
  513. package/mssql-core/query-builders/insert.d.ts +1 -1
  514. package/mssql-core/query-builders/select.d.ts +1 -1
  515. package/mssql-core/query-builders/update.d.ts +2 -2
  516. package/mssql-core/table.cjs +1 -1
  517. package/mssql-core/table.cjs.map +1 -1
  518. package/mssql-core/table.js +1 -1
  519. package/mssql-core/table.js.map +1 -1
  520. package/mssql-core/utils.cjs +3 -3
  521. package/mssql-core/utils.js +3 -3
  522. package/mssql-core/view.cjs +2 -2
  523. package/mssql-core/view.js +2 -2
  524. package/mysql-core/columns/bigint.cjs +8 -8
  525. package/mysql-core/columns/bigint.cjs.map +1 -1
  526. package/mysql-core/columns/bigint.d.cts +4 -4
  527. package/mysql-core/columns/bigint.d.ts +4 -4
  528. package/mysql-core/columns/bigint.js +8 -8
  529. package/mysql-core/columns/bigint.js.map +1 -1
  530. package/mysql-core/columns/binary.cjs +2 -2
  531. package/mysql-core/columns/binary.cjs.map +1 -1
  532. package/mysql-core/columns/binary.d.cts +1 -1
  533. package/mysql-core/columns/binary.d.ts +1 -1
  534. package/mysql-core/columns/binary.js +2 -2
  535. package/mysql-core/columns/binary.js.map +1 -1
  536. package/mysql-core/columns/blob.cjs +4 -4
  537. package/mysql-core/columns/blob.cjs.map +1 -1
  538. package/mysql-core/columns/blob.d.cts +2 -2
  539. package/mysql-core/columns/blob.d.ts +2 -2
  540. package/mysql-core/columns/blob.js +4 -4
  541. package/mysql-core/columns/blob.js.map +1 -1
  542. package/mysql-core/columns/boolean.cjs +2 -2
  543. package/mysql-core/columns/boolean.cjs.map +1 -1
  544. package/mysql-core/columns/boolean.d.cts +1 -1
  545. package/mysql-core/columns/boolean.d.ts +1 -1
  546. package/mysql-core/columns/boolean.js +2 -2
  547. package/mysql-core/columns/boolean.js.map +1 -1
  548. package/mysql-core/columns/custom.cjs +4 -4
  549. package/mysql-core/columns/custom.cjs.map +1 -1
  550. package/mysql-core/columns/custom.d.cts +2 -2
  551. package/mysql-core/columns/custom.d.ts +2 -2
  552. package/mysql-core/columns/custom.js +4 -4
  553. package/mysql-core/columns/custom.js.map +1 -1
  554. package/mysql-core/columns/date.cjs +4 -4
  555. package/mysql-core/columns/date.cjs.map +1 -1
  556. package/mysql-core/columns/date.d.cts +2 -2
  557. package/mysql-core/columns/date.d.ts +2 -2
  558. package/mysql-core/columns/date.js +4 -4
  559. package/mysql-core/columns/date.js.map +1 -1
  560. package/mysql-core/columns/datetime.cjs +8 -8
  561. package/mysql-core/columns/datetime.cjs.map +1 -1
  562. package/mysql-core/columns/datetime.d.cts +4 -4
  563. package/mysql-core/columns/datetime.d.ts +4 -4
  564. package/mysql-core/columns/datetime.js +8 -8
  565. package/mysql-core/columns/datetime.js.map +1 -1
  566. package/mysql-core/columns/decimal.cjs +4 -4
  567. package/mysql-core/columns/decimal.cjs.map +1 -1
  568. package/mysql-core/columns/decimal.d.cts +2 -2
  569. package/mysql-core/columns/decimal.d.ts +2 -2
  570. package/mysql-core/columns/decimal.js +4 -4
  571. package/mysql-core/columns/decimal.js.map +1 -1
  572. package/mysql-core/columns/float.cjs +2 -2
  573. package/mysql-core/columns/float.cjs.map +1 -1
  574. package/mysql-core/columns/float.d.cts +1 -1
  575. package/mysql-core/columns/float.d.ts +1 -1
  576. package/mysql-core/columns/float.js +2 -2
  577. package/mysql-core/columns/float.js.map +1 -1
  578. package/mysql-core/columns/int.cjs +2 -2
  579. package/mysql-core/columns/int.cjs.map +1 -1
  580. package/mysql-core/columns/int.d.cts +1 -1
  581. package/mysql-core/columns/int.d.ts +1 -1
  582. package/mysql-core/columns/int.js +2 -2
  583. package/mysql-core/columns/int.js.map +1 -1
  584. package/mysql-core/columns/json.cjs +2 -2
  585. package/mysql-core/columns/json.cjs.map +1 -1
  586. package/mysql-core/columns/json.d.cts +1 -1
  587. package/mysql-core/columns/json.d.ts +1 -1
  588. package/mysql-core/columns/json.js +2 -2
  589. package/mysql-core/columns/json.js.map +1 -1
  590. package/mysql-core/columns/mediumint.cjs +2 -2
  591. package/mysql-core/columns/mediumint.cjs.map +1 -1
  592. package/mysql-core/columns/mediumint.d.cts +1 -1
  593. package/mysql-core/columns/mediumint.d.ts +1 -1
  594. package/mysql-core/columns/mediumint.js +2 -2
  595. package/mysql-core/columns/mediumint.js.map +1 -1
  596. package/mysql-core/columns/serial.cjs +2 -2
  597. package/mysql-core/columns/serial.cjs.map +1 -1
  598. package/mysql-core/columns/serial.d.cts +1 -1
  599. package/mysql-core/columns/serial.d.ts +1 -1
  600. package/mysql-core/columns/serial.js +2 -2
  601. package/mysql-core/columns/serial.js.map +1 -1
  602. package/mysql-core/columns/smallint.cjs +2 -2
  603. package/mysql-core/columns/smallint.cjs.map +1 -1
  604. package/mysql-core/columns/smallint.d.cts +1 -1
  605. package/mysql-core/columns/smallint.d.ts +1 -1
  606. package/mysql-core/columns/smallint.js +2 -2
  607. package/mysql-core/columns/smallint.js.map +1 -1
  608. package/mysql-core/columns/time.cjs +2 -2
  609. package/mysql-core/columns/time.cjs.map +1 -1
  610. package/mysql-core/columns/time.d.cts +1 -1
  611. package/mysql-core/columns/time.d.ts +1 -1
  612. package/mysql-core/columns/time.js +2 -2
  613. package/mysql-core/columns/time.js.map +1 -1
  614. package/mysql-core/columns/timestamp.cjs +8 -8
  615. package/mysql-core/columns/timestamp.cjs.map +1 -1
  616. package/mysql-core/columns/timestamp.d.cts +4 -4
  617. package/mysql-core/columns/timestamp.d.ts +4 -4
  618. package/mysql-core/columns/timestamp.js +8 -8
  619. package/mysql-core/columns/timestamp.js.map +1 -1
  620. package/mysql-core/columns/tinyint.cjs +2 -2
  621. package/mysql-core/columns/tinyint.cjs.map +1 -1
  622. package/mysql-core/columns/tinyint.d.cts +1 -1
  623. package/mysql-core/columns/tinyint.d.ts +1 -1
  624. package/mysql-core/columns/tinyint.js +2 -2
  625. package/mysql-core/columns/tinyint.js.map +1 -1
  626. package/mysql-core/columns/varbinary.cjs +2 -2
  627. package/mysql-core/columns/varbinary.cjs.map +1 -1
  628. package/mysql-core/columns/varbinary.d.cts +1 -1
  629. package/mysql-core/columns/varbinary.d.ts +1 -1
  630. package/mysql-core/columns/varbinary.js +2 -2
  631. package/mysql-core/columns/varbinary.js.map +1 -1
  632. package/mysql-core/columns/year.cjs +2 -2
  633. package/mysql-core/columns/year.cjs.map +1 -1
  634. package/mysql-core/columns/year.d.cts +1 -1
  635. package/mysql-core/columns/year.d.ts +1 -1
  636. package/mysql-core/columns/year.js +2 -2
  637. package/mysql-core/columns/year.js.map +1 -1
  638. package/mysql-core/db.d.ts +2 -2
  639. package/mysql-core/dialect.cjs +2 -2
  640. package/mysql-core/dialect.d.ts +1 -1
  641. package/mysql-core/dialect.js +2 -2
  642. package/mysql-core/index.cjs +1 -1
  643. package/mysql-core/index.js +1 -1
  644. package/mysql-core/query-builders/query.cjs +5 -13
  645. package/mysql-core/query-builders/query.cjs.map +1 -1
  646. package/mysql-core/query-builders/query.d.ts +1 -1
  647. package/mysql-core/query-builders/query.js +5 -13
  648. package/mysql-core/query-builders/query.js.map +1 -1
  649. package/mysql-core/session.cjs +2 -1
  650. package/mysql-core/session.cjs.map +1 -1
  651. package/mysql-core/session.d.cts +4 -3
  652. package/mysql-core/session.d.ts +4 -3
  653. package/mysql-core/session.js +2 -1
  654. package/mysql-core/session.js.map +1 -1
  655. package/mysql-core/table.cjs +1 -1
  656. package/mysql-core/table.cjs.map +1 -1
  657. package/mysql-core/table.js +1 -1
  658. package/mysql-core/table.js.map +1 -1
  659. package/mysql-proxy/driver.cjs +2 -5
  660. package/mysql-proxy/driver.cjs.map +1 -1
  661. package/mysql-proxy/driver.js +2 -5
  662. package/mysql-proxy/driver.js.map +1 -1
  663. package/mysql-proxy/session.cjs +19 -26
  664. package/mysql-proxy/session.cjs.map +1 -1
  665. package/mysql-proxy/session.d.cts +4 -11
  666. package/mysql-proxy/session.d.ts +6 -13
  667. package/mysql-proxy/session.js +20 -27
  668. package/mysql-proxy/session.js.map +1 -1
  669. package/mysql2/driver.cjs +2 -3
  670. package/mysql2/driver.cjs.map +1 -1
  671. package/mysql2/driver.d.cts +0 -1
  672. package/mysql2/driver.d.ts +3 -4
  673. package/mysql2/driver.js +2 -3
  674. package/mysql2/driver.js.map +1 -1
  675. package/mysql2/session.cjs +39 -49
  676. package/mysql2/session.cjs.map +1 -1
  677. package/mysql2/session.d.cts +4 -11
  678. package/mysql2/session.d.ts +6 -13
  679. package/mysql2/session.js +40 -50
  680. package/mysql2/session.js.map +1 -1
  681. package/neon-http/driver.cjs +65 -34
  682. package/neon-http/driver.cjs.map +1 -1
  683. package/neon-http/driver.d.cts +19 -15
  684. package/neon-http/driver.d.ts +20 -16
  685. package/neon-http/driver.js +64 -34
  686. package/neon-http/driver.js.map +1 -1
  687. package/neon-http/index.cjs +4 -2
  688. package/neon-http/index.d.cts +3 -3
  689. package/neon-http/index.d.ts +3 -3
  690. package/neon-http/index.js +3 -3
  691. package/neon-http/migrator.cjs +1 -1
  692. package/neon-http/migrator.cjs.map +1 -1
  693. package/neon-http/migrator.d.cts +1 -1
  694. package/neon-http/migrator.d.ts +1 -1
  695. package/neon-http/migrator.js +1 -1
  696. package/neon-http/migrator.js.map +1 -1
  697. package/neon-http/session.cjs +117 -28
  698. package/neon-http/session.cjs.map +1 -1
  699. package/neon-http/session.d.cts +38 -10
  700. package/neon-http/session.d.ts +40 -12
  701. package/neon-http/session.js +117 -30
  702. package/neon-http/session.js.map +1 -1
  703. package/neon-serverless/driver.cjs +32 -14
  704. package/neon-serverless/driver.cjs.map +1 -1
  705. package/neon-serverless/driver.d.cts +17 -12
  706. package/neon-serverless/driver.d.ts +18 -13
  707. package/neon-serverless/driver.js +31 -14
  708. package/neon-serverless/driver.js.map +1 -1
  709. package/neon-serverless/index.cjs +3 -2
  710. package/neon-serverless/index.d.cts +3 -3
  711. package/neon-serverless/index.d.ts +3 -3
  712. package/neon-serverless/index.js +3 -3
  713. package/neon-serverless/migrator.cjs.map +1 -1
  714. package/neon-serverless/migrator.d.cts +1 -1
  715. package/neon-serverless/migrator.d.ts +1 -1
  716. package/neon-serverless/migrator.js.map +1 -1
  717. package/neon-serverless/session.cjs +108 -32
  718. package/neon-serverless/session.cjs.map +1 -1
  719. package/neon-serverless/session.d.cts +32 -9
  720. package/neon-serverless/session.d.ts +33 -10
  721. package/neon-serverless/session.js +109 -34
  722. package/neon-serverless/session.js.map +1 -1
  723. package/netlify-db/driver.cjs +123 -0
  724. package/netlify-db/driver.cjs.map +1 -0
  725. package/netlify-db/driver.d.cts +90 -0
  726. package/netlify-db/driver.d.ts +90 -0
  727. package/netlify-db/driver.js +113 -0
  728. package/netlify-db/driver.js.map +1 -0
  729. package/netlify-db/index.cjs +15 -0
  730. package/netlify-db/index.d.cts +3 -0
  731. package/netlify-db/index.d.ts +3 -0
  732. package/netlify-db/index.js +4 -0
  733. package/netlify-db/migrator.cjs +17 -0
  734. package/netlify-db/migrator.cjs.map +1 -0
  735. package/netlify-db/migrator.d.cts +11 -0
  736. package/netlify-db/migrator.d.ts +11 -0
  737. package/netlify-db/migrator.js +15 -0
  738. package/netlify-db/migrator.js.map +1 -0
  739. package/netlify-db/session.cjs +153 -0
  740. package/netlify-db/session.cjs.map +1 -0
  741. package/netlify-db/session.d.cts +68 -0
  742. package/netlify-db/session.d.ts +68 -0
  743. package/netlify-db/session.js +149 -0
  744. package/netlify-db/session.js.map +1 -0
  745. package/node-mssql/driver.cjs +3 -9
  746. package/node-mssql/driver.cjs.map +1 -1
  747. package/node-mssql/driver.d.cts +0 -1
  748. package/node-mssql/driver.d.ts +2 -3
  749. package/node-mssql/driver.js +3 -9
  750. package/node-mssql/driver.js.map +1 -1
  751. package/node-mssql/session.cjs +4 -6
  752. package/node-mssql/session.cjs.map +1 -1
  753. package/node-mssql/session.d.cts +1 -4
  754. package/node-mssql/session.d.ts +3 -6
  755. package/node-mssql/session.js +5 -7
  756. package/node-mssql/session.js.map +1 -1
  757. package/node-postgres/driver.cjs +18 -15
  758. package/node-postgres/driver.cjs.map +1 -1
  759. package/node-postgres/driver.d.cts +6 -11
  760. package/node-postgres/driver.d.ts +7 -12
  761. package/node-postgres/driver.js +18 -15
  762. package/node-postgres/driver.js.map +1 -1
  763. package/node-postgres/index.cjs +2 -2
  764. package/node-postgres/index.d.cts +3 -3
  765. package/node-postgres/index.d.ts +3 -3
  766. package/node-postgres/index.js +3 -3
  767. package/node-postgres/migrator.cjs.map +1 -1
  768. package/node-postgres/migrator.d.cts +1 -1
  769. package/node-postgres/migrator.d.ts +1 -1
  770. package/node-postgres/migrator.js.map +1 -1
  771. package/node-postgres/session.cjs +126 -33
  772. package/node-postgres/session.cjs.map +1 -1
  773. package/node-postgres/session.d.cts +30 -10
  774. package/node-postgres/session.d.ts +31 -11
  775. package/node-postgres/session.js +127 -35
  776. package/node-postgres/session.js.map +1 -1
  777. package/node-sqlite/driver.cjs +1 -1
  778. package/node-sqlite/driver.d.ts +1 -1
  779. package/node-sqlite/driver.js +1 -1
  780. package/node-sqlite/session.cjs +9 -4
  781. package/node-sqlite/session.cjs.map +1 -1
  782. package/node-sqlite/session.d.cts +4 -3
  783. package/node-sqlite/session.d.ts +5 -4
  784. package/node-sqlite/session.js +9 -4
  785. package/node-sqlite/session.js.map +1 -1
  786. package/op-sqlite/driver.cjs +2 -3
  787. package/op-sqlite/driver.cjs.map +1 -1
  788. package/op-sqlite/driver.d.ts +1 -1
  789. package/op-sqlite/driver.js +2 -3
  790. package/op-sqlite/driver.js.map +1 -1
  791. package/op-sqlite/session.cjs +16 -18
  792. package/op-sqlite/session.cjs.map +1 -1
  793. package/op-sqlite/session.d.cts +6 -10
  794. package/op-sqlite/session.d.ts +7 -11
  795. package/op-sqlite/session.js +17 -19
  796. package/op-sqlite/session.js.map +1 -1
  797. package/operations.d.cts +0 -3
  798. package/operations.d.ts +0 -3
  799. package/package.cjs +1 -1
  800. package/package.js +1 -1
  801. package/package.json +4736 -4700
  802. package/pg-core/async/count.cjs +9 -2
  803. package/pg-core/async/count.cjs.map +1 -1
  804. package/pg-core/async/count.js +9 -2
  805. package/pg-core/async/count.js.map +1 -1
  806. package/pg-core/async/db.cjs +27 -10
  807. package/pg-core/async/db.cjs.map +1 -1
  808. package/pg-core/async/db.d.cts +13 -5
  809. package/pg-core/async/db.d.ts +16 -8
  810. package/pg-core/async/db.js +27 -10
  811. package/pg-core/async/db.js.map +1 -1
  812. package/pg-core/async/delete.cjs +13 -8
  813. package/pg-core/async/delete.cjs.map +1 -1
  814. package/pg-core/async/delete.js +13 -8
  815. package/pg-core/async/delete.js.map +1 -1
  816. package/pg-core/async/insert.cjs +12 -7
  817. package/pg-core/async/insert.cjs.map +1 -1
  818. package/pg-core/async/insert.js +12 -7
  819. package/pg-core/async/insert.js.map +1 -1
  820. package/pg-core/async/query.cjs +14 -8
  821. package/pg-core/async/query.cjs.map +1 -1
  822. package/pg-core/async/query.js +14 -8
  823. package/pg-core/async/query.js.map +1 -1
  824. package/pg-core/async/refresh-materialized-view.cjs +9 -1
  825. package/pg-core/async/refresh-materialized-view.cjs.map +1 -1
  826. package/pg-core/async/refresh-materialized-view.js +9 -1
  827. package/pg-core/async/refresh-materialized-view.js.map +1 -1
  828. package/pg-core/async/select.cjs +13 -4
  829. package/pg-core/async/select.cjs.map +1 -1
  830. package/pg-core/async/select.js +13 -4
  831. package/pg-core/async/select.js.map +1 -1
  832. package/pg-core/async/session.cjs +22 -46
  833. package/pg-core/async/session.cjs.map +1 -1
  834. package/pg-core/async/session.d.cts +31 -25
  835. package/pg-core/async/session.d.ts +32 -26
  836. package/pg-core/async/session.js +23 -47
  837. package/pg-core/async/session.js.map +1 -1
  838. package/pg-core/async/update.cjs +15 -11
  839. package/pg-core/async/update.cjs.map +1 -1
  840. package/pg-core/async/update.js +15 -11
  841. package/pg-core/async/update.js.map +1 -1
  842. package/pg-core/columns/bigint.cjs +9 -10
  843. package/pg-core/columns/bigint.cjs.map +1 -1
  844. package/pg-core/columns/bigint.d.cts +3 -2
  845. package/pg-core/columns/bigint.d.ts +3 -2
  846. package/pg-core/columns/bigint.js +9 -10
  847. package/pg-core/columns/bigint.js.map +1 -1
  848. package/pg-core/columns/bigserial.cjs +6 -6
  849. package/pg-core/columns/bigserial.cjs.map +1 -1
  850. package/pg-core/columns/bigserial.d.cts +2 -1
  851. package/pg-core/columns/bigserial.d.ts +2 -1
  852. package/pg-core/columns/bigserial.js +6 -6
  853. package/pg-core/columns/bigserial.js.map +1 -1
  854. package/pg-core/columns/boolean.cjs +0 -2
  855. package/pg-core/columns/boolean.cjs.map +1 -1
  856. package/pg-core/columns/boolean.js +0 -2
  857. package/pg-core/columns/boolean.js.map +1 -1
  858. package/pg-core/columns/bytea.cjs +8 -2
  859. package/pg-core/columns/bytea.cjs.map +1 -1
  860. package/pg-core/columns/bytea.d.cts +1 -0
  861. package/pg-core/columns/bytea.d.ts +1 -0
  862. package/pg-core/columns/bytea.js +8 -2
  863. package/pg-core/columns/bytea.js.map +1 -1
  864. package/pg-core/columns/char.cjs +0 -2
  865. package/pg-core/columns/char.cjs.map +1 -1
  866. package/pg-core/columns/char.js +0 -2
  867. package/pg-core/columns/char.js.map +1 -1
  868. package/pg-core/columns/cidr.cjs +0 -2
  869. package/pg-core/columns/cidr.cjs.map +1 -1
  870. package/pg-core/columns/cidr.js +0 -2
  871. package/pg-core/columns/cidr.js.map +1 -1
  872. package/pg-core/columns/common.cjs +9 -11
  873. package/pg-core/columns/common.cjs.map +1 -1
  874. package/pg-core/columns/common.d.cts +39 -34
  875. package/pg-core/columns/common.d.ts +39 -34
  876. package/pg-core/columns/common.js +9 -11
  877. package/pg-core/columns/common.js.map +1 -1
  878. package/pg-core/columns/custom.cjs +46 -16
  879. package/pg-core/columns/custom.cjs.map +1 -1
  880. package/pg-core/columns/custom.d.cts +8 -17
  881. package/pg-core/columns/custom.d.ts +8 -17
  882. package/pg-core/columns/custom.js +46 -16
  883. package/pg-core/columns/custom.js.map +1 -1
  884. package/pg-core/columns/date.cjs +12 -11
  885. package/pg-core/columns/date.cjs.map +1 -1
  886. package/pg-core/columns/date.d.cts +4 -3
  887. package/pg-core/columns/date.d.ts +4 -3
  888. package/pg-core/columns/date.js +12 -11
  889. package/pg-core/columns/date.js.map +1 -1
  890. package/pg-core/columns/double-precision.cjs +4 -2
  891. package/pg-core/columns/double-precision.cjs.map +1 -1
  892. package/pg-core/columns/double-precision.d.cts +1 -0
  893. package/pg-core/columns/double-precision.d.ts +1 -0
  894. package/pg-core/columns/double-precision.js +4 -2
  895. package/pg-core/columns/double-precision.js.map +1 -1
  896. package/pg-core/columns/enum.cjs +0 -4
  897. package/pg-core/columns/enum.cjs.map +1 -1
  898. package/pg-core/columns/enum.js +0 -4
  899. package/pg-core/columns/enum.js.map +1 -1
  900. package/pg-core/columns/index.d.cts +2 -2
  901. package/pg-core/columns/index.d.ts +2 -2
  902. package/pg-core/columns/inet.cjs +0 -2
  903. package/pg-core/columns/inet.cjs.map +1 -1
  904. package/pg-core/columns/inet.js +0 -2
  905. package/pg-core/columns/inet.js.map +1 -1
  906. package/pg-core/columns/integer.cjs +4 -2
  907. package/pg-core/columns/integer.cjs.map +1 -1
  908. package/pg-core/columns/integer.d.cts +1 -0
  909. package/pg-core/columns/integer.d.ts +1 -0
  910. package/pg-core/columns/integer.js +4 -2
  911. package/pg-core/columns/integer.js.map +1 -1
  912. package/pg-core/columns/interval.cjs +0 -2
  913. package/pg-core/columns/interval.cjs.map +1 -1
  914. package/pg-core/columns/interval.js +0 -2
  915. package/pg-core/columns/interval.js.map +1 -1
  916. package/pg-core/columns/json.cjs +11 -2
  917. package/pg-core/columns/json.cjs.map +1 -1
  918. package/pg-core/columns/json.d.cts +2 -0
  919. package/pg-core/columns/json.d.ts +2 -0
  920. package/pg-core/columns/json.js +11 -2
  921. package/pg-core/columns/json.js.map +1 -1
  922. package/pg-core/columns/jsonb.cjs +11 -2
  923. package/pg-core/columns/jsonb.cjs.map +1 -1
  924. package/pg-core/columns/jsonb.d.cts +2 -0
  925. package/pg-core/columns/jsonb.d.ts +2 -0
  926. package/pg-core/columns/jsonb.js +11 -2
  927. package/pg-core/columns/jsonb.js.map +1 -1
  928. package/pg-core/columns/line.cjs +8 -12
  929. package/pg-core/columns/line.cjs.map +1 -1
  930. package/pg-core/columns/line.d.cts +5 -5
  931. package/pg-core/columns/line.d.ts +5 -5
  932. package/pg-core/columns/line.js +8 -12
  933. package/pg-core/columns/line.js.map +1 -1
  934. package/pg-core/columns/macaddr.cjs +0 -2
  935. package/pg-core/columns/macaddr.cjs.map +1 -1
  936. package/pg-core/columns/macaddr.js +0 -2
  937. package/pg-core/columns/macaddr.js.map +1 -1
  938. package/pg-core/columns/macaddr8.cjs +0 -2
  939. package/pg-core/columns/macaddr8.cjs.map +1 -1
  940. package/pg-core/columns/macaddr8.js +0 -2
  941. package/pg-core/columns/macaddr8.js.map +1 -1
  942. package/pg-core/columns/numeric.cjs +15 -12
  943. package/pg-core/columns/numeric.cjs.map +1 -1
  944. package/pg-core/columns/numeric.d.cts +5 -4
  945. package/pg-core/columns/numeric.d.ts +5 -4
  946. package/pg-core/columns/numeric.js +15 -12
  947. package/pg-core/columns/numeric.js.map +1 -1
  948. package/pg-core/columns/point.cjs +21 -19
  949. package/pg-core/columns/point.cjs.map +1 -1
  950. package/pg-core/columns/point.d.cts +11 -5
  951. package/pg-core/columns/point.d.ts +11 -5
  952. package/pg-core/columns/point.js +21 -19
  953. package/pg-core/columns/point.js.map +1 -1
  954. package/pg-core/columns/postgis_extension/geometry.cjs +9 -12
  955. package/pg-core/columns/postgis_extension/geometry.cjs.map +1 -1
  956. package/pg-core/columns/postgis_extension/geometry.d.cts +5 -5
  957. package/pg-core/columns/postgis_extension/geometry.d.ts +5 -5
  958. package/pg-core/columns/postgis_extension/geometry.js +9 -12
  959. package/pg-core/columns/postgis_extension/geometry.js.map +1 -1
  960. package/pg-core/columns/real.cjs +4 -2
  961. package/pg-core/columns/real.cjs.map +1 -1
  962. package/pg-core/columns/real.d.cts +1 -0
  963. package/pg-core/columns/real.d.ts +1 -0
  964. package/pg-core/columns/real.js +4 -2
  965. package/pg-core/columns/real.js.map +1 -1
  966. package/pg-core/columns/serial.cjs +0 -2
  967. package/pg-core/columns/serial.cjs.map +1 -1
  968. package/pg-core/columns/serial.js +0 -2
  969. package/pg-core/columns/serial.js.map +1 -1
  970. package/pg-core/columns/smallint.cjs +4 -2
  971. package/pg-core/columns/smallint.cjs.map +1 -1
  972. package/pg-core/columns/smallint.d.cts +1 -0
  973. package/pg-core/columns/smallint.d.ts +1 -0
  974. package/pg-core/columns/smallint.js +4 -2
  975. package/pg-core/columns/smallint.js.map +1 -1
  976. package/pg-core/columns/smallserial.cjs +0 -2
  977. package/pg-core/columns/smallserial.cjs.map +1 -1
  978. package/pg-core/columns/smallserial.js +0 -2
  979. package/pg-core/columns/smallserial.js.map +1 -1
  980. package/pg-core/columns/text.cjs +0 -2
  981. package/pg-core/columns/text.cjs.map +1 -1
  982. package/pg-core/columns/text.js +0 -2
  983. package/pg-core/columns/text.js.map +1 -1
  984. package/pg-core/columns/time.cjs +0 -2
  985. package/pg-core/columns/time.cjs.map +1 -1
  986. package/pg-core/columns/time.js +0 -2
  987. package/pg-core/columns/time.js.map +1 -1
  988. package/pg-core/columns/timestamp.cjs +14 -13
  989. package/pg-core/columns/timestamp.cjs.map +1 -1
  990. package/pg-core/columns/timestamp.d.cts +4 -3
  991. package/pg-core/columns/timestamp.d.ts +4 -3
  992. package/pg-core/columns/timestamp.js +14 -13
  993. package/pg-core/columns/timestamp.js.map +1 -1
  994. package/pg-core/columns/uuid.cjs +0 -2
  995. package/pg-core/columns/uuid.cjs.map +1 -1
  996. package/pg-core/columns/uuid.js +0 -2
  997. package/pg-core/columns/uuid.js.map +1 -1
  998. package/pg-core/columns/varchar.cjs +0 -2
  999. package/pg-core/columns/varchar.cjs.map +1 -1
  1000. package/pg-core/columns/varchar.js +0 -2
  1001. package/pg-core/columns/varchar.js.map +1 -1
  1002. package/pg-core/columns/vector_extension/bit.cjs +0 -2
  1003. package/pg-core/columns/vector_extension/bit.cjs.map +1 -1
  1004. package/pg-core/columns/vector_extension/bit.js +0 -2
  1005. package/pg-core/columns/vector_extension/bit.js.map +1 -1
  1006. package/pg-core/columns/vector_extension/halfvec.cjs +4 -6
  1007. package/pg-core/columns/vector_extension/halfvec.cjs.map +1 -1
  1008. package/pg-core/columns/vector_extension/halfvec.d.cts +2 -2
  1009. package/pg-core/columns/vector_extension/halfvec.d.ts +2 -2
  1010. package/pg-core/columns/vector_extension/halfvec.js +4 -6
  1011. package/pg-core/columns/vector_extension/halfvec.js.map +1 -1
  1012. package/pg-core/columns/vector_extension/sparsevec.cjs +0 -2
  1013. package/pg-core/columns/vector_extension/sparsevec.cjs.map +1 -1
  1014. package/pg-core/columns/vector_extension/sparsevec.js +0 -2
  1015. package/pg-core/columns/vector_extension/sparsevec.js.map +1 -1
  1016. package/pg-core/columns/vector_extension/vector.cjs +4 -6
  1017. package/pg-core/columns/vector_extension/vector.cjs.map +1 -1
  1018. package/pg-core/columns/vector_extension/vector.d.cts +2 -2
  1019. package/pg-core/columns/vector_extension/vector.d.ts +2 -2
  1020. package/pg-core/columns/vector_extension/vector.js +4 -6
  1021. package/pg-core/columns/vector_extension/vector.js.map +1 -1
  1022. package/pg-core/dialect.cjs +217 -52
  1023. package/pg-core/dialect.cjs.map +1 -1
  1024. package/pg-core/dialect.d.cts +30 -19
  1025. package/pg-core/dialect.d.ts +31 -20
  1026. package/pg-core/dialect.js +221 -57
  1027. package/pg-core/dialect.js.map +1 -1
  1028. package/pg-core/effect/count.cjs +1 -1
  1029. package/pg-core/effect/count.cjs.map +1 -1
  1030. package/pg-core/effect/count.d.cts +2 -2
  1031. package/pg-core/effect/count.d.ts +2 -2
  1032. package/pg-core/effect/count.js +1 -1
  1033. package/pg-core/effect/count.js.map +1 -1
  1034. package/pg-core/effect/db.cjs +20 -14
  1035. package/pg-core/effect/db.cjs.map +1 -1
  1036. package/pg-core/effect/db.d.cts +11 -7
  1037. package/pg-core/effect/db.d.ts +13 -9
  1038. package/pg-core/effect/db.js +20 -14
  1039. package/pg-core/effect/db.js.map +1 -1
  1040. package/pg-core/effect/delete.cjs +6 -8
  1041. package/pg-core/effect/delete.cjs.map +1 -1
  1042. package/pg-core/effect/delete.d.cts +1 -1
  1043. package/pg-core/effect/delete.d.ts +1 -1
  1044. package/pg-core/effect/delete.js +6 -8
  1045. package/pg-core/effect/delete.js.map +1 -1
  1046. package/pg-core/effect/index.cjs +3 -3
  1047. package/pg-core/effect/index.js +3 -3
  1048. package/pg-core/effect/insert.cjs +5 -7
  1049. package/pg-core/effect/insert.cjs.map +1 -1
  1050. package/pg-core/effect/insert.d.cts +1 -1
  1051. package/pg-core/effect/insert.d.ts +1 -1
  1052. package/pg-core/effect/insert.js +5 -7
  1053. package/pg-core/effect/insert.js.map +1 -1
  1054. package/pg-core/effect/query.cjs +6 -7
  1055. package/pg-core/effect/query.cjs.map +1 -1
  1056. package/pg-core/effect/query.d.cts +1 -1
  1057. package/pg-core/effect/query.d.ts +1 -1
  1058. package/pg-core/effect/query.js +6 -7
  1059. package/pg-core/effect/query.js.map +1 -1
  1060. package/pg-core/effect/refresh-materialized-view.cjs +2 -1
  1061. package/pg-core/effect/refresh-materialized-view.cjs.map +1 -1
  1062. package/pg-core/effect/refresh-materialized-view.d.cts +1 -1
  1063. package/pg-core/effect/refresh-materialized-view.d.ts +1 -1
  1064. package/pg-core/effect/refresh-materialized-view.js +2 -1
  1065. package/pg-core/effect/refresh-materialized-view.js.map +1 -1
  1066. package/pg-core/effect/select.cjs +5 -3
  1067. package/pg-core/effect/select.cjs.map +1 -1
  1068. package/pg-core/effect/select.d.cts +1 -1
  1069. package/pg-core/effect/select.d.ts +1 -1
  1070. package/pg-core/effect/select.js +5 -3
  1071. package/pg-core/effect/select.js.map +1 -1
  1072. package/pg-core/effect/session.cjs +19 -30
  1073. package/pg-core/effect/session.cjs.map +1 -1
  1074. package/pg-core/effect/session.d.cts +28 -24
  1075. package/pg-core/effect/session.d.ts +29 -25
  1076. package/pg-core/effect/session.js +20 -31
  1077. package/pg-core/effect/session.js.map +1 -1
  1078. package/pg-core/effect/update.cjs +8 -8
  1079. package/pg-core/effect/update.cjs.map +1 -1
  1080. package/pg-core/effect/update.d.cts +1 -1
  1081. package/pg-core/effect/update.d.ts +1 -1
  1082. package/pg-core/effect/update.js +8 -8
  1083. package/pg-core/effect/update.js.map +1 -1
  1084. package/pg-core/index.cjs +16 -16
  1085. package/pg-core/index.d.cts +4 -4
  1086. package/pg-core/index.d.ts +4 -4
  1087. package/pg-core/index.js +13 -13
  1088. package/pg-core/query-builders/_query.cjs +101 -0
  1089. package/pg-core/query-builders/_query.cjs.map +1 -0
  1090. package/pg-core/query-builders/_query.d.cts +55 -0
  1091. package/pg-core/query-builders/_query.d.ts +55 -0
  1092. package/pg-core/query-builders/_query.js +97 -0
  1093. package/pg-core/query-builders/_query.js.map +1 -0
  1094. package/pg-core/query-builders/delete.cjs +1 -1
  1095. package/pg-core/query-builders/delete.cjs.map +1 -1
  1096. package/pg-core/query-builders/delete.js +1 -1
  1097. package/pg-core/query-builders/delete.js.map +1 -1
  1098. package/pg-core/query-builders/index.cjs +1 -1
  1099. package/pg-core/query-builders/index.js +1 -1
  1100. package/pg-core/query-builders/insert.cjs +1 -1
  1101. package/pg-core/query-builders/insert.cjs.map +1 -1
  1102. package/pg-core/query-builders/insert.js +1 -1
  1103. package/pg-core/query-builders/insert.js.map +1 -1
  1104. package/pg-core/query-builders/query.cjs +1 -0
  1105. package/pg-core/query-builders/query.cjs.map +1 -1
  1106. package/pg-core/query-builders/query.d.cts +1 -2
  1107. package/pg-core/query-builders/query.d.ts +1 -2
  1108. package/pg-core/query-builders/query.js +1 -0
  1109. package/pg-core/query-builders/query.js.map +1 -1
  1110. package/pg-core/query-builders/raw.cjs +4 -0
  1111. package/pg-core/query-builders/raw.cjs.map +1 -1
  1112. package/pg-core/query-builders/raw.js +4 -0
  1113. package/pg-core/query-builders/raw.js.map +1 -1
  1114. package/pg-core/query-builders/update.cjs +1 -1
  1115. package/pg-core/query-builders/update.cjs.map +1 -1
  1116. package/pg-core/query-builders/update.js +1 -1
  1117. package/pg-core/query-builders/update.js.map +1 -1
  1118. package/pg-core/schema.cjs +1 -1
  1119. package/pg-core/schema.js +1 -1
  1120. package/pg-core/session.cjs +5 -3
  1121. package/pg-core/session.cjs.map +1 -1
  1122. package/pg-core/session.d.cts +7 -4
  1123. package/pg-core/session.d.ts +7 -4
  1124. package/pg-core/session.js +5 -3
  1125. package/pg-core/session.js.map +1 -1
  1126. package/pg-core/table.cjs +1 -1
  1127. package/pg-core/table.cjs.map +1 -1
  1128. package/pg-core/table.js +1 -1
  1129. package/pg-core/table.js.map +1 -1
  1130. package/pg-core/{array.cjs → utils/array.cjs} +1 -1
  1131. package/pg-core/utils/array.cjs.map +1 -0
  1132. package/pg-core/{array.d.cts → utils/array.d.cts} +1 -1
  1133. package/pg-core/{array.d.ts → utils/array.d.ts} +1 -1
  1134. package/pg-core/{array.js → utils/array.js} +1 -1
  1135. package/pg-core/utils/array.js.map +1 -0
  1136. package/pg-core/utils/index.cjs +6 -0
  1137. package/pg-core/utils/index.d.cts +2 -0
  1138. package/pg-core/utils/index.d.ts +2 -0
  1139. package/pg-core/utils/index.js +3 -0
  1140. package/pg-core/utils.cjs +2 -2
  1141. package/pg-core/utils.cjs.map +1 -1
  1142. package/pg-core/utils.d.cts +1 -7
  1143. package/pg-core/utils.d.ts +1 -7
  1144. package/pg-core/utils.js +2 -2
  1145. package/pg-core/utils.js.map +1 -1
  1146. package/pg-core/view.cjs +1 -1
  1147. package/pg-core/view.js +1 -1
  1148. package/pg-proxy/driver.cjs +15 -10
  1149. package/pg-proxy/driver.cjs.map +1 -1
  1150. package/pg-proxy/driver.d.cts +3 -6
  1151. package/pg-proxy/driver.d.ts +4 -7
  1152. package/pg-proxy/driver.js +14 -10
  1153. package/pg-proxy/driver.js.map +1 -1
  1154. package/pg-proxy/index.cjs +2 -0
  1155. package/pg-proxy/index.d.cts +2 -2
  1156. package/pg-proxy/index.d.ts +2 -2
  1157. package/pg-proxy/index.js +2 -2
  1158. package/pg-proxy/migrator.cjs.map +1 -1
  1159. package/pg-proxy/migrator.d.cts +1 -1
  1160. package/pg-proxy/migrator.d.ts +1 -1
  1161. package/pg-proxy/migrator.js.map +1 -1
  1162. package/pg-proxy/session.cjs +84 -8
  1163. package/pg-proxy/session.cjs.map +1 -1
  1164. package/pg-proxy/session.d.cts +32 -9
  1165. package/pg-proxy/session.d.ts +33 -10
  1166. package/pg-proxy/session.js +84 -10
  1167. package/pg-proxy/session.js.map +1 -1
  1168. package/pglite/driver.cjs +33 -71
  1169. package/pglite/driver.cjs.map +1 -1
  1170. package/pglite/driver.d.cts +17 -12
  1171. package/pglite/driver.d.ts +19 -14
  1172. package/pglite/driver.js +32 -71
  1173. package/pglite/driver.js.map +1 -1
  1174. package/pglite/index.cjs +3 -2
  1175. package/pglite/index.d.cts +3 -3
  1176. package/pglite/index.d.ts +3 -3
  1177. package/pglite/index.js +3 -3
  1178. package/pglite/migrator.cjs.map +1 -1
  1179. package/pglite/migrator.d.cts +1 -1
  1180. package/pglite/migrator.d.ts +1 -1
  1181. package/pglite/migrator.js.map +1 -1
  1182. package/pglite/session.cjs +86 -25
  1183. package/pglite/session.cjs.map +1 -1
  1184. package/pglite/session.d.cts +30 -9
  1185. package/pglite/session.d.ts +32 -11
  1186. package/pglite/session.js +87 -27
  1187. package/pglite/session.js.map +1 -1
  1188. package/planetscale-serverless/driver.cjs +2 -3
  1189. package/planetscale-serverless/driver.cjs.map +1 -1
  1190. package/planetscale-serverless/driver.d.cts +0 -1
  1191. package/planetscale-serverless/driver.d.ts +0 -1
  1192. package/planetscale-serverless/driver.js +2 -3
  1193. package/planetscale-serverless/driver.js.map +1 -1
  1194. package/planetscale-serverless/session.cjs +20 -27
  1195. package/planetscale-serverless/session.cjs.map +1 -1
  1196. package/planetscale-serverless/session.d.cts +6 -12
  1197. package/planetscale-serverless/session.d.ts +8 -14
  1198. package/planetscale-serverless/session.js +21 -28
  1199. package/planetscale-serverless/session.js.map +1 -1
  1200. package/postgres-js/driver.cjs +19 -124
  1201. package/postgres-js/driver.cjs.map +1 -1
  1202. package/postgres-js/driver.d.cts +6 -10
  1203. package/postgres-js/driver.d.ts +7 -11
  1204. package/postgres-js/driver.js +19 -124
  1205. package/postgres-js/driver.js.map +1 -1
  1206. package/postgres-js/index.cjs +2 -2
  1207. package/postgres-js/index.d.cts +3 -3
  1208. package/postgres-js/index.d.ts +3 -3
  1209. package/postgres-js/index.js +3 -3
  1210. package/postgres-js/migrator.cjs.map +1 -1
  1211. package/postgres-js/migrator.d.cts +1 -1
  1212. package/postgres-js/migrator.d.ts +1 -1
  1213. package/postgres-js/migrator.js.map +1 -1
  1214. package/postgres-js/session.cjs +112 -17
  1215. package/postgres-js/session.cjs.map +1 -1
  1216. package/postgres-js/session.d.cts +31 -10
  1217. package/postgres-js/session.d.ts +32 -11
  1218. package/postgres-js/session.js +112 -18
  1219. package/postgres-js/session.js.map +1 -1
  1220. package/prisma/mysql/driver.cjs +1 -1
  1221. package/prisma/mysql/driver.js +1 -1
  1222. package/prisma/mysql/session.cjs +1 -2
  1223. package/prisma/mysql/session.cjs.map +1 -1
  1224. package/prisma/mysql/session.d.cts +0 -1
  1225. package/prisma/mysql/session.d.ts +1 -2
  1226. package/prisma/mysql/session.js +1 -2
  1227. package/prisma/mysql/session.js.map +1 -1
  1228. package/prisma/pg/driver.cjs +3 -9
  1229. package/prisma/pg/driver.cjs.map +1 -1
  1230. package/prisma/pg/driver.d.cts +3 -7
  1231. package/prisma/pg/driver.d.ts +3 -7
  1232. package/prisma/pg/driver.js +4 -9
  1233. package/prisma/pg/driver.js.map +1 -1
  1234. package/prisma/pg/index.cjs +2 -2
  1235. package/prisma/pg/index.d.cts +3 -3
  1236. package/prisma/pg/index.d.ts +3 -3
  1237. package/prisma/pg/index.js +3 -3
  1238. package/prisma/pg/session.cjs +25 -1
  1239. package/prisma/pg/session.cjs.map +1 -1
  1240. package/prisma/pg/session.d.cts +15 -3
  1241. package/prisma/pg/session.d.ts +15 -3
  1242. package/prisma/pg/session.js +25 -2
  1243. package/prisma/pg/session.js.map +1 -1
  1244. package/prisma/sqlite/session.cjs +3 -0
  1245. package/prisma/sqlite/session.cjs.map +1 -1
  1246. package/prisma/sqlite/session.d.cts +1 -0
  1247. package/prisma/sqlite/session.d.ts +2 -1
  1248. package/prisma/sqlite/session.js +3 -0
  1249. package/prisma/sqlite/session.js.map +1 -1
  1250. package/relations.cjs +24 -85
  1251. package/relations.cjs.map +1 -1
  1252. package/relations.d.cts +16 -41
  1253. package/relations.d.ts +16 -41
  1254. package/relations.js +25 -84
  1255. package/relations.js.map +1 -1
  1256. package/row-mappers/index.cjs +1 -1
  1257. package/row-mappers/index.cjs.map +1 -1
  1258. package/row-mappers/index.js +1 -1
  1259. package/row-mappers/index.js.map +1 -1
  1260. package/selection-proxy.cjs +1 -1
  1261. package/selection-proxy.js +1 -1
  1262. package/singlestore/driver.cjs +2 -4
  1263. package/singlestore/driver.cjs.map +1 -1
  1264. package/singlestore/driver.d.cts +1 -2
  1265. package/singlestore/driver.d.ts +3 -4
  1266. package/singlestore/driver.js +2 -4
  1267. package/singlestore/driver.js.map +1 -1
  1268. package/singlestore/session.cjs +7 -17
  1269. package/singlestore/session.cjs.map +1 -1
  1270. package/singlestore/session.d.cts +4 -8
  1271. package/singlestore/session.d.ts +6 -10
  1272. package/singlestore/session.js +8 -18
  1273. package/singlestore/session.js.map +1 -1
  1274. package/singlestore-core/columns/bigint.cjs +4 -4
  1275. package/singlestore-core/columns/bigint.cjs.map +1 -1
  1276. package/singlestore-core/columns/bigint.d.cts +2 -2
  1277. package/singlestore-core/columns/bigint.d.ts +2 -2
  1278. package/singlestore-core/columns/bigint.js +4 -4
  1279. package/singlestore-core/columns/bigint.js.map +1 -1
  1280. package/singlestore-core/columns/binary.cjs +2 -2
  1281. package/singlestore-core/columns/binary.cjs.map +1 -1
  1282. package/singlestore-core/columns/binary.d.cts +1 -1
  1283. package/singlestore-core/columns/binary.d.ts +1 -1
  1284. package/singlestore-core/columns/binary.js +2 -2
  1285. package/singlestore-core/columns/binary.js.map +1 -1
  1286. package/singlestore-core/columns/boolean.cjs +2 -2
  1287. package/singlestore-core/columns/boolean.cjs.map +1 -1
  1288. package/singlestore-core/columns/boolean.d.cts +1 -1
  1289. package/singlestore-core/columns/boolean.d.ts +1 -1
  1290. package/singlestore-core/columns/boolean.js +2 -2
  1291. package/singlestore-core/columns/boolean.js.map +1 -1
  1292. package/singlestore-core/columns/custom.cjs +4 -4
  1293. package/singlestore-core/columns/custom.cjs.map +1 -1
  1294. package/singlestore-core/columns/custom.d.cts +2 -2
  1295. package/singlestore-core/columns/custom.d.ts +2 -2
  1296. package/singlestore-core/columns/custom.js +4 -4
  1297. package/singlestore-core/columns/custom.js.map +1 -1
  1298. package/singlestore-core/columns/date.cjs +2 -2
  1299. package/singlestore-core/columns/date.cjs.map +1 -1
  1300. package/singlestore-core/columns/date.d.cts +1 -1
  1301. package/singlestore-core/columns/date.d.ts +1 -1
  1302. package/singlestore-core/columns/date.js +2 -2
  1303. package/singlestore-core/columns/date.js.map +1 -1
  1304. package/singlestore-core/columns/datetime.cjs +6 -6
  1305. package/singlestore-core/columns/datetime.cjs.map +1 -1
  1306. package/singlestore-core/columns/datetime.d.cts +3 -3
  1307. package/singlestore-core/columns/datetime.d.ts +3 -3
  1308. package/singlestore-core/columns/datetime.js +6 -6
  1309. package/singlestore-core/columns/datetime.js.map +1 -1
  1310. package/singlestore-core/columns/decimal.cjs +4 -4
  1311. package/singlestore-core/columns/decimal.cjs.map +1 -1
  1312. package/singlestore-core/columns/decimal.d.cts +2 -2
  1313. package/singlestore-core/columns/decimal.d.ts +2 -2
  1314. package/singlestore-core/columns/decimal.js +4 -4
  1315. package/singlestore-core/columns/decimal.js.map +1 -1
  1316. package/singlestore-core/columns/float.cjs +2 -2
  1317. package/singlestore-core/columns/float.cjs.map +1 -1
  1318. package/singlestore-core/columns/float.d.cts +1 -1
  1319. package/singlestore-core/columns/float.d.ts +1 -1
  1320. package/singlestore-core/columns/float.js +2 -2
  1321. package/singlestore-core/columns/float.js.map +1 -1
  1322. package/singlestore-core/columns/int.cjs +2 -2
  1323. package/singlestore-core/columns/int.cjs.map +1 -1
  1324. package/singlestore-core/columns/int.d.cts +1 -1
  1325. package/singlestore-core/columns/int.d.ts +1 -1
  1326. package/singlestore-core/columns/int.js +2 -2
  1327. package/singlestore-core/columns/int.js.map +1 -1
  1328. package/singlestore-core/columns/json.cjs +2 -2
  1329. package/singlestore-core/columns/json.cjs.map +1 -1
  1330. package/singlestore-core/columns/json.d.cts +1 -1
  1331. package/singlestore-core/columns/json.d.ts +1 -1
  1332. package/singlestore-core/columns/json.js +2 -2
  1333. package/singlestore-core/columns/json.js.map +1 -1
  1334. package/singlestore-core/columns/mediumint.cjs +2 -2
  1335. package/singlestore-core/columns/mediumint.cjs.map +1 -1
  1336. package/singlestore-core/columns/mediumint.d.cts +1 -1
  1337. package/singlestore-core/columns/mediumint.d.ts +1 -1
  1338. package/singlestore-core/columns/mediumint.js +2 -2
  1339. package/singlestore-core/columns/mediumint.js.map +1 -1
  1340. package/singlestore-core/columns/serial.cjs +2 -2
  1341. package/singlestore-core/columns/serial.cjs.map +1 -1
  1342. package/singlestore-core/columns/serial.d.cts +1 -1
  1343. package/singlestore-core/columns/serial.d.ts +1 -1
  1344. package/singlestore-core/columns/serial.js +2 -2
  1345. package/singlestore-core/columns/serial.js.map +1 -1
  1346. package/singlestore-core/columns/smallint.cjs +2 -2
  1347. package/singlestore-core/columns/smallint.cjs.map +1 -1
  1348. package/singlestore-core/columns/smallint.d.cts +1 -1
  1349. package/singlestore-core/columns/smallint.d.ts +1 -1
  1350. package/singlestore-core/columns/smallint.js +2 -2
  1351. package/singlestore-core/columns/smallint.js.map +1 -1
  1352. package/singlestore-core/columns/timestamp.cjs +6 -6
  1353. package/singlestore-core/columns/timestamp.cjs.map +1 -1
  1354. package/singlestore-core/columns/timestamp.d.cts +3 -3
  1355. package/singlestore-core/columns/timestamp.d.ts +3 -3
  1356. package/singlestore-core/columns/timestamp.js +6 -6
  1357. package/singlestore-core/columns/timestamp.js.map +1 -1
  1358. package/singlestore-core/columns/tinyint.cjs +2 -2
  1359. package/singlestore-core/columns/tinyint.cjs.map +1 -1
  1360. package/singlestore-core/columns/tinyint.d.cts +1 -1
  1361. package/singlestore-core/columns/tinyint.d.ts +1 -1
  1362. package/singlestore-core/columns/tinyint.js +2 -2
  1363. package/singlestore-core/columns/tinyint.js.map +1 -1
  1364. package/singlestore-core/columns/varbinary.cjs +2 -2
  1365. package/singlestore-core/columns/varbinary.cjs.map +1 -1
  1366. package/singlestore-core/columns/varbinary.d.cts +1 -1
  1367. package/singlestore-core/columns/varbinary.d.ts +1 -1
  1368. package/singlestore-core/columns/varbinary.js +2 -2
  1369. package/singlestore-core/columns/varbinary.js.map +1 -1
  1370. package/singlestore-core/columns/vector.cjs +8 -8
  1371. package/singlestore-core/columns/vector.cjs.map +1 -1
  1372. package/singlestore-core/columns/vector.d.cts +4 -4
  1373. package/singlestore-core/columns/vector.d.ts +4 -4
  1374. package/singlestore-core/columns/vector.js +8 -8
  1375. package/singlestore-core/columns/vector.js.map +1 -1
  1376. package/singlestore-core/columns/year.cjs +2 -2
  1377. package/singlestore-core/columns/year.cjs.map +1 -1
  1378. package/singlestore-core/columns/year.d.cts +1 -1
  1379. package/singlestore-core/columns/year.d.ts +1 -1
  1380. package/singlestore-core/columns/year.js +2 -2
  1381. package/singlestore-core/columns/year.js.map +1 -1
  1382. package/singlestore-core/db.d.ts +2 -2
  1383. package/singlestore-core/dialect.cjs +2 -2
  1384. package/singlestore-core/dialect.d.ts +1 -1
  1385. package/singlestore-core/dialect.js +2 -2
  1386. package/singlestore-core/query-builders/delete.d.ts +1 -1
  1387. package/singlestore-core/query-builders/insert.d.ts +1 -1
  1388. package/singlestore-core/query-builders/query.cjs +5 -13
  1389. package/singlestore-core/query-builders/query.cjs.map +1 -1
  1390. package/singlestore-core/query-builders/query.d.ts +1 -1
  1391. package/singlestore-core/query-builders/query.js +5 -13
  1392. package/singlestore-core/query-builders/query.js.map +1 -1
  1393. package/singlestore-core/query-builders/select.d.ts +1 -1
  1394. package/singlestore-core/query-builders/update.d.ts +1 -1
  1395. package/singlestore-core/session.cjs.map +1 -1
  1396. package/singlestore-core/session.d.cts +2 -2
  1397. package/singlestore-core/session.d.ts +2 -2
  1398. package/singlestore-core/session.js.map +1 -1
  1399. package/singlestore-core/table.cjs +1 -1
  1400. package/singlestore-core/table.cjs.map +1 -1
  1401. package/singlestore-core/table.js +1 -1
  1402. package/singlestore-core/table.js.map +1 -1
  1403. package/singlestore-proxy/driver.cjs +2 -5
  1404. package/singlestore-proxy/driver.cjs.map +1 -1
  1405. package/singlestore-proxy/driver.js +2 -5
  1406. package/singlestore-proxy/driver.js.map +1 -1
  1407. package/singlestore-proxy/session.cjs +6 -11
  1408. package/singlestore-proxy/session.cjs.map +1 -1
  1409. package/singlestore-proxy/session.d.cts +4 -9
  1410. package/singlestore-proxy/session.d.ts +5 -10
  1411. package/singlestore-proxy/session.js +7 -12
  1412. package/singlestore-proxy/session.js.map +1 -1
  1413. package/sql/index.cjs +0 -1
  1414. package/sql/index.d.cts +2 -2
  1415. package/sql/index.d.ts +2 -2
  1416. package/sql/index.js +2 -2
  1417. package/sql/sql.cjs +11 -32
  1418. package/sql/sql.cjs.map +1 -1
  1419. package/sql/sql.d.cts +5 -15
  1420. package/sql/sql.d.ts +5 -15
  1421. package/sql/sql.js +12 -32
  1422. package/sql/sql.js.map +1 -1
  1423. package/sql-js/driver.cjs +2 -5
  1424. package/sql-js/driver.cjs.map +1 -1
  1425. package/sql-js/driver.d.ts +1 -1
  1426. package/sql-js/driver.js +2 -5
  1427. package/sql-js/driver.js.map +1 -1
  1428. package/sql-js/session.cjs +14 -14
  1429. package/sql-js/session.cjs.map +1 -1
  1430. package/sql-js/session.d.cts +6 -10
  1431. package/sql-js/session.d.ts +6 -10
  1432. package/sql-js/session.js +15 -15
  1433. package/sql-js/session.js.map +1 -1
  1434. package/sqlite-cloud/driver.cjs +2 -3
  1435. package/sqlite-cloud/driver.cjs.map +1 -1
  1436. package/sqlite-cloud/driver.d.ts +1 -1
  1437. package/sqlite-cloud/driver.js +2 -3
  1438. package/sqlite-cloud/driver.js.map +1 -1
  1439. package/sqlite-cloud/session.cjs +20 -21
  1440. package/sqlite-cloud/session.cjs.map +1 -1
  1441. package/sqlite-cloud/session.d.cts +6 -9
  1442. package/sqlite-cloud/session.d.ts +7 -10
  1443. package/sqlite-cloud/session.js +21 -22
  1444. package/sqlite-cloud/session.js.map +1 -1
  1445. package/sqlite-core/columns/blob.cjs +10 -10
  1446. package/sqlite-core/columns/blob.cjs.map +1 -1
  1447. package/sqlite-core/columns/blob.d.cts +5 -5
  1448. package/sqlite-core/columns/blob.d.ts +5 -5
  1449. package/sqlite-core/columns/blob.js +10 -10
  1450. package/sqlite-core/columns/blob.js.map +1 -1
  1451. package/sqlite-core/columns/custom.cjs +4 -4
  1452. package/sqlite-core/columns/custom.cjs.map +1 -1
  1453. package/sqlite-core/columns/custom.d.cts +2 -2
  1454. package/sqlite-core/columns/custom.d.ts +2 -2
  1455. package/sqlite-core/columns/custom.js +4 -4
  1456. package/sqlite-core/columns/custom.js.map +1 -1
  1457. package/sqlite-core/columns/integer.cjs +8 -8
  1458. package/sqlite-core/columns/integer.cjs.map +1 -1
  1459. package/sqlite-core/columns/integer.d.cts +4 -4
  1460. package/sqlite-core/columns/integer.d.ts +4 -4
  1461. package/sqlite-core/columns/integer.js +8 -8
  1462. package/sqlite-core/columns/integer.js.map +1 -1
  1463. package/sqlite-core/columns/numeric.cjs +4 -4
  1464. package/sqlite-core/columns/numeric.cjs.map +1 -1
  1465. package/sqlite-core/columns/numeric.d.cts +2 -2
  1466. package/sqlite-core/columns/numeric.d.ts +2 -2
  1467. package/sqlite-core/columns/numeric.js +4 -4
  1468. package/sqlite-core/columns/numeric.js.map +1 -1
  1469. package/sqlite-core/columns/text.cjs +4 -4
  1470. package/sqlite-core/columns/text.cjs.map +1 -1
  1471. package/sqlite-core/columns/text.d.cts +2 -2
  1472. package/sqlite-core/columns/text.d.ts +2 -2
  1473. package/sqlite-core/columns/text.js +4 -4
  1474. package/sqlite-core/columns/text.js.map +1 -1
  1475. package/sqlite-core/db.d.ts +1 -1
  1476. package/sqlite-core/dialect.cjs +2 -2
  1477. package/sqlite-core/dialect.d.ts +1 -1
  1478. package/sqlite-core/dialect.js +2 -2
  1479. package/sqlite-core/index.cjs +9 -9
  1480. package/sqlite-core/index.js +9 -9
  1481. package/sqlite-core/query-builders/_query.cjs +1 -1
  1482. package/sqlite-core/query-builders/_query.cjs.map +1 -1
  1483. package/sqlite-core/query-builders/_query.js +1 -1
  1484. package/sqlite-core/query-builders/_query.js.map +1 -1
  1485. package/sqlite-core/query-builders/delete.cjs +1 -1
  1486. package/sqlite-core/query-builders/delete.cjs.map +1 -1
  1487. package/sqlite-core/query-builders/delete.js +1 -1
  1488. package/sqlite-core/query-builders/delete.js.map +1 -1
  1489. package/sqlite-core/query-builders/index.cjs +1 -1
  1490. package/sqlite-core/query-builders/index.js +1 -1
  1491. package/sqlite-core/query-builders/insert.cjs +1 -1
  1492. package/sqlite-core/query-builders/insert.cjs.map +1 -1
  1493. package/sqlite-core/query-builders/insert.js +1 -1
  1494. package/sqlite-core/query-builders/insert.js.map +1 -1
  1495. package/sqlite-core/query-builders/query.cjs +5 -13
  1496. package/sqlite-core/query-builders/query.cjs.map +1 -1
  1497. package/sqlite-core/query-builders/query.d.ts +1 -1
  1498. package/sqlite-core/query-builders/query.js +5 -13
  1499. package/sqlite-core/query-builders/query.js.map +1 -1
  1500. package/sqlite-core/query-builders/raw.cjs +4 -0
  1501. package/sqlite-core/query-builders/raw.cjs.map +1 -1
  1502. package/sqlite-core/query-builders/raw.js +4 -0
  1503. package/sqlite-core/query-builders/raw.js.map +1 -1
  1504. package/sqlite-core/query-builders/select.cjs +2 -2
  1505. package/sqlite-core/query-builders/select.cjs.map +1 -1
  1506. package/sqlite-core/query-builders/select.js +2 -2
  1507. package/sqlite-core/query-builders/select.js.map +1 -1
  1508. package/sqlite-core/query-builders/update.cjs +2 -2
  1509. package/sqlite-core/query-builders/update.cjs.map +1 -1
  1510. package/sqlite-core/query-builders/update.js +2 -2
  1511. package/sqlite-core/query-builders/update.js.map +1 -1
  1512. package/sqlite-core/session.cjs +8 -8
  1513. package/sqlite-core/session.cjs.map +1 -1
  1514. package/sqlite-core/session.d.cts +5 -5
  1515. package/sqlite-core/session.d.ts +5 -5
  1516. package/sqlite-core/session.js +8 -8
  1517. package/sqlite-core/session.js.map +1 -1
  1518. package/sqlite-core/table.cjs +1 -1
  1519. package/sqlite-core/table.cjs.map +1 -1
  1520. package/sqlite-core/table.js +1 -1
  1521. package/sqlite-core/table.js.map +1 -1
  1522. package/sqlite-core/utils.cjs +3 -3
  1523. package/sqlite-core/utils.js +3 -3
  1524. package/sqlite-proxy/driver.cjs +2 -3
  1525. package/sqlite-proxy/driver.cjs.map +1 -1
  1526. package/sqlite-proxy/driver.d.ts +1 -1
  1527. package/sqlite-proxy/driver.js +2 -3
  1528. package/sqlite-proxy/driver.js.map +1 -1
  1529. package/sqlite-proxy/session.cjs +17 -20
  1530. package/sqlite-proxy/session.cjs.map +1 -1
  1531. package/sqlite-proxy/session.d.cts +7 -11
  1532. package/sqlite-proxy/session.d.ts +8 -12
  1533. package/sqlite-proxy/session.js +18 -21
  1534. package/sqlite-proxy/session.js.map +1 -1
  1535. package/table.d.cts +1 -1
  1536. package/table.d.ts +1 -1
  1537. package/tidb-serverless/driver.cjs +2 -3
  1538. package/tidb-serverless/driver.cjs.map +1 -1
  1539. package/tidb-serverless/driver.d.cts +0 -1
  1540. package/tidb-serverless/driver.d.ts +0 -1
  1541. package/tidb-serverless/driver.js +2 -3
  1542. package/tidb-serverless/driver.js.map +1 -1
  1543. package/tidb-serverless/session.cjs +37 -25
  1544. package/tidb-serverless/session.cjs.map +1 -1
  1545. package/tidb-serverless/session.d.cts +4 -10
  1546. package/tidb-serverless/session.d.ts +6 -12
  1547. package/tidb-serverless/session.js +38 -26
  1548. package/tidb-serverless/session.js.map +1 -1
  1549. package/tursodatabase/driver-core.cjs +2 -3
  1550. package/tursodatabase/driver-core.cjs.map +1 -1
  1551. package/tursodatabase/driver-core.d.ts +1 -1
  1552. package/tursodatabase/driver-core.js +2 -3
  1553. package/tursodatabase/driver-core.js.map +1 -1
  1554. package/tursodatabase/session.cjs +19 -20
  1555. package/tursodatabase/session.cjs.map +1 -1
  1556. package/tursodatabase/session.d.cts +6 -9
  1557. package/tursodatabase/session.d.ts +7 -10
  1558. package/tursodatabase/session.js +20 -21
  1559. package/tursodatabase/session.js.map +1 -1
  1560. package/up-migrations/effect-pg.cjs +3 -3
  1561. package/up-migrations/effect-pg.cjs.map +1 -1
  1562. package/up-migrations/effect-pg.d.ts +1 -1
  1563. package/up-migrations/effect-pg.js +3 -3
  1564. package/up-migrations/effect-pg.js.map +1 -1
  1565. package/up-migrations/pg.cjs +8 -3
  1566. package/up-migrations/pg.cjs.map +1 -1
  1567. package/up-migrations/pg.d.cts +1 -1
  1568. package/up-migrations/pg.d.ts +2 -2
  1569. package/up-migrations/pg.js +8 -3
  1570. package/up-migrations/pg.js.map +1 -1
  1571. package/up-migrations/sqlite.d.ts +2 -2
  1572. package/utils.cjs +7 -129
  1573. package/utils.cjs.map +1 -1
  1574. package/utils.d.cts +3 -10
  1575. package/utils.d.ts +3 -10
  1576. package/utils.js +8 -127
  1577. package/utils.js.map +1 -1
  1578. package/vercel-postgres/driver.cjs +32 -14
  1579. package/vercel-postgres/driver.cjs.map +1 -1
  1580. package/vercel-postgres/driver.d.cts +17 -12
  1581. package/vercel-postgres/driver.d.ts +18 -13
  1582. package/vercel-postgres/driver.js +31 -14
  1583. package/vercel-postgres/driver.js.map +1 -1
  1584. package/vercel-postgres/index.cjs +3 -2
  1585. package/vercel-postgres/index.d.cts +3 -3
  1586. package/vercel-postgres/index.d.ts +3 -3
  1587. package/vercel-postgres/index.js +3 -3
  1588. package/vercel-postgres/migrator.cjs.map +1 -1
  1589. package/vercel-postgres/migrator.d.cts +1 -1
  1590. package/vercel-postgres/migrator.d.ts +1 -1
  1591. package/vercel-postgres/migrator.js.map +1 -1
  1592. package/vercel-postgres/session.cjs +110 -32
  1593. package/vercel-postgres/session.cjs.map +1 -1
  1594. package/vercel-postgres/session.d.cts +32 -9
  1595. package/vercel-postgres/session.d.ts +33 -10
  1596. package/vercel-postgres/session.js +111 -34
  1597. package/vercel-postgres/session.js.map +1 -1
  1598. package/xata-http/driver.cjs +31 -91
  1599. package/xata-http/driver.cjs.map +1 -1
  1600. package/xata-http/driver.d.cts +16 -10
  1601. package/xata-http/driver.d.ts +17 -11
  1602. package/xata-http/driver.js +30 -91
  1603. package/xata-http/driver.js.map +1 -1
  1604. package/xata-http/index.cjs +4 -2
  1605. package/xata-http/index.d.cts +3 -3
  1606. package/xata-http/index.d.ts +3 -3
  1607. package/xata-http/index.js +3 -3
  1608. package/xata-http/migrator.cjs +1 -1
  1609. package/xata-http/migrator.cjs.map +1 -1
  1610. package/xata-http/migrator.d.cts +1 -1
  1611. package/xata-http/migrator.d.ts +1 -1
  1612. package/xata-http/migrator.js +1 -1
  1613. package/xata-http/migrator.js.map +1 -1
  1614. package/xata-http/session.cjs +110 -24
  1615. package/xata-http/session.cjs.map +1 -1
  1616. package/xata-http/session.d.cts +33 -7
  1617. package/xata-http/session.d.ts +34 -8
  1618. package/xata-http/session.js +110 -26
  1619. package/xata-http/session.js.map +1 -1
  1620. package/codecs.cjs +0 -77
  1621. package/codecs.cjs.map +0 -1
  1622. package/codecs.d.cts +0 -68
  1623. package/codecs.d.ts +0 -68
  1624. package/codecs.js +0 -74
  1625. package/codecs.js.map +0 -1
  1626. package/pg-core/array.cjs.map +0 -1
  1627. package/pg-core/array.js.map +0 -1
  1628. package/pg-core/codecs.cjs +0 -156
  1629. package/pg-core/codecs.cjs.map +0 -1
  1630. package/pg-core/codecs.d.cts +0 -27
  1631. package/pg-core/codecs.d.ts +0 -27
  1632. package/pg-core/codecs.js +0 -148
  1633. package/pg-core/codecs.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"dialect.cjs","names":["entityKind","CasingCache","CodecsCollection","resolvePgType","makeJitQueryMapper","makeRqbJitMapper","makeQueryMapper","makeRqbMapper","sql","Table","SQL","PgTable","PgColumn","Column","Subquery","View","ViewBaseConfig","PgViewBase","Param","PgJsonb","PgJson","PgNumeric","PgTime","PgTimestamp","PgTimestampString","PgDate","PgDateString","PgUUID","DrizzleError","TableColumns","One"],"sources":["../../src/pg-core/dialect.ts"],"sourcesContent":["import { aliasedTable, getOriginalColumnFromAlias } from '~/alias.ts';\nimport { CasingCache } from '~/casing.ts';\nimport { CodecsCollection } from '~/codecs.ts';\nimport { Column } from '~/column.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { DrizzleError } from '~/errors.ts';\nimport {\n\tPgColumn,\n\ttype PgCustomColumn,\n\tPgDate,\n\tPgDateString,\n\tPgJson,\n\tPgJsonb,\n\tPgNumeric,\n\tPgTime,\n\tPgTimestamp,\n\tPgTimestampString,\n\tPgUUID,\n} from '~/pg-core/columns/index.ts';\nimport type {\n\tAnyPgSelectQueryBuilder,\n\tPgDeleteConfig,\n\tPgInsertConfig,\n\tPgSelectJoinConfig,\n\tPgUpdateConfig,\n} from '~/pg-core/query-builders/index.ts';\nimport type { PgSelectConfig, SelectedFieldsOrdered } from '~/pg-core/query-builders/select.types.ts';\nimport { PgTable } from '~/pg-core/table.ts';\nimport {\n\ttype AnyOne,\n\t// AggregatedField,\n\ttype BuildRelationalQueryResult,\n\ttype DBQueryConfigWithComment,\n\tgetTableAsAliasSQL,\n\tmakeRqbJitMapper,\n\tmakeRqbMapper,\n\tOne,\n\ttype Relation,\n\ttype RelationalRowsMapperGenerator,\n\trelationExtrasToSQL,\n\trelationsFilterToSQL,\n\trelationsOrderToSQL,\n\trelationToSQL,\n\ttype TableRelationalConfig,\n\ttype TablesRelationalConfig,\n\ttype WithContainer,\n} from '~/relations.ts';\nimport { and, isSQLWrapper, type SQLWrapper, View } from '~/sql/index.ts';\nimport {\n\ttype DriverValueEncoder,\n\ttype Name,\n\tParam,\n\ttype QueryTypingsValue,\n\ttype QueryWithTypings,\n\tSQL,\n\tsql,\n\ttype SQLChunk,\n} from '~/sql/sql.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { getTableName, Table, TableColumns } from '~/table.ts';\nimport {\n\ttype Casing,\n\tmakeJitQueryMapper,\n\tmakeQueryMapper,\n\torderSelectedFields,\n\ttype RowsMapperGenerator,\n\ttype UpdateSet,\n} from '~/utils.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport { type PgCodecs, type PostgresType, resolvePgType } from './codecs.ts';\nimport { PgViewBase } from './view-base.ts';\nimport type { PgMaterializedView, PgView } from './view.ts';\n\nexport interface PgDialectConfig {\n\tcasing?: Casing | CasingCache;\n\tcodecs?: PgCodecs;\n\tuseJitMappers?: boolean;\n}\n\nexport class PgDialect {\n\tstatic readonly [entityKind]: string = 'PgDialect';\n\n\treadonly casing: CasingCache;\n\treadonly codecs: CodecsCollection<PostgresType>;\n\treadonly mapperGenerators: {\n\t\trows: RowsMapperGenerator;\n\t\trelationalRows: RelationalRowsMapperGenerator;\n\t};\n\n\tconstructor(config?: PgDialectConfig) {\n\t\tthis.casing = typeof config?.casing === 'object' ? config.casing : new CasingCache(config?.casing);\n\t\tthis.codecs = new CodecsCollection<PostgresType>(resolvePgType, config?.codecs);\n\t\tthis.mapperGenerators = config?.useJitMappers\n\t\t\t? {\n\t\t\t\trows: makeJitQueryMapper,\n\t\t\t\trelationalRows: makeRqbJitMapper,\n\t\t\t}\n\t\t\t: {\n\t\t\t\trows: makeQueryMapper,\n\t\t\t\trelationalRows: makeRqbMapper,\n\t\t\t};\n\t}\n\n\tescapeName(name: string): string {\n\t\treturn `\"${name.replace(/\"/g, '\"\"')}\"`;\n\t}\n\n\tescapeParam(num: number): string {\n\t\treturn `$${num + 1}`;\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({\n\t\ttable,\n\t\twhere,\n\t\treturning,\n\t\twithList,\n\t\tcomment,\n\t}: PgDeleteConfig): 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\t\tcomment !== undefined ? sql` ${comment}` : undefined\n\t\t}`;\n\t}\n\n\tbuildUpdateSet(table: PgTable, set: UpdateSet): SQL {\n\t\tconst tableColumns = table[Table.Symbol.Columns];\n\n\t\tconst columnNames = Object.keys(tableColumns).filter(\n\t\t\t(colName) =>\n\t\t\t\tset[colName] !== undefined\n\t\t\t\t|| tableColumns[colName]?.onUpdateFn !== undefined,\n\t\t);\n\n\t\tconst setLength = columnNames.length;\n\t\treturn sql.join(\n\t\t\tcolumnNames.flatMap((colName, i) => {\n\t\t\t\tconst col = tableColumns[colName]!;\n\n\t\t\t\tconst onUpdateFnResult = col.onUpdateFn?.();\n\t\t\t\tconst value = set[colName]\n\t\t\t\t\t?? (is(onUpdateFnResult, SQL)\n\t\t\t\t\t\t? onUpdateFnResult\n\t\t\t\t\t\t: sql.param(onUpdateFnResult, col));\n\t\t\t\tconst res = sql`${sql.identifier(this.casing.getColumnCasing(col))} = ${value}`;\n\n\t\t\t\tif (i < setLength - 1) {\n\t\t\t\t\treturn [res, sql.raw(', ')];\n\t\t\t\t}\n\t\t\t\treturn [res];\n\t\t\t}),\n\t\t);\n\t}\n\n\tbuildUpdateQuery({\n\t\ttable,\n\t\tset,\n\t\twhere,\n\t\treturning,\n\t\twithList,\n\t\tfrom,\n\t\tjoins,\n\t\tcomment,\n\t}: PgUpdateConfig): SQL {\n\t\tconst withSql = this.buildWithCTE(withList);\n\n\t\tconst tableName = table[PgTable.Symbol.Name];\n\t\tconst tableSchema = table[PgTable.Symbol.Schema];\n\t\tconst origTableName = table[PgTable.Symbol.OriginalName];\n\t\tconst alias = tableName === origTableName ? undefined : tableName;\n\t\tconst tableSql = sql`${tableSchema ? sql`${sql.identifier(tableSchema)}.` : undefined}${\n\t\t\tsql.identifier(\n\t\t\t\torigTableName,\n\t\t\t)\n\t\t}${alias && sql` ${sql.identifier(alias)}`}`;\n\n\t\tconst setSql = this.buildUpdateSet(table, set);\n\n\t\tconst fromSql = from && sql.join([sql.raw(' from '), this.buildFromTable(from)]);\n\n\t\tconst joinsSql = this.buildJoins(joins);\n\n\t\tconst returningSql = returning\n\t\t\t? sql` returning ${this.buildSelection(returning, { isSingleTable: !from })}`\n\t\t\t: undefined;\n\n\t\tconst whereSql = where ? sql` where ${where}` : undefined;\n\n\t\treturn sql`${withSql}update ${tableSql} set ${setSql}${fromSql}${joinsSql}${whereSql}${returningSql}${\n\t\t\tcomment !== undefined ? sql` ${comment}` : undefined\n\t\t}`;\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.flatMap(({ field }, i) => {\n\t\t\tconst chunk: SQLChunk[] = [];\n\n\t\t\tif (is(field, SQL.Aliased) && field.isSelectionField) {\n\t\t\t\tif (!isSingleTable && field.origin !== undefined) {\n\t\t\t\t\tchunk.push(sql.identifier(field.origin), sql.raw('.'));\n\t\t\t\t}\n\t\t\t\tchunk.push(sql.identifier(field.fieldAlias));\n\t\t\t} else if (is(field, SQL.Aliased) || is(field, SQL)) {\n\t\t\t\tconst query = is(field, SQL.Aliased) ? field.sql : field;\n\n\t\t\t\tif (isSingleTable) {\n\t\t\t\t\tconst newSql = new SQL(\n\t\t\t\t\t\tquery.queryChunks.map((c) => {\n\t\t\t\t\t\t\tif (is(c, PgColumn)) {\n\t\t\t\t\t\t\t\treturn sql.identifier(this.casing.getColumnCasing(c));\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\treturn c;\n\t\t\t\t\t\t}),\n\t\t\t\t\t);\n\n\t\t\t\t\tchunk.push(query.shouldInlineParams ? newSql.inlineParams() : newSql);\n\t\t\t\t} else {\n\t\t\t\t\tchunk.push(query);\n\t\t\t\t}\n\n\t\t\t\tif (is(field, SQL.Aliased)) {\n\t\t\t\t\tchunk.push(sql` as ${sql.identifier(field.fieldAlias)}`);\n\t\t\t\t}\n\t\t\t} else if (is(field, Column)) {\n\t\t\t\tlet name: Name | Column;\n\t\t\t\tif (isSingleTable) {\n\t\t\t\t\tname = field.isAlias\n\t\t\t\t\t\t? sql.identifier(this.casing.getColumnCasing(getOriginalColumnFromAlias(field)))\n\t\t\t\t\t\t: sql.identifier(this.casing.getColumnCasing(field));\n\t\t\t\t} else {\n\t\t\t\t\tname = field.isAlias ? getOriginalColumnFromAlias(field) : field;\n\t\t\t\t}\n\n\t\t\t\tconst casted = this.codecs.apply(field, 'cast', name);\n\t\t\t\tchunk.push(field.isAlias ? sql`${casted} as ${field}` : casted);\n\t\t\t} else if (is(field, Subquery)) {\n\t\t\t\tconst entries = Object.entries(field._.selectedFields) as [string, SQL.Aliased | Column | SQL][];\n\n\t\t\t\tif (entries.length === 1) {\n\t\t\t\t\tconst entry = entries[0]![1];\n\n\t\t\t\t\tconst fieldDecoder = is(entry, SQL)\n\t\t\t\t\t\t? entry.decoder\n\t\t\t\t\t\t: is(entry, Column)\n\t\t\t\t\t\t? { mapFromDriverValue: (v: any) => entry.mapFromDriverValue(v) }\n\t\t\t\t\t\t: entry.sql.decoder;\n\n\t\t\t\t\tif (fieldDecoder) {\n\t\t\t\t\t\tfield._.sql.decoder = fieldDecoder;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tchunk.push(field);\n\t\t\t}\n\n\t\t\tif (i < columnsLen - 1) {\n\t\t\t\tchunk.push(sql`, `);\n\t\t\t}\n\n\t\t\treturn chunk;\n\t\t});\n\n\t\treturn sql.join(chunks);\n\t}\n\n\tprivate buildJoins(joins: PgSelectJoinConfig[] | undefined): SQL | undefined {\n\t\tif (!joins || joins.length === 0) {\n\t\t\treturn undefined;\n\t\t}\n\n\t\tconst joinsArray: SQL[] = [];\n\n\t\tfor (const [index, joinMeta] of joins.entries()) {\n\t\t\tif (index === 0) {\n\t\t\t\tjoinsArray.push(sql` `);\n\t\t\t}\n\t\t\tconst table = joinMeta.table;\n\t\t\tconst lateralSql = joinMeta.lateral ? sql` lateral` : undefined;\n\t\t\tconst onSql = joinMeta.on ? sql` on ${joinMeta.on}` : undefined;\n\n\t\t\tif (is(table, PgTable)) {\n\t\t\t\tconst tableName = table[PgTable.Symbol.Name];\n\t\t\t\tconst tableSchema = table[PgTable.Symbol.Schema];\n\t\t\t\tconst origTableName = table[PgTable.Symbol.OriginalName];\n\t\t\t\tconst alias = tableName === origTableName ? undefined : joinMeta.alias;\n\t\t\t\tjoinsArray.push(\n\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join${lateralSql} ${\n\t\t\t\t\t\ttableSchema ? sql`${sql.identifier(tableSchema)}.` : undefined\n\t\t\t\t\t}${sql.identifier(origTableName)}${alias && sql` ${sql.identifier(alias)}`}${onSql}`,\n\t\t\t\t);\n\t\t\t} else if (is(table, View)) {\n\t\t\t\tconst viewName = table[ViewBaseConfig].name;\n\t\t\t\tconst viewSchema = table[ViewBaseConfig].schema;\n\t\t\t\tconst origViewName = table[ViewBaseConfig].originalName;\n\t\t\t\tconst alias = viewName === origViewName ? undefined : joinMeta.alias;\n\t\t\t\tjoinsArray.push(\n\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join${lateralSql} ${\n\t\t\t\t\t\tviewSchema ? sql`${sql.identifier(viewSchema)}.` : undefined\n\t\t\t\t\t}${sql.identifier(origViewName)}${alias && sql` ${sql.identifier(alias)}`}${onSql}`,\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tjoinsArray.push(\n\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join${lateralSql} ${table}${onSql}`,\n\t\t\t\t);\n\t\t\t}\n\t\t\tif (index < joins.length - 1) {\n\t\t\t\tjoinsArray.push(sql` `);\n\t\t\t}\n\t\t}\n\n\t\treturn sql.join(joinsArray);\n\t}\n\n\tprivate buildFromTable(\n\t\ttable: SQL | Subquery | PgViewBase | PgTable | undefined,\n\t): SQL | Subquery | PgViewBase | PgTable | undefined {\n\t\tif (is(table, Table) && table[Table.Symbol.IsAlias]) {\n\t\t\tlet fullName = sql`${sql.identifier(table[Table.Symbol.OriginalName])}`;\n\t\t\tif (table[Table.Symbol.Schema]) {\n\t\t\t\tfullName = sql`${sql.identifier(table[Table.Symbol.Schema]!)}.${fullName}`;\n\t\t\t}\n\t\t\treturn sql`${fullName} ${sql.identifier(table[Table.Symbol.Name])}`;\n\t\t}\n\n\t\tif (is(table, View) && table[ViewBaseConfig].isAlias) {\n\t\t\tlet fullName = sql`${sql.identifier(table[ViewBaseConfig].originalName)}`;\n\t\t\tif (table[ViewBaseConfig].schema) {\n\t\t\t\tfullName = sql`${sql.identifier(table[ViewBaseConfig].schema)}.${fullName}`;\n\t\t\t}\n\t\t\treturn sql`${fullName} ${sql.identifier(table[ViewBaseConfig].name)}`;\n\t\t}\n\n\t\treturn table;\n\t}\n\n\tbuildSelectQuery({\n\t\twithList,\n\t\tfields,\n\t\tfieldsFlat,\n\t\twhere,\n\t\thaving,\n\t\ttable,\n\t\tjoins,\n\t\torderBy,\n\t\tgroupBy,\n\t\tlimit,\n\t\toffset,\n\t\tlockingClause,\n\t\tdistinct,\n\t\tsetOperators,\n\t\tcomment,\n\t}: PgSelectConfig): SQL {\n\t\tconst fieldsList = fieldsFlat\n\t\t\t?? orderSelectedFields<PgColumn>(fields, undefined, this.codecs);\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, PgViewBase)\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(\n\t\t\t\t\t\t({ alias }) =>\n\t\t\t\t\t\t\talias\n\t\t\t\t\t\t\t\t=== (table[Table.Symbol.IsAlias]\n\t\t\t\t\t\t\t\t\t? getTableName(table)\n\t\t\t\t\t\t\t\t\t: 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\t\t'->',\n\t\t\t\t\t\t)\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\tlet distinctSql: SQL | undefined;\n\t\tif (distinct) {\n\t\t\tdistinctSql = distinct === true\n\t\t\t\t? sql` distinct`\n\t\t\t\t: sql` distinct on (${sql.join(distinct.on, sql`, `)})`;\n\t\t}\n\n\t\tconst selection = this.buildSelection(fieldsList, { isSingleTable });\n\n\t\tconst tableSql = this.buildFromTable(table);\n\n\t\tconst joinsSql = this.buildJoins(joins);\n\n\t\tconst whereSql = where ? sql` where ${where}` : undefined;\n\n\t\tconst havingSql = having ? sql` having ${having}` : undefined;\n\n\t\tlet orderBySql;\n\t\tif (orderBy && orderBy.length > 0) {\n\t\t\torderBySql = sql` order by ${sql.join(orderBy, sql`, `)}`;\n\t\t}\n\n\t\tlet groupBySql;\n\t\tif (groupBy && groupBy.length > 0) {\n\t\t\tgroupBySql = sql` group by ${sql.join(groupBy, 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 offsetSql = offset ? sql` offset ${offset}` : undefined;\n\n\t\tconst lockingClauseSql = sql.empty();\n\t\tif (lockingClause) {\n\t\t\tconst clauseSql = sql` for ${sql.raw(lockingClause.strength)}`;\n\t\t\tif (lockingClause.config.of) {\n\t\t\t\tclauseSql.append(\n\t\t\t\t\tsql` of ${\n\t\t\t\t\t\tsql.join(\n\t\t\t\t\t\t\tArray.isArray(lockingClause.config.of)\n\t\t\t\t\t\t\t\t? lockingClause.config.of.map((it) => sql.identifier(it[PgTable.Symbol.Name]))\n\t\t\t\t\t\t\t\t: [sql.identifier(lockingClause.config.of[PgTable.Symbol.Name])],\n\t\t\t\t\t\t\tsql`, `,\n\t\t\t\t\t\t)\n\t\t\t\t\t}`,\n\t\t\t\t);\n\t\t\t}\n\t\t\tif (lockingClause.config.noWait) {\n\t\t\t\tclauseSql.append(sql` nowait`);\n\t\t\t} else if (lockingClause.config.skipLocked) {\n\t\t\t\tclauseSql.append(sql` skip locked`);\n\t\t\t}\n\t\t\tlockingClauseSql.append(clauseSql);\n\t\t}\n\t\tconst finalQuery =\n\t\t\tsql`${withSql}select${distinctSql} ${selection} from ${tableSql}${joinsSql}${whereSql}${groupBySql}${havingSql}${orderBySql}${limitSql}${offsetSql}${lockingClauseSql}${\n\t\t\t\tcomment !== undefined ? sql` ${comment}` : undefined\n\t\t\t}`;\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(\n\t\tleftSelect: SQL,\n\t\tsetOperators: PgSelectConfig['setOperators'],\n\t): 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}: {\n\t\tleftSelect: SQL;\n\t\tsetOperator: PgSelectConfig['setOperators'][number];\n\t}): SQL {\n\t\tconst leftChunk = sql`(${leftSelect.getSQL()}) `;\n\t\tconst rightChunk = sql`(${rightSelect.getSQL()})`;\n\n\t\tlet orderBySql;\n\t\tif (orderBy && orderBy.length > 0) {\n\t\t\tconst orderByValues: (SQL<unknown> | Name)[] = [];\n\n\t\t\t// The next bit is necessary because the sql operator replaces ${table.column} with `table`.`column`\n\t\t\t// which is invalid 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, PgColumn)) {\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, PgColumn)) {\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({\n\t\ttable,\n\t\tvalues: valuesOrSelect,\n\t\tonConflict,\n\t\treturning,\n\t\twithList,\n\t\tselect,\n\t\toverridingSystemValue_,\n\t\tcomment,\n\t}: PgInsertConfig): SQL {\n\t\tconst valuesSqlList: ((SQLChunk | SQL)[] | SQL)[] = [];\n\t\tconst columns: Record<string, PgColumn> = table[Table.Symbol.Columns];\n\n\t\tconst colEntries: [string, PgColumn][] = Object.entries(columns).filter(\n\t\t\t([_, col]) => !col.shouldDisableInsert(),\n\t\t);\n\n\t\tconst insertOrder = colEntries.map(([, column]) => sql.identifier(this.casing.getColumnCasing(column)));\n\n\t\tif (select) {\n\t\t\tconst select = valuesOrSelect as AnyPgSelectQueryBuilder | SQL;\n\n\t\t\tif (is(select, SQL)) {\n\t\t\t\tvaluesSqlList.push(select);\n\t\t\t} else {\n\t\t\t\tvaluesSqlList.push(select.getSQL());\n\t\t\t}\n\t\t} else {\n\t\t\tconst values = valuesOrSelect as Record<string, Param | SQL>[];\n\t\t\tvaluesSqlList.push(sql.raw('values '));\n\n\t\t\tfor (const [valueIndex, value] of values.entries()) {\n\t\t\t\tconst valueList: (SQLChunk | SQL)[] = [];\n\t\t\t\tfor (const [fieldName, col] of colEntries) {\n\t\t\t\t\tconst colValue = value[fieldName];\n\t\t\t\t\tif (\n\t\t\t\t\t\tcolValue === undefined\n\t\t\t\t\t\t|| (is(colValue, Param) && colValue.value === undefined)\n\t\t\t\t\t) {\n\t\t\t\t\t\t// eslint-disable-next-line unicorn/no-negated-condition\n\t\t\t\t\t\tif (col.defaultFn !== undefined) {\n\t\t\t\t\t\t\tconst defaultFnResult = col.defaultFn();\n\t\t\t\t\t\t\tconst defaultValue = is(defaultFnResult, SQL)\n\t\t\t\t\t\t\t\t? defaultFnResult\n\t\t\t\t\t\t\t\t: sql.param(defaultFnResult, col);\n\t\t\t\t\t\t\tvalueList.push(defaultValue);\n\t\t\t\t\t\t\t// eslint-disable-next-line unicorn/no-negated-condition\n\t\t\t\t\t\t} else if (!col.default && col.onUpdateFn !== undefined) {\n\t\t\t\t\t\t\tconst onUpdateFnResult = col.onUpdateFn();\n\t\t\t\t\t\t\tconst newValue = is(onUpdateFnResult, SQL)\n\t\t\t\t\t\t\t\t? onUpdateFnResult\n\t\t\t\t\t\t\t\t: sql.param(onUpdateFnResult, col);\n\t\t\t\t\t\t\tvalueList.push(newValue);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tvalueList.push(sql`default`);\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvalueList.push(colValue);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tvaluesSqlList.push(valueList);\n\t\t\t\tif (valueIndex < values.length - 1) {\n\t\t\t\t\tvaluesSqlList.push(sql`, `);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tconst 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\n\t\t\t? sql` on conflict ${onConflict}`\n\t\t\t: undefined;\n\n\t\tconst overridingSql = overridingSystemValue_ === true\n\t\t\t? sql`overriding system value `\n\t\t\t: undefined;\n\n\t\treturn sql`${withSql}insert into ${table} ${insertOrder} ${overridingSql}${valuesSql}${onConflictSql}${returningSql}${\n\t\t\tcomment !== undefined ? sql` ${comment}` : undefined\n\t\t}`;\n\t}\n\n\tbuildRefreshMaterializedViewQuery({\n\t\tview,\n\t\tconcurrently,\n\t\twithNoData,\n\t}: {\n\t\tview: PgMaterializedView;\n\t\tconcurrently?: boolean;\n\t\twithNoData?: boolean;\n\t}): SQL {\n\t\tconst concurrentlySql = concurrently ? sql` concurrently` : undefined;\n\t\tconst withNoDataSql = withNoData ? sql` with no data` : undefined;\n\n\t\treturn sql`refresh materialized view${concurrentlySql} ${view}${withNoDataSql}`;\n\t}\n\n\tprepareTyping(\n\t\tencoder: DriverValueEncoder<unknown, unknown>,\n\t): QueryTypingsValue {\n\t\tif (is(encoder, PgJsonb) || is(encoder, PgJson)) {\n\t\t\treturn 'json';\n\t\t} else if (is(encoder, PgNumeric)) {\n\t\t\treturn 'decimal';\n\t\t} else if (is(encoder, PgTime)) {\n\t\t\treturn 'time';\n\t\t} else if (is(encoder, PgTimestamp) || is(encoder, PgTimestampString)) {\n\t\t\treturn 'timestamp';\n\t\t} else if (is(encoder, PgDate) || is(encoder, PgDateString)) {\n\t\t\treturn 'date';\n\t\t} else if (is(encoder, PgUUID)) {\n\t\t\treturn 'uuid';\n\t\t} else {\n\t\t\treturn 'none';\n\t\t}\n\t}\n\n\tsqlToQuery(sql: SQL, invokeSource?: 'indexes' | undefined): QueryWithTypings {\n\t\treturn sql.toQuery({\n\t\t\tcasing: this.casing,\n\t\t\tescapeName: this.escapeName,\n\t\t\tescapeParam: this.escapeParam,\n\t\t\tescapeString: this.escapeString,\n\t\t\tprepareTyping: this.prepareTyping,\n\t\t\tcodecs: this.codecs,\n\t\t\tinvokeSource,\n\t\t});\n\t}\n\n\tprivate nestedSelectionerror() {\n\t\tthrow new DrizzleError({\n\t\t\tmessage: `Views with nested selections are not supported by the relational query builder`,\n\t\t});\n\t}\n\n\tprivate buildRqbColumn(table: Table | View, column: unknown, key: string, inJson: boolean) {\n\t\tif (is(column, Column)) {\n\t\t\tconst name = sql`${table}.${sql.identifier(this.casing.getColumnCasing(column))}`;\n\t\t\tconst casted = inJson && (<PgCustomColumn<any>> column).jsonSelectIdentifier\n\t\t\t\t? (<PgCustomColumn<any>> column).jsonSelectIdentifier!(name, sql, (<PgCustomColumn<any>> column).dimensions)\n\t\t\t\t: this.codecs.apply(column, inJson ? 'castInJson' : 'cast', name);\n\n\t\t\treturn sql`${casted} as ${sql.identifier(key)}`;\n\t\t}\n\n\t\treturn sql`${table}.${\n\t\t\tis(column, SQL.Aliased)\n\t\t\t\t? sql.identifier(column.fieldAlias)\n\t\t\t\t: isSQLWrapper(column)\n\t\t\t\t? sql.identifier(key)\n\t\t\t\t: this.nestedSelectionerror()\n\t\t} as ${sql.identifier(key)}`;\n\t}\n\n\tprivate unwrapAllColumns = (\n\t\ttable: Table | View,\n\t\tselection: BuildRelationalQueryResult['selection'],\n\t\tinJson: boolean,\n\t) => {\n\t\treturn sql.join(\n\t\t\tObject.entries(table[TableColumns]).map(([k, v]) => {\n\t\t\t\tselection.push(\n\t\t\t\t\tis(v, Column)\n\t\t\t\t\t\t? {\n\t\t\t\t\t\t\tkey: k,\n\t\t\t\t\t\t\tcodec: this.codecs.get(v, inJson ? 'normalizeInJson' : 'normalize'),\n\t\t\t\t\t\t\tarrayDimensions: (<PgColumn> v).dimensions,\n\t\t\t\t\t\t\tfield: v,\n\t\t\t\t\t\t}\n\t\t\t\t\t\t: {\n\t\t\t\t\t\t\tkey: k,\n\t\t\t\t\t\t\tfield: v as SQL | SQLWrapper | SQL.Aliased,\n\t\t\t\t\t\t},\n\t\t\t\t);\n\n\t\t\t\treturn this.buildRqbColumn(table, v, k, inJson);\n\t\t\t}),\n\t\t\tsql`, `,\n\t\t);\n\t};\n\n\tprivate buildColumns = (\n\t\ttable: Table | View,\n\t\tselection: BuildRelationalQueryResult['selection'],\n\t\tinJson: boolean,\n\t\tconfig?: DBQueryConfigWithComment<'many'>,\n\t) =>\n\t\tconfig?.columns\n\t\t\t? (() => {\n\t\t\t\tconst entries = Object.entries(config.columns);\n\t\t\t\tconst columnContainer: Record<string, unknown> = table[TableColumns];\n\n\t\t\t\tconst columnIdentifiers: SQL[] = [];\n\t\t\t\tlet colSelectionMode: boolean | undefined;\n\t\t\t\tfor (const [k, v] of entries) {\n\t\t\t\t\tif (v === undefined) continue;\n\t\t\t\t\tcolSelectionMode = colSelectionMode || v;\n\n\t\t\t\t\tif (v) {\n\t\t\t\t\t\tconst column = columnContainer[k];\n\t\t\t\t\t\tcolumnIdentifiers.push(this.buildRqbColumn(table, column, k, inJson));\n\n\t\t\t\t\t\tselection.push(\n\t\t\t\t\t\t\tis(column, Column)\n\t\t\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\t\tkey: k,\n\t\t\t\t\t\t\t\t\tcodec: this.codecs.get(column, inJson ? 'normalizeInJson' : 'normalize'),\n\t\t\t\t\t\t\t\t\tarrayDimensions: (<PgColumn> column).dimensions,\n\t\t\t\t\t\t\t\t\tfield: column,\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t: {\n\t\t\t\t\t\t\t\t\tkey: k,\n\t\t\t\t\t\t\t\t\tfield: column as SQL | SQLWrapper | SQL.Aliased,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (colSelectionMode === false) {\n\t\t\t\t\tfor (const [k, v] of Object.entries(columnContainer)) {\n\t\t\t\t\t\tif (config.columns[k] === false) continue;\n\t\t\t\t\t\tcolumnIdentifiers.push(this.buildRqbColumn(table, v, k, inJson));\n\n\t\t\t\t\t\tselection.push(\n\t\t\t\t\t\t\tis(v, Column)\n\t\t\t\t\t\t\t\t? {\n\t\t\t\t\t\t\t\t\tkey: k,\n\t\t\t\t\t\t\t\t\tcodec: this.codecs.get(v, inJson ? 'normalizeInJson' : 'normalize'),\n\t\t\t\t\t\t\t\t\tarrayDimensions: (<PgColumn> v).dimensions,\n\t\t\t\t\t\t\t\t\tfield: v,\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t: {\n\t\t\t\t\t\t\t\t\tkey: k,\n\t\t\t\t\t\t\t\t\tfield: v as SQL | SQLWrapper | SQL.Aliased,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn columnIdentifiers.length\n\t\t\t\t\t? sql.join(columnIdentifiers, sql`, `)\n\t\t\t\t\t: undefined;\n\t\t\t})()\n\t\t\t: this.unwrapAllColumns(table, selection, inJson);\n\n\tbuildRelationalQuery({\n\t\tschema,\n\t\ttable,\n\t\ttableConfig,\n\t\tqueryConfig: config,\n\t\trelationWhere,\n\t\tmode,\n\t\terrorPath,\n\t\tdepth,\n\t\tthroughJoin,\n\t\tnested,\n\t}: {\n\t\tschema: TablesRelationalConfig;\n\t\ttable: PgTable | PgView;\n\t\ttableConfig: TableRelationalConfig;\n\t\tqueryConfig?: DBQueryConfigWithComment<'many'> | true;\n\t\trelationWhere?: SQL;\n\t\tmode: 'first' | 'many';\n\t\terrorPath?: string;\n\t\tdepth?: number;\n\t\tthroughJoin?: SQL;\n\t\tnested?: boolean;\n\t}): BuildRelationalQueryResult {\n\t\tconst selection: BuildRelationalQueryResult['selection'] = [];\n\t\tconst isSingle = mode === 'first';\n\t\tconst params = config === true ? undefined : config;\n\t\tconst currentPath = errorPath ?? '';\n\t\tconst currentDepth = depth ?? 0;\n\t\tif (!currentDepth) table = aliasedTable(table, `d${currentDepth}`);\n\n\t\tconst limit = isSingle ? 1 : params?.limit;\n\t\tconst offset = params?.offset;\n\n\t\tconst where: SQL | undefined = params?.where && relationWhere\n\t\t\t? and(\n\t\t\t\trelationsFilterToSQL(\n\t\t\t\t\ttable,\n\t\t\t\t\tparams.where,\n\t\t\t\t\ttableConfig.relations,\n\t\t\t\t\tschema,\n\t\t\t\t\tthis.casing,\n\t\t\t\t),\n\t\t\t\trelationWhere,\n\t\t\t)\n\t\t\t: params?.where\n\t\t\t? relationsFilterToSQL(\n\t\t\t\ttable,\n\t\t\t\tparams.where,\n\t\t\t\ttableConfig.relations,\n\t\t\t\tschema,\n\t\t\t\tthis.casing,\n\t\t\t)\n\t\t\t: relationWhere;\n\n\t\tconst order = params?.orderBy\n\t\t\t? relationsOrderToSQL(table, params.orderBy)\n\t\t\t: undefined;\n\t\tconst columns = this.buildColumns(table, selection, !!nested, params);\n\t\tconst extras = params?.extras\n\t\t\t? relationExtrasToSQL(table, params.extras)\n\t\t\t: undefined;\n\t\tif (extras) selection.push(...extras.selection);\n\n\t\tconst selectionArr: SQL[] = columns ? [columns] : [];\n\n\t\tconst joins = params\n\t\t\t? (() => {\n\t\t\t\tconst { with: joins } = params as WithContainer;\n\t\t\t\tif (!joins) return;\n\n\t\t\t\tconst withEntries = Object.entries(joins).filter(([_, v]) => v);\n\t\t\t\tif (!withEntries.length) return;\n\n\t\t\t\treturn sql.join(\n\t\t\t\t\twithEntries.map(([k, join]) => {\n\t\t\t\t\t\t// if (is(tableConfig.relations[k]!, AggregatedField)) {\n\t\t\t\t\t\t// \tconst relation = tableConfig.relations[k]!;\n\n\t\t\t\t\t\t// \trelation.onTable(table);\n\t\t\t\t\t\t// \tconst query = relation.getSQL();\n\n\t\t\t\t\t\t// \tselection.push({\n\t\t\t\t\t\t// \t\tkey: k,\n\t\t\t\t\t\t// \t\tfield: relation,\n\t\t\t\t\t\t// \t});\n\n\t\t\t\t\t\t// \tselectionArr.push(sql`${sql.identifier(k)}.${sql.identifier('r')} as ${sql.identifier(k)}`);\n\n\t\t\t\t\t\t// \treturn sql`left join lateral(${query}) as ${sql.identifier(k)} on true`;\n\t\t\t\t\t\t// }\n\n\t\t\t\t\t\tconst relation = tableConfig.relations[k]! as Relation;\n\t\t\t\t\t\tconst isSingle = is(relation, One);\n\t\t\t\t\t\tconst targetTable = aliasedTable(\n\t\t\t\t\t\t\trelation.targetTable,\n\t\t\t\t\t\t\t`d${currentDepth + 1}`,\n\t\t\t\t\t\t);\n\t\t\t\t\t\tconst throughTable = relation.throughTable\n\t\t\t\t\t\t\t? (aliasedTable(relation.throughTable, `tr${currentDepth}`) as\n\t\t\t\t\t\t\t\t| Table\n\t\t\t\t\t\t\t\t| View)\n\t\t\t\t\t\t\t: undefined;\n\t\t\t\t\t\tconst { filter, joinCondition } = relationToSQL(\n\t\t\t\t\t\t\tthis.casing,\n\t\t\t\t\t\t\trelation,\n\t\t\t\t\t\t\ttable,\n\t\t\t\t\t\t\ttargetTable,\n\t\t\t\t\t\t\tthroughTable,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tselectionArr.push(\n\t\t\t\t\t\t\tsql`${sql.identifier(k)}.${sql.identifier('r')} as ${sql.identifier(k)}`,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tconst throughJoin = throughTable\n\t\t\t\t\t\t\t? sql` inner join ${getTableAsAliasSQL(throughTable)} on ${joinCondition!}`\n\t\t\t\t\t\t\t: undefined;\n\n\t\t\t\t\t\tconst innerQuery = this.buildRelationalQuery({\n\t\t\t\t\t\t\ttable: targetTable as PgTable | PgView,\n\t\t\t\t\t\t\tmode: isSingle ? 'first' : 'many',\n\t\t\t\t\t\t\tschema,\n\t\t\t\t\t\t\tqueryConfig: join as DBQueryConfigWithComment,\n\t\t\t\t\t\t\ttableConfig: schema[relation.targetTableName]!,\n\t\t\t\t\t\t\trelationWhere: filter,\n\t\t\t\t\t\t\terrorPath: `${currentPath.length ? `${currentPath}.` : ''}${k}`,\n\t\t\t\t\t\t\tdepth: currentDepth + 1,\n\t\t\t\t\t\t\tthroughJoin,\n\t\t\t\t\t\t\tnested: true,\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tselection.push({\n\t\t\t\t\t\t\tfield: targetTable,\n\t\t\t\t\t\t\tkey: k,\n\t\t\t\t\t\t\tselection: innerQuery.selection,\n\t\t\t\t\t\t\tisArray: !isSingle,\n\t\t\t\t\t\t\tisOptional: ((relation as AnyOne).optional ?? false)\n\t\t\t\t\t\t\t\t|| (join !== true\n\t\t\t\t\t\t\t\t\t&& !!(join as Exclude<typeof join, boolean | undefined>)\n\t\t\t\t\t\t\t\t\t\t.where),\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tconst joinQuery = sql`left join lateral(select ${\n\t\t\t\t\t\t\tisSingle\n\t\t\t\t\t\t\t\t? sql`row_to_json(${sql.identifier('t')}.*) ${sql.identifier('r')}`\n\t\t\t\t\t\t\t\t: sql`coalesce(json_agg(row_to_json(${sql.identifier('t')}.*)), '[]') as ${sql.identifier('r')}`\n\t\t\t\t\t\t} from (${innerQuery.sql}) as ${sql.identifier('t')}) as ${sql.identifier(k)} on true`;\n\n\t\t\t\t\t\treturn joinQuery;\n\t\t\t\t\t}),\n\t\t\t\t\tsql` `,\n\t\t\t\t);\n\t\t\t})()\n\t\t\t: undefined;\n\n\t\tif (extras?.sql) selectionArr.push(extras.sql);\n\t\tif (!selectionArr.length) {\n\t\t\tthrow new DrizzleError({\n\t\t\t\tmessage: `No fields selected for table \"${tableConfig.name}\"${currentPath ? ` (\"${currentPath}\")` : ''}`,\n\t\t\t});\n\t\t}\n\t\tconst selectionSet = sql.join(\n\t\t\tselectionArr.filter((e) => e !== undefined),\n\t\t\tsql`, `,\n\t\t);\n\t\tconst comment = config !== true && config?.comment\n\t\t\t? sql.comment(config.comment)\n\t\t\t: undefined;\n\n\t\tconst query = sql`select ${selectionSet} from ${getTableAsAliasSQL(table)}${throughJoin}${\n\t\t\tjoins ? sql` ${joins}` : undefined\n\t\t}${where ? sql` where ${where}` : undefined}${order ? sql` order by ${order}` : undefined}${\n\t\t\tlimit !== undefined ? sql` limit ${limit}` : undefined\n\t\t}${offset !== undefined ? sql` offset ${offset}` : undefined}${comment ? sql` ${comment}` : undefined}`;\n\n\t\treturn {\n\t\t\tsql: query,\n\t\t\tselection,\n\t\t};\n\t}\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"dialect.cjs","names":["entityKind","CasingCache","sql","Table","SQL","PgTable","PgColumn","Column","Subquery","View","ViewBaseConfig","PgViewBase","Param","PgJsonb","PgJson","PgNumeric","PgTime","PgTimestamp","PgTimestampString","PgDate","PgDateString","PgUUID","V1","DrizzleError","TableColumns","One"],"sources":["../../src/pg-core/dialect.ts"],"sourcesContent":["import * as V1 from '~/_relations.ts';\nimport {\n\taliasedTable,\n\taliasedTableColumn,\n\tgetOriginalColumnFromAlias,\n\tmapColumnsInAliasedSQLToAlias,\n\tmapColumnsInSQLToAlias,\n} from '~/alias.ts';\nimport { CasingCache } from '~/casing.ts';\nimport { Column } from '~/column.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { DrizzleError } from '~/errors.ts';\nimport {\n\tPgColumn,\n\ttype PgCustomColumn,\n\tPgDate,\n\tPgDateString,\n\tPgJson,\n\tPgJsonb,\n\tPgNumeric,\n\tPgTime,\n\tPgTimestamp,\n\tPgTimestampString,\n\tPgUUID,\n} from '~/pg-core/columns/index.ts';\nimport type {\n\tAnyPgSelectQueryBuilder,\n\tPgDeleteConfig,\n\tPgInsertConfig,\n\tPgSelectJoinConfig,\n\tPgUpdateConfig,\n} from '~/pg-core/query-builders/index.ts';\nimport type { PgSelectConfig, SelectedFieldsOrdered } from '~/pg-core/query-builders/select.types.ts';\nimport { PgTable } from '~/pg-core/table.ts';\nimport {\n\ttype AnyOne,\n\t// AggregatedField,\n\ttype BuildRelationalQueryResult,\n\ttype DBQueryConfigWithComment,\n\tgetTableAsAliasSQL,\n\tOne,\n\ttype Relation,\n\trelationExtrasToSQL,\n\trelationsFilterToSQL,\n\trelationsOrderToSQL,\n\trelationToSQL,\n\ttype TableRelationalConfig,\n\ttype TablesRelationalConfig,\n\ttype WithContainer,\n} from '~/relations.ts';\nimport { and, eq, isSQLWrapper, type SQLWrapper, View } from '~/sql/index.ts';\nimport {\n\ttype DriverValueEncoder,\n\ttype Name,\n\tParam,\n\ttype QueryTypingsValue,\n\ttype QueryWithTypings,\n\tSQL,\n\tsql,\n\ttype SQLChunk,\n} from '~/sql/sql.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { getTableName, getTableUniqueName, Table, TableColumns } from '~/table.ts';\nimport { type Casing, orderSelectedFields, type UpdateSet } from '~/utils.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport { PgViewBase } from './view-base.ts';\nimport type { PgMaterializedView, PgView } from './view.ts';\n\nexport interface PgDialectConfig {\n\tcasing?: Casing;\n}\n\nexport class PgDialect {\n\tstatic readonly [entityKind]: string = 'PgDialect';\n\n\t/** @internal */\n\treadonly casing: CasingCache;\n\n\tconstructor(config?: PgDialectConfig) {\n\t\tthis.casing = new CasingCache(config?.casing);\n\t}\n\n\tescapeName(name: string): string {\n\t\treturn `\"${name.replace(/\"/g, '\"\"')}\"`;\n\t}\n\n\tescapeParam(num: number): string {\n\t\treturn `$${num + 1}`;\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({\n\t\ttable,\n\t\twhere,\n\t\treturning,\n\t\twithList,\n\t\tcomment,\n\t}: PgDeleteConfig): 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\t\tcomment !== undefined ? sql` ${comment}` : undefined\n\t\t}`;\n\t}\n\n\tbuildUpdateSet(table: PgTable, set: UpdateSet): SQL {\n\t\tconst tableColumns = table[Table.Symbol.Columns];\n\n\t\tconst columnNames = Object.keys(tableColumns).filter(\n\t\t\t(colName) =>\n\t\t\t\tset[colName] !== undefined\n\t\t\t\t|| tableColumns[colName]?.onUpdateFn !== undefined,\n\t\t);\n\n\t\tconst setLength = columnNames.length;\n\t\treturn sql.join(\n\t\t\tcolumnNames.flatMap((colName, i) => {\n\t\t\t\tconst col = tableColumns[colName]!;\n\n\t\t\t\tconst onUpdateFnResult = col.onUpdateFn?.();\n\t\t\t\tconst value = set[colName]\n\t\t\t\t\t?? (is(onUpdateFnResult, SQL)\n\t\t\t\t\t\t? onUpdateFnResult\n\t\t\t\t\t\t: sql.param(onUpdateFnResult, col));\n\t\t\t\tconst res = sql`${sql.identifier(this.casing.getColumnCasing(col))} = ${value}`;\n\n\t\t\t\tif (i < setLength - 1) {\n\t\t\t\t\treturn [res, sql.raw(', ')];\n\t\t\t\t}\n\t\t\t\treturn [res];\n\t\t\t}),\n\t\t);\n\t}\n\n\tbuildUpdateQuery({\n\t\ttable,\n\t\tset,\n\t\twhere,\n\t\treturning,\n\t\twithList,\n\t\tfrom,\n\t\tjoins,\n\t\tcomment,\n\t}: PgUpdateConfig): SQL {\n\t\tconst withSql = this.buildWithCTE(withList);\n\n\t\tconst tableName = table[PgTable.Symbol.Name];\n\t\tconst tableSchema = table[PgTable.Symbol.Schema];\n\t\tconst origTableName = table[PgTable.Symbol.OriginalName];\n\t\tconst alias = tableName === origTableName ? undefined : tableName;\n\t\tconst tableSql = sql`${tableSchema ? sql`${sql.identifier(tableSchema)}.` : undefined}${\n\t\t\tsql.identifier(\n\t\t\t\torigTableName,\n\t\t\t)\n\t\t}${alias && sql` ${sql.identifier(alias)}`}`;\n\n\t\tconst setSql = this.buildUpdateSet(table, set);\n\n\t\tconst fromSql = from && sql.join([sql.raw(' from '), this.buildFromTable(from)]);\n\n\t\tconst joinsSql = this.buildJoins(joins);\n\n\t\tconst returningSql = returning\n\t\t\t? sql` returning ${this.buildSelection(returning, { isSingleTable: !from })}`\n\t\t\t: undefined;\n\n\t\tconst whereSql = where ? sql` where ${where}` : undefined;\n\n\t\treturn sql`${withSql}update ${tableSql} set ${setSql}${fromSql}${joinsSql}${whereSql}${returningSql}${\n\t\t\tcomment !== undefined ? sql` ${comment}` : undefined\n\t\t}`;\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.flatMap(({ field }, i) => {\n\t\t\tconst chunk: SQLChunk[] = [];\n\n\t\t\tif (is(field, SQL.Aliased) && field.isSelectionField) {\n\t\t\t\tif (!isSingleTable && field.origin !== undefined) {\n\t\t\t\t\tchunk.push(sql.identifier(field.origin), sql.raw('.'));\n\t\t\t\t}\n\t\t\t\tchunk.push(sql.identifier(field.fieldAlias));\n\t\t\t} else if (is(field, SQL.Aliased) || is(field, SQL)) {\n\t\t\t\tconst query = is(field, SQL.Aliased) ? field.sql : field;\n\n\t\t\t\tif (isSingleTable) {\n\t\t\t\t\tconst newSql = new SQL(\n\t\t\t\t\t\tquery.queryChunks.map((c) => {\n\t\t\t\t\t\t\tif (is(c, PgColumn)) {\n\t\t\t\t\t\t\t\treturn sql.identifier(this.casing.getColumnCasing(c));\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\treturn c;\n\t\t\t\t\t\t}),\n\t\t\t\t\t);\n\n\t\t\t\t\tchunk.push(query.shouldInlineParams ? newSql.inlineParams() : newSql);\n\t\t\t\t} else {\n\t\t\t\t\tchunk.push(query);\n\t\t\t\t}\n\n\t\t\t\tif (is(field, SQL.Aliased)) {\n\t\t\t\t\tchunk.push(sql` as ${sql.identifier(field.fieldAlias)}`);\n\t\t\t\t}\n\t\t\t} else if (is(field, Column)) {\n\t\t\t\tif (isSingleTable) {\n\t\t\t\t\tchunk.push(\n\t\t\t\t\t\tfield.isAlias\n\t\t\t\t\t\t\t? sql`${sql.identifier(this.casing.getColumnCasing(getOriginalColumnFromAlias(field)))} as ${field}`\n\t\t\t\t\t\t\t: sql.identifier(this.casing.getColumnCasing(field)),\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\tchunk.push(\n\t\t\t\t\t\tfield.isAlias\n\t\t\t\t\t\t\t? sql`${getOriginalColumnFromAlias(field)} as ${field}`\n\t\t\t\t\t\t\t: field,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t} else if (is(field, Subquery)) {\n\t\t\t\tconst entries = Object.entries(field._.selectedFields) as [\n\t\t\t\t\tstring,\n\t\t\t\t\tSQL.Aliased | Column | SQL,\n\t\t\t\t][];\n\n\t\t\t\tif (entries.length === 1) {\n\t\t\t\t\tconst entry = entries[0]![1];\n\n\t\t\t\t\tconst fieldDecoder = is(entry, SQL)\n\t\t\t\t\t\t? entry.decoder\n\t\t\t\t\t\t: is(entry, Column)\n\t\t\t\t\t\t? { mapFromDriverValue: (v: any) => entry.mapFromDriverValue(v) }\n\t\t\t\t\t\t: entry.sql.decoder;\n\n\t\t\t\t\tif (fieldDecoder) {\n\t\t\t\t\t\tfield._.sql.decoder = fieldDecoder;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tchunk.push(field);\n\t\t\t}\n\n\t\t\tif (i < columnsLen - 1) {\n\t\t\t\tchunk.push(sql`, `);\n\t\t\t}\n\n\t\t\treturn chunk;\n\t\t});\n\n\t\treturn sql.join(chunks);\n\t}\n\n\tprivate buildJoins(joins: PgSelectJoinConfig[] | undefined): SQL | undefined {\n\t\tif (!joins || joins.length === 0) {\n\t\t\treturn undefined;\n\t\t}\n\n\t\tconst joinsArray: SQL[] = [];\n\n\t\tfor (const [index, joinMeta] of joins.entries()) {\n\t\t\tif (index === 0) {\n\t\t\t\tjoinsArray.push(sql` `);\n\t\t\t}\n\t\t\tconst table = joinMeta.table;\n\t\t\tconst lateralSql = joinMeta.lateral ? sql` lateral` : undefined;\n\t\t\tconst onSql = joinMeta.on ? sql` on ${joinMeta.on}` : undefined;\n\n\t\t\tif (is(table, PgTable)) {\n\t\t\t\tconst tableName = table[PgTable.Symbol.Name];\n\t\t\t\tconst tableSchema = table[PgTable.Symbol.Schema];\n\t\t\t\tconst origTableName = table[PgTable.Symbol.OriginalName];\n\t\t\t\tconst alias = tableName === origTableName ? undefined : joinMeta.alias;\n\t\t\t\tjoinsArray.push(\n\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join${lateralSql} ${\n\t\t\t\t\t\ttableSchema ? sql`${sql.identifier(tableSchema)}.` : undefined\n\t\t\t\t\t}${sql.identifier(origTableName)}${alias && sql` ${sql.identifier(alias)}`}${onSql}`,\n\t\t\t\t);\n\t\t\t} else if (is(table, View)) {\n\t\t\t\tconst viewName = table[ViewBaseConfig].name;\n\t\t\t\tconst viewSchema = table[ViewBaseConfig].schema;\n\t\t\t\tconst origViewName = table[ViewBaseConfig].originalName;\n\t\t\t\tconst alias = viewName === origViewName ? undefined : joinMeta.alias;\n\t\t\t\tjoinsArray.push(\n\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join${lateralSql} ${\n\t\t\t\t\t\tviewSchema ? sql`${sql.identifier(viewSchema)}.` : undefined\n\t\t\t\t\t}${sql.identifier(origViewName)}${alias && sql` ${sql.identifier(alias)}`}${onSql}`,\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tjoinsArray.push(\n\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join${lateralSql} ${table}${onSql}`,\n\t\t\t\t);\n\t\t\t}\n\t\t\tif (index < joins.length - 1) {\n\t\t\t\tjoinsArray.push(sql` `);\n\t\t\t}\n\t\t}\n\n\t\treturn sql.join(joinsArray);\n\t}\n\n\tprivate buildFromTable(\n\t\ttable: SQL | Subquery | PgViewBase | PgTable | undefined,\n\t): SQL | Subquery | PgViewBase | PgTable | undefined {\n\t\tif (is(table, Table) && table[Table.Symbol.IsAlias]) {\n\t\t\tlet fullName = sql`${sql.identifier(table[Table.Symbol.OriginalName])}`;\n\t\t\tif (table[Table.Symbol.Schema]) {\n\t\t\t\tfullName = sql`${sql.identifier(table[Table.Symbol.Schema]!)}.${fullName}`;\n\t\t\t}\n\t\t\treturn sql`${fullName} ${sql.identifier(table[Table.Symbol.Name])}`;\n\t\t}\n\n\t\tif (is(table, View) && table[ViewBaseConfig].isAlias) {\n\t\t\tlet fullName = sql`${sql.identifier(table[ViewBaseConfig].originalName)}`;\n\t\t\tif (table[ViewBaseConfig].schema) {\n\t\t\t\tfullName = sql`${sql.identifier(table[ViewBaseConfig].schema)}.${fullName}`;\n\t\t\t}\n\t\t\treturn sql`${fullName} ${sql.identifier(table[ViewBaseConfig].name)}`;\n\t\t}\n\n\t\treturn table;\n\t}\n\n\tbuildSelectQuery({\n\t\twithList,\n\t\tfields,\n\t\tfieldsFlat,\n\t\twhere,\n\t\thaving,\n\t\ttable,\n\t\tjoins,\n\t\torderBy,\n\t\tgroupBy,\n\t\tlimit,\n\t\toffset,\n\t\tlockingClause,\n\t\tdistinct,\n\t\tsetOperators,\n\t\tcomment,\n\t}: PgSelectConfig): SQL {\n\t\tconst fieldsList = fieldsFlat ?? orderSelectedFields<PgColumn>(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, PgViewBase)\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(\n\t\t\t\t\t\t({ alias }) =>\n\t\t\t\t\t\t\talias\n\t\t\t\t\t\t\t\t=== (table[Table.Symbol.IsAlias]\n\t\t\t\t\t\t\t\t\t? getTableName(table)\n\t\t\t\t\t\t\t\t\t: 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\t\t'->',\n\t\t\t\t\t\t)\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\tlet distinctSql: SQL | undefined;\n\t\tif (distinct) {\n\t\t\tdistinctSql = distinct === true\n\t\t\t\t? sql` distinct`\n\t\t\t\t: sql` distinct on (${sql.join(distinct.on, sql`, `)})`;\n\t\t}\n\n\t\tconst selection = this.buildSelection(fieldsList, { isSingleTable });\n\n\t\tconst tableSql = this.buildFromTable(table);\n\n\t\tconst joinsSql = this.buildJoins(joins);\n\n\t\tconst whereSql = where ? sql` where ${where}` : undefined;\n\n\t\tconst havingSql = having ? sql` having ${having}` : undefined;\n\n\t\tlet orderBySql;\n\t\tif (orderBy && orderBy.length > 0) {\n\t\t\torderBySql = sql` order by ${sql.join(orderBy, sql`, `)}`;\n\t\t}\n\n\t\tlet groupBySql;\n\t\tif (groupBy && groupBy.length > 0) {\n\t\t\tgroupBySql = sql` group by ${sql.join(groupBy, 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 offsetSql = offset ? sql` offset ${offset}` : undefined;\n\n\t\tconst lockingClauseSql = sql.empty();\n\t\tif (lockingClause) {\n\t\t\tconst clauseSql = sql` for ${sql.raw(lockingClause.strength)}`;\n\t\t\tif (lockingClause.config.of) {\n\t\t\t\tclauseSql.append(\n\t\t\t\t\tsql` of ${\n\t\t\t\t\t\tsql.join(\n\t\t\t\t\t\t\tArray.isArray(lockingClause.config.of)\n\t\t\t\t\t\t\t\t? lockingClause.config.of.map((it) => sql.identifier(it[PgTable.Symbol.Name]))\n\t\t\t\t\t\t\t\t: [sql.identifier(lockingClause.config.of[PgTable.Symbol.Name])],\n\t\t\t\t\t\t\tsql`, `,\n\t\t\t\t\t\t)\n\t\t\t\t\t}`,\n\t\t\t\t);\n\t\t\t}\n\t\t\tif (lockingClause.config.noWait) {\n\t\t\t\tclauseSql.append(sql` nowait`);\n\t\t\t} else if (lockingClause.config.skipLocked) {\n\t\t\t\tclauseSql.append(sql` skip locked`);\n\t\t\t}\n\t\t\tlockingClauseSql.append(clauseSql);\n\t\t}\n\t\tconst finalQuery =\n\t\t\tsql`${withSql}select${distinctSql} ${selection} from ${tableSql}${joinsSql}${whereSql}${groupBySql}${havingSql}${orderBySql}${limitSql}${offsetSql}${lockingClauseSql}${\n\t\t\t\tcomment !== undefined ? sql` ${comment}` : undefined\n\t\t\t}`;\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(\n\t\tleftSelect: SQL,\n\t\tsetOperators: PgSelectConfig['setOperators'],\n\t): 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}: {\n\t\tleftSelect: SQL;\n\t\tsetOperator: PgSelectConfig['setOperators'][number];\n\t}): SQL {\n\t\tconst leftChunk = sql`(${leftSelect.getSQL()}) `;\n\t\tconst rightChunk = sql`(${rightSelect.getSQL()})`;\n\n\t\tlet orderBySql;\n\t\tif (orderBy && orderBy.length > 0) {\n\t\t\tconst orderByValues: (SQL<unknown> | Name)[] = [];\n\n\t\t\t// The next bit is necessary because the sql operator replaces ${table.column} with `table`.`column`\n\t\t\t// which is invalid 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, PgColumn)) {\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, PgColumn)) {\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({\n\t\ttable,\n\t\tvalues: valuesOrSelect,\n\t\tonConflict,\n\t\treturning,\n\t\twithList,\n\t\tselect,\n\t\toverridingSystemValue_,\n\t\tcomment,\n\t}: PgInsertConfig): SQL {\n\t\tconst valuesSqlList: ((SQLChunk | SQL)[] | SQL)[] = [];\n\t\tconst columns: Record<string, PgColumn> = table[Table.Symbol.Columns];\n\n\t\tconst colEntries: [string, PgColumn][] = Object.entries(columns).filter(\n\t\t\t([_, col]) => !col.shouldDisableInsert(),\n\t\t);\n\n\t\tconst insertOrder = colEntries.map(([, column]) => sql.identifier(this.casing.getColumnCasing(column)));\n\n\t\tif (select) {\n\t\t\tconst select = valuesOrSelect as AnyPgSelectQueryBuilder | SQL;\n\n\t\t\tif (is(select, SQL)) {\n\t\t\t\tvaluesSqlList.push(select);\n\t\t\t} else {\n\t\t\t\tvaluesSqlList.push(select.getSQL());\n\t\t\t}\n\t\t} else {\n\t\t\tconst values = valuesOrSelect as Record<string, Param | SQL>[];\n\t\t\tvaluesSqlList.push(sql.raw('values '));\n\n\t\t\tfor (const [valueIndex, value] of values.entries()) {\n\t\t\t\tconst valueList: (SQLChunk | SQL)[] = [];\n\t\t\t\tfor (const [fieldName, col] of colEntries) {\n\t\t\t\t\tconst colValue = value[fieldName];\n\t\t\t\t\tif (\n\t\t\t\t\t\tcolValue === undefined\n\t\t\t\t\t\t|| (is(colValue, Param) && colValue.value === undefined)\n\t\t\t\t\t) {\n\t\t\t\t\t\t// eslint-disable-next-line unicorn/no-negated-condition\n\t\t\t\t\t\tif (col.defaultFn !== undefined) {\n\t\t\t\t\t\t\tconst defaultFnResult = col.defaultFn();\n\t\t\t\t\t\t\tconst defaultValue = is(defaultFnResult, SQL)\n\t\t\t\t\t\t\t\t? defaultFnResult\n\t\t\t\t\t\t\t\t: sql.param(defaultFnResult, col);\n\t\t\t\t\t\t\tvalueList.push(defaultValue);\n\t\t\t\t\t\t\t// eslint-disable-next-line unicorn/no-negated-condition\n\t\t\t\t\t\t} else if (!col.default && col.onUpdateFn !== undefined) {\n\t\t\t\t\t\t\tconst onUpdateFnResult = col.onUpdateFn();\n\t\t\t\t\t\t\tconst newValue = is(onUpdateFnResult, SQL)\n\t\t\t\t\t\t\t\t? onUpdateFnResult\n\t\t\t\t\t\t\t\t: sql.param(onUpdateFnResult, col);\n\t\t\t\t\t\t\tvalueList.push(newValue);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tvalueList.push(sql`default`);\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvalueList.push(colValue);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tvaluesSqlList.push(valueList);\n\t\t\t\tif (valueIndex < values.length - 1) {\n\t\t\t\t\tvaluesSqlList.push(sql`, `);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tconst 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\n\t\t\t? sql` on conflict ${onConflict}`\n\t\t\t: undefined;\n\n\t\tconst overridingSql = overridingSystemValue_ === true\n\t\t\t? sql`overriding system value `\n\t\t\t: undefined;\n\n\t\treturn sql`${withSql}insert into ${table} ${insertOrder} ${overridingSql}${valuesSql}${onConflictSql}${returningSql}${\n\t\t\tcomment !== undefined ? sql` ${comment}` : undefined\n\t\t}`;\n\t}\n\n\tbuildRefreshMaterializedViewQuery({\n\t\tview,\n\t\tconcurrently,\n\t\twithNoData,\n\t}: {\n\t\tview: PgMaterializedView;\n\t\tconcurrently?: boolean;\n\t\twithNoData?: boolean;\n\t}): SQL {\n\t\tconst concurrentlySql = concurrently ? sql` concurrently` : undefined;\n\t\tconst withNoDataSql = withNoData ? sql` with no data` : undefined;\n\n\t\treturn sql`refresh materialized view${concurrentlySql} ${view}${withNoDataSql}`;\n\t}\n\n\tprepareTyping(\n\t\tencoder: DriverValueEncoder<unknown, unknown>,\n\t): QueryTypingsValue {\n\t\tif (is(encoder, PgJsonb) || is(encoder, PgJson)) {\n\t\t\treturn 'json';\n\t\t} else if (is(encoder, PgNumeric)) {\n\t\t\treturn 'decimal';\n\t\t} else if (is(encoder, PgTime)) {\n\t\t\treturn 'time';\n\t\t} else if (is(encoder, PgTimestamp) || is(encoder, PgTimestampString)) {\n\t\t\treturn 'timestamp';\n\t\t} else if (is(encoder, PgDate) || is(encoder, PgDateString)) {\n\t\t\treturn 'date';\n\t\t} else if (is(encoder, PgUUID)) {\n\t\t\treturn 'uuid';\n\t\t} else {\n\t\t\treturn 'none';\n\t\t}\n\t}\n\n\tsqlToQuery(sql: SQL, invokeSource?: 'indexes' | undefined): QueryWithTypings {\n\t\treturn sql.toQuery({\n\t\t\tcasing: this.casing,\n\t\t\tescapeName: this.escapeName,\n\t\t\tescapeParam: this.escapeParam,\n\t\t\tescapeString: this.escapeString,\n\t\t\tprepareTyping: this.prepareTyping,\n\t\t\tinvokeSource,\n\t\t});\n\t}\n\n\t/** @deprecated */\n\t_buildRelationalQuery({\n\t\tfullSchema,\n\t\tschema,\n\t\ttableNamesMap,\n\t\ttable,\n\t\ttableConfig,\n\t\tqueryConfig: config,\n\t\ttableAlias,\n\t\tnestedQueryRelation,\n\t\tjoinOn,\n\t}: {\n\t\tfullSchema: Record<string, unknown>;\n\t\tschema: V1.TablesRelationalConfig;\n\t\ttableNamesMap: Record<string, string>;\n\t\ttable: PgTable;\n\t\ttableConfig: V1.TableRelationalConfig;\n\t\tqueryConfig: true | V1.DBQueryConfigWithComment<'many', true>;\n\t\ttableAlias: string;\n\t\tnestedQueryRelation?: V1.Relation;\n\t\tjoinOn?: SQL;\n\t}): V1.BuildRelationalQueryResult<PgTable, PgColumn> {\n\t\tlet selection: V1.BuildRelationalQueryResult<\n\t\t\tPgTable,\n\t\t\tPgColumn\n\t\t>['selection'] = [];\n\t\tlet limit,\n\t\t\toffset,\n\t\t\torderBy: NonNullable<PgSelectConfig['orderBy']> = [],\n\t\t\twhere;\n\t\tconst joins: PgSelectJoinConfig[] = [];\n\n\t\tif (config === true) {\n\t\t\tconst selectionEntries = Object.entries(tableConfig.columns);\n\t\t\tselection = selectionEntries.map(([key, value]) => ({\n\t\t\t\tdbKey: value.name,\n\t\t\t\ttsKey: key,\n\t\t\t\tfield: aliasedTableColumn(value as PgColumn, 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]) => [\n\t\t\t\t\tkey,\n\t\t\t\t\taliasedTableColumn(value, tableAlias),\n\t\t\t\t]),\n\t\t\t);\n\n\t\t\tif (config.where) {\n\t\t\t\tconst whereSql = typeof config.where === 'function'\n\t\t\t\t\t? config.where(aliasedColumns, V1.getOperators())\n\t\t\t\t\t: config.where;\n\t\t\t\twhere = whereSql && mapColumnsInSQLToAlias(whereSql, tableAlias);\n\t\t\t}\n\n\t\t\tconst fieldsSelection: {\n\t\t\t\ttsKey: string;\n\t\t\t\tvalue: PgColumn | SQL.Aliased;\n\t\t\t}[] = [];\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(\n\t\t\t\t\t\t\t(key) => !selectedColumns.includes(key),\n\t\t\t\t\t\t);\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 PgColumn;\n\t\t\t\tfieldsSelection.push({ tsKey: field, value: column });\n\t\t\t}\n\n\t\t\tlet selectedRelations: {\n\t\t\t\ttsKey: string;\n\t\t\t\tqueryConfig: true | V1.DBQueryConfigWithComment<'many', false>;\n\t\t\t\trelation: V1.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(\n\t\t\t\t\t\t(\n\t\t\t\t\t\t\tentry,\n\t\t\t\t\t\t): entry is [(typeof entry)[0], NonNullable<(typeof entry)[1]>] => !!entry[1],\n\t\t\t\t\t)\n\t\t\t\t\t.map(([tsKey, queryConfig]) => ({\n\t\t\t\t\t\ttsKey,\n\t\t\t\t\t\tqueryConfig,\n\t\t\t\t\t\trelation: tableConfig.relations[tsKey]!,\n\t\t\t\t\t}));\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)\n\t\t\t\t\t\t? value.fieldAlias\n\t\t\t\t\t\t: tableConfig.columns[tsKey]!.name,\n\t\t\t\t\ttsKey,\n\t\t\t\t\tfield: is(value, Column)\n\t\t\t\t\t\t? aliasedTableColumn(value, tableAlias)\n\t\t\t\t\t\t: value,\n\t\t\t\t\trelationTableTsKey: undefined,\n\t\t\t\t\tisJson: false,\n\t\t\t\t\tselection: [],\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tlet orderByOrig = typeof config.orderBy === 'function'\n\t\t\t\t? config.orderBy(aliasedColumns, V1.getOrderByOperators())\n\t\t\t\t: (config.orderBy ?? []);\n\t\t\tif (!Array.isArray(orderByOrig)) {\n\t\t\t\torderByOrig = [orderByOrig];\n\t\t\t}\n\t\t\torderBy = orderByOrig.map((orderByValue) => {\n\t\t\t\tif (is(orderByValue, Column)) {\n\t\t\t\t\treturn aliasedTableColumn(orderByValue, tableAlias) as PgColumn;\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 = V1.normalizeRelation(\n\t\t\t\t\tschema,\n\t\t\t\t\ttableNamesMap,\n\t\t\t\t\trelation,\n\t\t\t\t);\n\t\t\t\tconst relationTableName = getTableUniqueName(relation.referencedTable);\n\t\t\t\tconst relationTableTsName = tableNamesMap[relationTableName]!;\n\t\t\t\tconst relationTableAlias = `${tableAlias}_${selectedRelationTsKey}`;\n\t\t\t\tconst joinOn = and(\n\t\t\t\t\t...normalizedRelation.fields.map((field, i) =>\n\t\t\t\t\t\teq(\n\t\t\t\t\t\t\taliasedTableColumn(\n\t\t\t\t\t\t\t\tnormalizedRelation.references[i]!,\n\t\t\t\t\t\t\t\trelationTableAlias,\n\t\t\t\t\t\t\t),\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 PgTable,\n\t\t\t\t\ttableConfig: schema[relationTableTsName]!,\n\t\t\t\t\tqueryConfig: is(relation, V1.One)\n\t\t\t\t\t\t? selectedRelationConfigValue === true\n\t\t\t\t\t\t\t? { limit: 1 }\n\t\t\t\t\t\t\t: { ...selectedRelationConfigValue, limit: 1 }\n\t\t\t\t\t\t: selectedRelationConfigValue,\n\t\t\t\t\ttableAlias: relationTableAlias,\n\t\t\t\t\tjoinOn,\n\t\t\t\t\tnestedQueryRelation: relation,\n\t\t\t\t});\n\t\t\t\tconst field = sql`${sql.identifier(relationTableAlias)}.${sql.identifier('data')}`.as(\n\t\t\t\t\tselectedRelationTsKey,\n\t\t\t\t);\n\t\t\t\tjoins.push({\n\t\t\t\t\ton: sql`true`,\n\t\t\t\t\ttable: new Subquery(builtRelation.sql as SQL, {}, relationTableAlias),\n\t\t\t\t\talias: relationTableAlias,\n\t\t\t\t\tjoinType: 'left',\n\t\t\t\t\tlateral: true,\n\t\t\t\t});\n\t\t\t\tselection.push({\n\t\t\t\t\tdbKey: selectedRelationTsKey,\n\t\t\t\t\ttsKey: selectedRelationTsKey,\n\t\t\t\t\tfield,\n\t\t\t\t\trelationTableTsKey: relationTableTsName,\n\t\t\t\t\tisJson: true,\n\t\t\t\t\tselection: builtRelation.selection,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tif (selection.length === 0) {\n\t\t\tthrow new DrizzleError({\n\t\t\t\tmessage: `No fields selected for table \"${tableConfig.tsName}\" (\"${tableAlias}\")`,\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_build_array(${\n\t\t\t\tsql.join(\n\t\t\t\t\tselection.map(({ field, tsKey, isJson }) =>\n\t\t\t\t\t\tisJson\n\t\t\t\t\t\t\t? sql`${sql.identifier(`${tableAlias}_${tsKey}`)}.${sql.identifier('data')}`\n\t\t\t\t\t\t\t: is(field, SQL.Aliased)\n\t\t\t\t\t\t\t? field.sql\n\t\t\t\t\t\t\t: field\n\t\t\t\t\t),\n\t\t\t\t\tsql`, `,\n\t\t\t\t)\n\t\t\t})`;\n\t\t\tif (is(nestedQueryRelation, V1.Many)) {\n\t\t\t\tfield = sql`coalesce(json_agg(${field}${\n\t\t\t\t\torderBy.length > 0\n\t\t\t\t\t\t? sql` order by ${sql.join(orderBy, sql`, `)}`\n\t\t\t\t\t\t: undefined\n\t\t\t\t}), '[]'::json)`;\n\t\t\t\t// orderBy = [];\n\t\t\t}\n\t\t\tconst nestedSelection = [\n\t\t\t\t{\n\t\t\t\t\tdbKey: 'data',\n\t\t\t\t\ttsKey: 'data',\n\t\t\t\t\tfield: field.as('data'),\n\t\t\t\t\tisJson: true,\n\t\t\t\t\trelationTableTsKey: tableConfig.tsName,\n\t\t\t\t\tselection,\n\t\t\t\t},\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 = [];\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, PgTable)\n\t\t\t\t\t? result\n\t\t\t\t\t: 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)\n\t\t\t\t\t\t? aliasedTableColumn(field, tableAlias)\n\t\t\t\t\t\t: 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)\n\t\t\t\t\t\t? aliasedTableColumn(field, tableAlias)\n\t\t\t\t\t\t: 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\tif (config !== true && config.comment) {\n\t\t\tconst comment = sql.comment(config.comment);\n\t\t\tresult = comment ? sql`${result} ${comment}` : result;\n\t\t}\n\n\t\treturn {\n\t\t\ttableTsKey: tableConfig.tsName,\n\t\t\tsql: result,\n\t\t\tselection,\n\t\t};\n\t}\n\n\tprivate nestedSelectionerror() {\n\t\tthrow new DrizzleError({\n\t\t\tmessage: `Views with nested selections are not supported by the relational query builder`,\n\t\t});\n\t}\n\n\tprivate buildRqbColumn(table: Table | View, column: unknown, key: string) {\n\t\tif (is(column, Column)) {\n\t\t\tconst name = sql`${table}.${sql.identifier(this.casing.getColumnCasing(column))}`;\n\t\t\tconst targetType = column.columnType;\n\t\t\t// Get dimension count directly from PgColumn.dimensions\n\t\t\tconst dimensionCnt = is(column, PgColumn) ? column.dimensions : 0;\n\n\t\t\tswitch (targetType) {\n\t\t\t\tcase 'PgNumeric':\n\t\t\t\tcase 'PgNumericNumber':\n\t\t\t\tcase 'PgNumericBigInt':\n\t\t\t\tcase 'PgBigInt64':\n\t\t\t\tcase 'PgBigIntString':\n\t\t\t\tcase 'PgBigSerial64':\n\t\t\t\tcase 'PgTimestampString':\n\t\t\t\tcase 'PgGeometry':\n\t\t\t\tcase 'PgGeometryObject':\n\t\t\t\tcase 'PgBytea': {\n\t\t\t\t\tconst arrVal = '[]'.repeat(dimensionCnt);\n\n\t\t\t\t\treturn sql`${name}::text${sql.raw(arrVal).if(arrVal)} as ${sql.identifier(key)}`;\n\t\t\t\t}\n\t\t\t\tcase 'PgCustomColumn': {\n\t\t\t\t\treturn sql`${\n\t\t\t\t\t\t(<PgCustomColumn<any>> column).jsonSelectIdentifier(\n\t\t\t\t\t\t\tname,\n\t\t\t\t\t\t\tsql,\n\t\t\t\t\t\t\tdimensionCnt > 0 ? dimensionCnt : undefined,\n\t\t\t\t\t\t)\n\t\t\t\t\t} as ${sql.identifier(key)}`;\n\t\t\t\t}\n\t\t\t\tdefault: {\n\t\t\t\t\treturn sql`${name} as ${sql.identifier(key)}`;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn sql`${table}.${\n\t\t\tis(column, SQL.Aliased)\n\t\t\t\t? sql.identifier(column.fieldAlias)\n\t\t\t\t: isSQLWrapper(column)\n\t\t\t\t? sql.identifier(key)\n\t\t\t\t: this.nestedSelectionerror()\n\t\t} as ${sql.identifier(key)}`;\n\t}\n\n\tprivate unwrapAllColumns = (\n\t\ttable: Table | View,\n\t\tselection: BuildRelationalQueryResult['selection'],\n\t) => {\n\t\treturn sql.join(\n\t\t\tObject.entries(table[TableColumns]).map(([k, v]) => {\n\t\t\t\tselection.push({\n\t\t\t\t\tkey: k,\n\t\t\t\t\tfield: v as Column | SQL | SQLWrapper | SQL.Aliased,\n\t\t\t\t});\n\n\t\t\t\treturn this.buildRqbColumn(table, v, k);\n\t\t\t}),\n\t\t\tsql`, `,\n\t\t);\n\t};\n\n\tprivate buildColumns = (\n\t\ttable: Table | View,\n\t\tselection: BuildRelationalQueryResult['selection'],\n\t\tconfig?: DBQueryConfigWithComment<'many'>,\n\t) =>\n\t\tconfig?.columns\n\t\t\t? (() => {\n\t\t\t\tconst entries = Object.entries(config.columns);\n\t\t\t\tconst columnContainer: Record<string, unknown> = table[TableColumns];\n\n\t\t\t\tconst columnIdentifiers: SQL[] = [];\n\t\t\t\tlet colSelectionMode: boolean | undefined;\n\t\t\t\tfor (const [k, v] of entries) {\n\t\t\t\t\tif (v === undefined) continue;\n\t\t\t\t\tcolSelectionMode = colSelectionMode || v;\n\n\t\t\t\t\tif (v) {\n\t\t\t\t\t\tconst column = columnContainer[k];\n\t\t\t\t\t\tcolumnIdentifiers.push(this.buildRqbColumn(table, column, k));\n\n\t\t\t\t\t\tselection.push({\n\t\t\t\t\t\t\tkey: k,\n\t\t\t\t\t\t\tfield: column as SQL | SQLWrapper | SQL.Aliased | Column,\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (colSelectionMode === false) {\n\t\t\t\t\tfor (const [k, v] of Object.entries(columnContainer)) {\n\t\t\t\t\t\tif (config.columns[k] === false) continue;\n\t\t\t\t\t\tcolumnIdentifiers.push(this.buildRqbColumn(table, v, k));\n\n\t\t\t\t\t\tselection.push({\n\t\t\t\t\t\t\tkey: k,\n\t\t\t\t\t\t\tfield: v as SQL | SQLWrapper | SQL.Aliased | Column,\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn columnIdentifiers.length\n\t\t\t\t\t? sql.join(columnIdentifiers, sql`, `)\n\t\t\t\t\t: undefined;\n\t\t\t})()\n\t\t\t: this.unwrapAllColumns(table, selection);\n\n\tbuildRelationalQuery({\n\t\tschema,\n\t\ttable,\n\t\ttableConfig,\n\t\tqueryConfig: config,\n\t\trelationWhere,\n\t\tmode,\n\t\terrorPath,\n\t\tdepth,\n\t\tthroughJoin,\n\t}: {\n\t\tschema: TablesRelationalConfig;\n\t\ttable: PgTable | PgView;\n\t\ttableConfig: TableRelationalConfig;\n\t\tqueryConfig?: DBQueryConfigWithComment<'many'> | true;\n\t\trelationWhere?: SQL;\n\t\tmode: 'first' | 'many';\n\t\terrorPath?: string;\n\t\tdepth?: number;\n\t\tthroughJoin?: SQL;\n\t}): BuildRelationalQueryResult {\n\t\tconst selection: BuildRelationalQueryResult['selection'] = [];\n\t\tconst isSingle = mode === 'first';\n\t\tconst params = config === true ? undefined : config;\n\t\tconst currentPath = errorPath ?? '';\n\t\tconst currentDepth = depth ?? 0;\n\t\tif (!currentDepth) table = aliasedTable(table, `d${currentDepth}`);\n\n\t\tconst limit = isSingle ? 1 : params?.limit;\n\t\tconst offset = params?.offset;\n\n\t\tconst where: SQL | undefined = params?.where && relationWhere\n\t\t\t? and(\n\t\t\t\trelationsFilterToSQL(\n\t\t\t\t\ttable,\n\t\t\t\t\tparams.where,\n\t\t\t\t\ttableConfig.relations,\n\t\t\t\t\tschema,\n\t\t\t\t\tthis.casing,\n\t\t\t\t),\n\t\t\t\trelationWhere,\n\t\t\t)\n\t\t\t: params?.where\n\t\t\t? relationsFilterToSQL(\n\t\t\t\ttable,\n\t\t\t\tparams.where,\n\t\t\t\ttableConfig.relations,\n\t\t\t\tschema,\n\t\t\t\tthis.casing,\n\t\t\t)\n\t\t\t: relationWhere;\n\n\t\tconst order = params?.orderBy\n\t\t\t? relationsOrderToSQL(table, params.orderBy)\n\t\t\t: undefined;\n\t\tconst columns = this.buildColumns(table, selection, params);\n\t\tconst extras = params?.extras\n\t\t\t? relationExtrasToSQL(table, params.extras)\n\t\t\t: undefined;\n\t\tif (extras) selection.push(...extras.selection);\n\n\t\tconst selectionArr: SQL[] = columns ? [columns] : [];\n\n\t\tconst joins = params\n\t\t\t? (() => {\n\t\t\t\tconst { with: joins } = params as WithContainer;\n\t\t\t\tif (!joins) return;\n\n\t\t\t\tconst withEntries = Object.entries(joins).filter(([_, v]) => v);\n\t\t\t\tif (!withEntries.length) return;\n\n\t\t\t\treturn sql.join(\n\t\t\t\t\twithEntries.map(([k, join]) => {\n\t\t\t\t\t\t// if (is(tableConfig.relations[k]!, AggregatedField)) {\n\t\t\t\t\t\t// \tconst relation = tableConfig.relations[k]!;\n\n\t\t\t\t\t\t// \trelation.onTable(table);\n\t\t\t\t\t\t// \tconst query = relation.getSQL();\n\n\t\t\t\t\t\t// \tselection.push({\n\t\t\t\t\t\t// \t\tkey: k,\n\t\t\t\t\t\t// \t\tfield: relation,\n\t\t\t\t\t\t// \t});\n\n\t\t\t\t\t\t// \tselectionArr.push(sql`${sql.identifier(k)}.${sql.identifier('r')} as ${sql.identifier(k)}`);\n\n\t\t\t\t\t\t// \treturn sql`left join lateral(${query}) as ${sql.identifier(k)} on true`;\n\t\t\t\t\t\t// }\n\n\t\t\t\t\t\tconst relation = tableConfig.relations[k]! as Relation;\n\t\t\t\t\t\tconst isSingle = is(relation, One);\n\t\t\t\t\t\tconst targetTable = aliasedTable(\n\t\t\t\t\t\t\trelation.targetTable,\n\t\t\t\t\t\t\t`d${currentDepth + 1}`,\n\t\t\t\t\t\t);\n\t\t\t\t\t\tconst throughTable = relation.throughTable\n\t\t\t\t\t\t\t? (aliasedTable(relation.throughTable, `tr${currentDepth}`) as\n\t\t\t\t\t\t\t\t| Table\n\t\t\t\t\t\t\t\t| View)\n\t\t\t\t\t\t\t: undefined;\n\t\t\t\t\t\tconst { filter, joinCondition } = relationToSQL(\n\t\t\t\t\t\t\tthis.casing,\n\t\t\t\t\t\t\trelation,\n\t\t\t\t\t\t\ttable,\n\t\t\t\t\t\t\ttargetTable,\n\t\t\t\t\t\t\tthroughTable,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tselectionArr.push(\n\t\t\t\t\t\t\tsql`${sql.identifier(k)}.${sql.identifier('r')} as ${sql.identifier(k)}`,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tconst throughJoin = throughTable\n\t\t\t\t\t\t\t? sql` inner join ${getTableAsAliasSQL(throughTable)} on ${joinCondition!}`\n\t\t\t\t\t\t\t: undefined;\n\n\t\t\t\t\t\tconst innerQuery = this.buildRelationalQuery({\n\t\t\t\t\t\t\ttable: targetTable as PgTable | PgView,\n\t\t\t\t\t\t\tmode: isSingle ? 'first' : 'many',\n\t\t\t\t\t\t\tschema,\n\t\t\t\t\t\t\tqueryConfig: join as DBQueryConfigWithComment,\n\t\t\t\t\t\t\ttableConfig: schema[relation.targetTableName]!,\n\t\t\t\t\t\t\trelationWhere: filter,\n\t\t\t\t\t\t\terrorPath: `${currentPath.length ? `${currentPath}.` : ''}${k}`,\n\t\t\t\t\t\t\tdepth: currentDepth + 1,\n\t\t\t\t\t\t\tthroughJoin,\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tselection.push({\n\t\t\t\t\t\t\tfield: targetTable,\n\t\t\t\t\t\t\tkey: k,\n\t\t\t\t\t\t\tselection: innerQuery.selection,\n\t\t\t\t\t\t\tisArray: !isSingle,\n\t\t\t\t\t\t\tisOptional: ((relation as AnyOne).optional ?? false)\n\t\t\t\t\t\t\t\t|| (join !== true\n\t\t\t\t\t\t\t\t\t&& !!(join as Exclude<typeof join, boolean | undefined>)\n\t\t\t\t\t\t\t\t\t\t.where),\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tconst joinQuery = sql`left join lateral(select ${\n\t\t\t\t\t\t\tisSingle\n\t\t\t\t\t\t\t\t? sql`row_to_json(${sql.identifier('t')}.*) ${sql.identifier('r')}`\n\t\t\t\t\t\t\t\t: sql`coalesce(json_agg(row_to_json(${sql.identifier('t')}.*)), '[]') as ${sql.identifier('r')}`\n\t\t\t\t\t\t} from (${innerQuery.sql}) as ${sql.identifier('t')}) as ${sql.identifier(k)} on true`;\n\n\t\t\t\t\t\treturn joinQuery;\n\t\t\t\t\t}),\n\t\t\t\t\tsql` `,\n\t\t\t\t);\n\t\t\t})()\n\t\t\t: undefined;\n\n\t\tif (extras?.sql) selectionArr.push(extras.sql);\n\t\tif (!selectionArr.length) {\n\t\t\tthrow new DrizzleError({\n\t\t\t\tmessage: `No fields selected for table \"${tableConfig.name}\"${currentPath ? ` (\"${currentPath}\")` : ''}`,\n\t\t\t});\n\t\t}\n\t\tconst selectionSet = sql.join(\n\t\t\tselectionArr.filter((e) => e !== undefined),\n\t\t\tsql`, `,\n\t\t);\n\t\tconst comment = config !== true && config?.comment\n\t\t\t? sql.comment(config.comment)\n\t\t\t: undefined;\n\n\t\tconst query = sql`select ${selectionSet} from ${getTableAsAliasSQL(table)}${throughJoin}${\n\t\t\tjoins ? sql` ${joins}` : undefined\n\t\t}${where ? sql` where ${where}` : undefined}${order ? sql` order by ${order}` : undefined}${\n\t\t\tlimit !== undefined ? sql` limit ${limit}` : undefined\n\t\t}${offset !== undefined ? sql` offset ${offset}` : undefined}${comment ? sql` ${comment}` : undefined}`;\n\n\t\treturn {\n\t\t\tsql: query,\n\t\t\tselection,\n\t\t};\n\t}\n}\n"],"mappings":"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"}
@@ -1,29 +1,20 @@
1
- import { PgCodecs, PostgresType } from "./codecs.cjs";
2
1
  import { PgMaterializedView, PgView } from "./view.cjs";
3
2
  import { entityKind } from "../entity.cjs";
4
3
  import { DriverValueEncoder, QueryTypingsValue, QueryWithTypings, SQL } from "../sql/sql.cjs";
5
- import { Casing, RowsMapperGenerator, UpdateSet } from "../utils.cjs";
6
- import { BuildRelationalQueryResult, DBQueryConfigWithComment, RelationalRowsMapperGenerator, TableRelationalConfig, TablesRelationalConfig } from "../relations.cjs";
4
+ import { Casing, UpdateSet } from "../utils.cjs";
5
+ import * as V1 from "../_relations.cjs";
6
+ import { BuildRelationalQueryResult, DBQueryConfigWithComment, TableRelationalConfig as TableRelationalConfig$1, TablesRelationalConfig as TablesRelationalConfig$1 } from "../relations.cjs";
7
+ import { PgColumn } from "./columns/index.cjs";
7
8
  import { PgTable } from "./table.cjs";
8
- import { CodecsCollection } from "../codecs.cjs";
9
- import { CasingCache } from "../casing.cjs";
10
9
  import { PgDeleteConfig, PgInsertConfig, PgUpdateConfig } from "./query-builders/index.cjs";
11
10
  import { PgSelectConfig } from "./query-builders/select.types.cjs";
12
11
 
13
12
  //#region src/pg-core/dialect.d.ts
14
13
  interface PgDialectConfig {
15
- casing?: Casing | CasingCache;
16
- codecs?: PgCodecs;
17
- useJitMappers?: boolean;
14
+ casing?: Casing;
18
15
  }
19
16
  declare class PgDialect {
20
17
  static readonly [entityKind]: string;
21
- readonly casing: CasingCache;
22
- readonly codecs: CodecsCollection<PostgresType>;
23
- readonly mapperGenerators: {
24
- rows: RowsMapperGenerator;
25
- relationalRows: RelationalRowsMapperGenerator;
26
- };
27
18
  constructor(config?: PgDialectConfig);
28
19
  escapeName(name: string): string;
29
20
  escapeParam(num: number): string;
@@ -114,6 +105,28 @@ declare class PgDialect {
114
105
  }): SQL;
115
106
  prepareTyping(encoder: DriverValueEncoder<unknown, unknown>): QueryTypingsValue;
116
107
  sqlToQuery(sql: SQL, invokeSource?: 'indexes' | undefined): QueryWithTypings;
108
+ /** @deprecated */
109
+ _buildRelationalQuery({
110
+ fullSchema,
111
+ schema,
112
+ tableNamesMap,
113
+ table,
114
+ tableConfig,
115
+ queryConfig: config,
116
+ tableAlias,
117
+ nestedQueryRelation,
118
+ joinOn
119
+ }: {
120
+ fullSchema: Record<string, unknown>;
121
+ schema: V1.TablesRelationalConfig;
122
+ tableNamesMap: Record<string, string>;
123
+ table: PgTable;
124
+ tableConfig: V1.TableRelationalConfig;
125
+ queryConfig: true | V1.DBQueryConfigWithComment<'many', true>;
126
+ tableAlias: string;
127
+ nestedQueryRelation?: V1.Relation;
128
+ joinOn?: SQL;
129
+ }): V1.BuildRelationalQueryResult<PgTable, PgColumn>;
117
130
  private nestedSelectionerror;
118
131
  private buildRqbColumn;
119
132
  private unwrapAllColumns;
@@ -127,19 +140,17 @@ declare class PgDialect {
127
140
  mode,
128
141
  errorPath,
129
142
  depth,
130
- throughJoin,
131
- nested
143
+ throughJoin
132
144
  }: {
133
- schema: TablesRelationalConfig;
145
+ schema: TablesRelationalConfig$1;
134
146
  table: PgTable | PgView;
135
- tableConfig: TableRelationalConfig;
147
+ tableConfig: TableRelationalConfig$1;
136
148
  queryConfig?: DBQueryConfigWithComment<'many'> | true;
137
149
  relationWhere?: SQL;
138
150
  mode: 'first' | 'many';
139
151
  errorPath?: string;
140
152
  depth?: number;
141
153
  throughJoin?: SQL;
142
- nested?: boolean;
143
154
  }): BuildRelationalQueryResult;
144
155
  }
145
156
  //#endregion
@@ -1,29 +1,20 @@
1
- import { PgCodecs, PostgresType } from "./codecs.js";
2
1
  import { PgMaterializedView, PgView } from "./view.js";
3
2
  import { entityKind } from "../entity.js";
4
- import { Casing, RowsMapperGenerator, UpdateSet } from "../utils.js";
5
- import { CodecsCollection } from "../codecs.js";
3
+ import { Casing, UpdateSet } from "../utils.js";
6
4
  import { DriverValueEncoder, QueryTypingsValue, QueryWithTypings, SQL } from "../sql/sql.js";
7
- import { BuildRelationalQueryResult, DBQueryConfigWithComment, RelationalRowsMapperGenerator, TableRelationalConfig, TablesRelationalConfig } from "../relations.js";
8
- import { CasingCache } from "../casing.js";
9
- import { PgTable } from "./table.js";
5
+ import * as V1 from "../_relations.js";
6
+ import { BuildRelationalQueryResult, DBQueryConfigWithComment, TableRelationalConfig as TableRelationalConfig$1, TablesRelationalConfig as TablesRelationalConfig$1 } from "../relations.js";
10
7
  import { PgDeleteConfig, PgInsertConfig, PgUpdateConfig } from "./query-builders/index.js";
8
+ import { PgTable } from "./table.js";
9
+ import { PgColumn } from "./columns/index.js";
11
10
  import { PgSelectConfig } from "./query-builders/select.types.js";
12
11
 
13
12
  //#region src/pg-core/dialect.d.ts
14
13
  interface PgDialectConfig {
15
- casing?: Casing | CasingCache;
16
- codecs?: PgCodecs;
17
- useJitMappers?: boolean;
14
+ casing?: Casing;
18
15
  }
19
16
  declare class PgDialect {
20
17
  static readonly [entityKind]: string;
21
- readonly casing: CasingCache;
22
- readonly codecs: CodecsCollection<PostgresType>;
23
- readonly mapperGenerators: {
24
- rows: RowsMapperGenerator;
25
- relationalRows: RelationalRowsMapperGenerator;
26
- };
27
18
  constructor(config?: PgDialectConfig);
28
19
  escapeName(name: string): string;
29
20
  escapeParam(num: number): string;
@@ -114,6 +105,28 @@ declare class PgDialect {
114
105
  }): SQL;
115
106
  prepareTyping(encoder: DriverValueEncoder<unknown, unknown>): QueryTypingsValue;
116
107
  sqlToQuery(sql: SQL, invokeSource?: 'indexes' | undefined): QueryWithTypings;
108
+ /** @deprecated */
109
+ _buildRelationalQuery({
110
+ fullSchema,
111
+ schema,
112
+ tableNamesMap,
113
+ table,
114
+ tableConfig,
115
+ queryConfig: config,
116
+ tableAlias,
117
+ nestedQueryRelation,
118
+ joinOn
119
+ }: {
120
+ fullSchema: Record<string, unknown>;
121
+ schema: V1.TablesRelationalConfig;
122
+ tableNamesMap: Record<string, string>;
123
+ table: PgTable;
124
+ tableConfig: V1.TableRelationalConfig;
125
+ queryConfig: true | V1.DBQueryConfigWithComment<'many', true>;
126
+ tableAlias: string;
127
+ nestedQueryRelation?: V1.Relation;
128
+ joinOn?: SQL;
129
+ }): V1.BuildRelationalQueryResult<PgTable, PgColumn>;
117
130
  private nestedSelectionerror;
118
131
  private buildRqbColumn;
119
132
  private unwrapAllColumns;
@@ -127,19 +140,17 @@ declare class PgDialect {
127
140
  mode,
128
141
  errorPath,
129
142
  depth,
130
- throughJoin,
131
- nested
143
+ throughJoin
132
144
  }: {
133
- schema: TablesRelationalConfig;
145
+ schema: TablesRelationalConfig$1;
134
146
  table: PgTable | PgView;
135
- tableConfig: TableRelationalConfig;
147
+ tableConfig: TableRelationalConfig$1;
136
148
  queryConfig?: DBQueryConfigWithComment<'many'> | true;
137
149
  relationWhere?: SQL;
138
150
  mode: 'first' | 'many';
139
151
  errorPath?: string;
140
152
  depth?: number;
141
153
  throughJoin?: SQL;
142
- nested?: boolean;
143
154
  }): BuildRelationalQueryResult;
144
155
  }
145
156
  //#endregion