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":"update.cjs","names":["entityKind","QueryPromise","GelTable","Table","Subquery","ViewBaseConfig","SQL","SelectionProxyHandler","extractUsedTable"],"sources":["../../../src/gel-core/query-builders/update.ts"],"sourcesContent":["import type { GetColumnData } from '~/column.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport type { GelDialect } from '~/gel-core/dialect.ts';\nimport type {\n\tGelPreparedQuery,\n\tGelQueryResultHKT,\n\tGelQueryResultKind,\n\tGelSession,\n\tPreparedQueryConfig,\n} from '~/gel-core/session.ts';\nimport { GelTable } from '~/gel-core/table.ts';\nimport type {\n\tAppendToNullabilityMap,\n\tAppendToResult,\n\tGetSelectTableName,\n\tGetSelectTableSelection,\n\tJoinNullability,\n\tJoinType,\n\tSelectMode,\n\tSelectResult,\n} from '~/query-builders/select.types.ts';\nimport { preparedStatementName } from '~/query-name-generator.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport { type ColumnsSelection, type Placeholder, type Query, SQL, type SQLWrapper } from '~/sql/sql.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { type InferInsertModel, Table } from '~/table.ts';\nimport { type Assume, getTableLikeName, mapUpdateSet, orderSelectedFields, type UpdateSet } from '~/utils.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport type { GelColumn } from '../columns/common.ts';\nimport { extractUsedTable } from '../utils.ts';\nimport type { GelViewBase } from '../view-base.ts';\nimport type { GelSelectJoinConfig, SelectedFields, SelectedFieldsOrdered } from './select.types.ts';\n\nexport interface GelUpdateConfig {\n\twhere?: SQL | undefined;\n\tset: UpdateSet;\n\ttable: GelTable;\n\tfrom?: GelTable | Subquery | GelViewBase | SQL;\n\tjoins: GelSelectJoinConfig[];\n\treturning?: SelectedFieldsOrdered;\n\twithList?: Subquery[];\n}\n\nexport type GelUpdateSetSource<\n\tTTable extends GelTable,\n\tTModel extends Record<string, any> = InferInsertModel<TTable>,\n> =\n\t& {\n\t\t[Key in keyof TModel & string]?:\n\t\t\t| GetColumnData<TTable['_']['columns'][Key]>\n\t\t\t| SQL\n\t\t\t| Placeholder\n\t\t\t| GelColumn\n\t\t\t| undefined;\n\t}\n\t& {};\n\nexport class GelUpdateBuilder<TTable extends GelTable, TQueryResult extends GelQueryResultHKT> {\n\tstatic readonly [entityKind]: string = 'GelUpdateBuilder';\n\n\tdeclare readonly _: {\n\t\treadonly table: TTable;\n\t};\n\n\tconstructor(\n\t\tprivate table: TTable,\n\t\tprivate session: GelSession,\n\t\tprivate dialect: GelDialect,\n\t\tprivate withList?: Subquery[],\n\t) {}\n\n\tset(\n\t\tvalues: GelUpdateSetSource<TTable>,\n\t): GelUpdateWithout<GelUpdateBase<TTable, TQueryResult>, false, 'leftJoin' | 'rightJoin' | 'innerJoin' | 'fullJoin'> {\n\t\treturn new GelUpdateBase<TTable, TQueryResult>(\n\t\t\tthis.table,\n\t\t\tmapUpdateSet(this.table, values),\n\t\t\tthis.session,\n\t\t\tthis.dialect,\n\t\t\tthis.withList,\n\t\t);\n\t}\n}\n\nexport type GelUpdateWithout<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tK extends keyof T & string,\n> = TDynamic extends true ? T : Omit<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tT['_']['from'],\n\t\tT['_']['returning'],\n\t\tT['_']['nullabilityMap'],\n\t\tT['_']['joins'],\n\t\tTDynamic,\n\t\tT['_']['excludedMethods'] | K\n\t>,\n\tT['_']['excludedMethods'] | K\n>;\n\nexport type GelUpdateWithJoins<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL,\n> = TDynamic extends true ? T : Omit<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tTFrom,\n\t\tT['_']['returning'],\n\t\tAppendToNullabilityMap<T['_']['nullabilityMap'], GetSelectTableName<TFrom>, 'inner'>,\n\t\t[...T['_']['joins'], {\n\t\t\tname: GetSelectTableName<TFrom>;\n\t\t\tjoinType: 'inner';\n\t\t\ttable: TFrom;\n\t\t}],\n\t\tTDynamic,\n\t\tExclude<T['_']['excludedMethods'] | 'from', 'leftJoin' | 'rightJoin' | 'innerJoin' | 'fullJoin'>\n\t>,\n\tExclude<T['_']['excludedMethods'] | 'from', 'leftJoin' | 'rightJoin' | 'innerJoin' | 'fullJoin'>\n>;\n\nexport type GelUpdateJoinFn<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTJoinType extends JoinType,\n> = <\n\tTJoinedTable extends GelTable | Subquery | GelViewBase | SQL,\n>(\n\ttable: TJoinedTable,\n\ton:\n\t\t| (\n\t\t\t(\n\t\t\t\tupdateTable: T['_']['table']['_']['columns'],\n\t\t\t\tfrom: T['_']['from'] extends GelTable ? T['_']['from']['_']['columns']\n\t\t\t\t\t: T['_']['from'] extends Subquery | GelViewBase ? T['_']['from']['_']['selectedFields']\n\t\t\t\t\t: never,\n\t\t\t) => SQL | undefined\n\t\t)\n\t\t| SQL\n\t\t| undefined,\n) => GelUpdateJoin<T, TDynamic, TJoinType, TJoinedTable>;\n\nexport type GelUpdateJoin<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTJoinType extends JoinType,\n\tTJoinedTable extends GelTable | Subquery | GelViewBase | SQL,\n> = TDynamic extends true ? T : GelUpdateBase<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['from'],\n\tT['_']['returning'],\n\tAppendToNullabilityMap<T['_']['nullabilityMap'], GetSelectTableName<TJoinedTable>, TJoinType>,\n\t[...T['_']['joins'], {\n\t\tname: GetSelectTableName<TJoinedTable>;\n\t\tjoinType: TJoinType;\n\t\ttable: TJoinedTable;\n\t}],\n\tTDynamic,\n\tT['_']['excludedMethods']\n>;\n\ntype Join = {\n\tname: string | undefined;\n\tjoinType: JoinType;\n\ttable: GelTable | Subquery | GelViewBase | SQL;\n};\n\ntype AccumulateToResult<\n\tT extends AnyGelUpdate,\n\tTSelectMode extends SelectMode,\n\tTJoins extends Join[],\n\tTSelectedFields extends ColumnsSelection,\n> = TJoins extends [infer TJoin extends Join, ...infer TRest extends Join[]] ? AccumulateToResult<\n\t\tT,\n\t\tTSelectMode extends 'partial' ? TSelectMode : 'multiple',\n\t\tTRest,\n\t\tAppendToResult<\n\t\t\tT['_']['table']['_']['name'],\n\t\t\tTSelectedFields,\n\t\t\tTJoin['name'],\n\t\t\tTJoin['table'] extends Table ? TJoin['table']['_']['columns']\n\t\t\t\t: TJoin['table'] extends Subquery ? Assume<TJoin['table']['_']['selectedFields'], SelectedFields>\n\t\t\t\t: never,\n\t\t\tTSelectMode extends 'partial' ? TSelectMode : 'multiple'\n\t\t>\n\t>\n\t: TSelectedFields;\n\nexport type GelUpdateReturningAll<T extends AnyGelUpdate, TDynamic extends boolean> = GelUpdateWithout<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tT['_']['from'],\n\t\tSelectResult<\n\t\t\tAccumulateToResult<\n\t\t\t\tT,\n\t\t\t\t'single',\n\t\t\t\tT['_']['joins'],\n\t\t\t\tGetSelectTableSelection<T['_']['table']>\n\t\t\t>,\n\t\t\t'partial',\n\t\t\tT['_']['nullabilityMap']\n\t\t>,\n\t\tT['_']['nullabilityMap'],\n\t\tT['_']['joins'],\n\t\tTDynamic,\n\t\tT['_']['excludedMethods']\n\t>,\n\tTDynamic,\n\t'returning'\n>;\n\nexport type GelUpdateReturning<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTSelectedFields extends SelectedFields,\n> = GelUpdateWithout<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tT['_']['from'],\n\t\tSelectResult<\n\t\t\tAccumulateToResult<\n\t\t\t\tT,\n\t\t\t\t'partial',\n\t\t\t\tT['_']['joins'],\n\t\t\t\tTSelectedFields\n\t\t\t>,\n\t\t\t'partial',\n\t\t\tT['_']['nullabilityMap']\n\t\t>,\n\t\tT['_']['nullabilityMap'],\n\t\tT['_']['joins'],\n\t\tTDynamic,\n\t\tT['_']['excludedMethods']\n\t>,\n\tTDynamic,\n\t'returning'\n>;\n\nexport type GelUpdatePrepare<T extends AnyGelUpdate> = GelPreparedQuery<\n\tPreparedQueryConfig & {\n\t\texecute: T['_']['returning'] extends undefined ? GelQueryResultKind<T['_']['queryResult'], never>\n\t\t\t: T['_']['returning'][];\n\t}\n>;\n\nexport type GelUpdateDynamic<T extends AnyGelUpdate> = GelUpdate<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['from'],\n\tT['_']['returning'],\n\tT['_']['nullabilityMap']\n>;\n\nexport type GelUpdate<\n\tTTable extends GelTable = GelTable,\n\tTQueryResult extends GelQueryResultHKT = GelQueryResultHKT,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL | undefined = undefined,\n\tTReturning extends Record<string, unknown> | undefined = Record<string, unknown> | undefined,\n\tTNullabilityMap extends Record<string, JoinNullability> = Record<TTable['_']['name'], 'not-null'>,\n\tTJoins extends Join[] = [],\n> = GelUpdateBase<TTable, TQueryResult, TFrom, TReturning, TNullabilityMap, TJoins, true, never>;\n\nexport type AnyGelUpdate = GelUpdateBase<any, any, any, any, any, any, any, any>;\n\nexport interface GelUpdateBase<\n\tTTable extends GelTable,\n\tTQueryResult extends GelQueryResultHKT,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL | undefined = undefined,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\tTNullabilityMap extends Record<string, JoinNullability> = Record<TTable['_']['name'], 'not-null'>,\n\tTJoins extends Join[] = [],\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n> extends\n\tQueryPromise<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[]>,\n\tRunnableQuery<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[], 'gel'>,\n\tSQLWrapper\n{\n\treadonly _: {\n\t\treadonly dialect: 'gel';\n\t\treadonly table: TTable;\n\t\treadonly joins: TJoins;\n\t\treadonly nullabilityMap: TNullabilityMap;\n\t\treadonly queryResult: TQueryResult;\n\t\treadonly from: TFrom;\n\t\treadonly returning: TReturning;\n\t\treadonly dynamic: TDynamic;\n\t\treadonly excludedMethods: TExcludedMethods;\n\t\treadonly result: TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[];\n\t};\n}\n\nexport class GelUpdateBase<\n\tTTable extends GelTable,\n\tTQueryResult extends GelQueryResultHKT,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL | undefined = undefined,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTNullabilityMap extends Record<string, JoinNullability> = Record<TTable['_']['name'], 'not-null'>,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTJoins extends Join[] = [],\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTDynamic extends boolean = false,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTExcludedMethods extends string = never,\n> extends QueryPromise<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[]>\n\timplements\n\t\tRunnableQuery<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[], 'gel'>,\n\t\tSQLWrapper\n{\n\tstatic override readonly [entityKind]: string = 'GelUpdate';\n\n\tprivate config: GelUpdateConfig;\n\tprivate tableName: string | undefined;\n\tprivate joinsNotNullableMap: Record<string, boolean>;\n\n\tconstructor(\n\t\ttable: TTable,\n\t\tset: UpdateSet,\n\t\tprivate session: GelSession,\n\t\tprivate dialect: GelDialect,\n\t\twithList?: Subquery[],\n\t) {\n\t\tsuper();\n\t\tthis.config = { set, table, withList, joins: [] };\n\t\tthis.tableName = getTableLikeName(table);\n\t\tthis.joinsNotNullableMap = typeof this.tableName === 'string' ? { [this.tableName]: true } : {};\n\t}\n\n\tfrom<TFrom extends GelTable | Subquery | GelViewBase | SQL>(\n\t\tsource: TFrom,\n\t): GelUpdateWithJoins<this, TDynamic, TFrom> {\n\t\tconst tableName = getTableLikeName(source);\n\t\tif (typeof tableName === 'string') {\n\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t}\n\t\tthis.config.from = source;\n\t\treturn this as any;\n\t}\n\n\tprivate getTableLikeFields(table: GelTable | Subquery | GelViewBase): Record<string, unknown> {\n\t\tif (is(table, GelTable)) {\n\t\t\treturn table[Table.Symbol.Columns];\n\t\t} else if (is(table, Subquery)) {\n\t\t\treturn table._.selectedFields;\n\t\t}\n\t\treturn table[ViewBaseConfig].selectedFields;\n\t}\n\n\tprivate createJoin<TJoinType extends JoinType>(\n\t\tjoinType: TJoinType,\n\t): GelUpdateJoinFn<this, TDynamic, TJoinType> {\n\t\treturn ((\n\t\t\ttable: GelTable | Subquery | GelViewBase | SQL,\n\t\t\ton: ((updateTable: TTable, from: TFrom) => SQL | undefined) | SQL | undefined,\n\t\t) => {\n\t\t\tconst tableName = getTableLikeName(table);\n\n\t\t\tif (typeof tableName === 'string' && this.config.joins.some((join) => join.alias === tableName)) {\n\t\t\t\tthrow new Error(`Alias \"${tableName}\" is already used in this query`);\n\t\t\t}\n\n\t\t\tif (typeof on === 'function') {\n\t\t\t\tconst from = this.config.from && !is(this.config.from, SQL)\n\t\t\t\t\t? this.getTableLikeFields(this.config.from)\n\t\t\t\t\t: undefined;\n\t\t\t\ton = on(\n\t\t\t\t\tnew Proxy(\n\t\t\t\t\t\tthis.config.table[Table.Symbol.Columns],\n\t\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t\t) as any,\n\t\t\t\t\tfrom && new Proxy(\n\t\t\t\t\t\tfrom,\n\t\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t\t) as any,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tthis.config.joins.push({ on, table, joinType, alias: tableName });\n\n\t\t\tif (typeof tableName === 'string') {\n\t\t\t\tswitch (joinType) {\n\t\t\t\t\tcase 'left': {\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = false;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'right': {\n\t\t\t\t\t\tthis.joinsNotNullableMap = Object.fromEntries(\n\t\t\t\t\t\t\tObject.entries(this.joinsNotNullableMap).map(([key]) => [key, false]),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'inner': {\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'full': {\n\t\t\t\t\t\tthis.joinsNotNullableMap = Object.fromEntries(\n\t\t\t\t\t\t\tObject.entries(this.joinsNotNullableMap).map(([key]) => [key, false]),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = false;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn this as any;\n\t\t}) as any;\n\t}\n\n\tleftJoin = this.createJoin('left');\n\n\trightJoin = this.createJoin('right');\n\n\tinnerJoin = this.createJoin('inner');\n\n\tfullJoin = this.createJoin('full');\n\n\t/**\n\t * Adds a 'where' clause to the query.\n\t *\n\t * Calling this method will update only those rows that fulfill a specified condition.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/update}\n\t *\n\t * @param where the 'where' clause.\n\t *\n\t * @example\n\t * You can use conditional operators and `sql function` to filter the rows to be updated.\n\t *\n\t * ```ts\n\t * // Update all cars with green color\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(eq(cars.color, 'green'));\n\t * // or\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(sql`${cars.color} = 'green'`)\n\t * ```\n\t *\n\t * You can logically combine conditional operators with `and()` and `or()` operators:\n\t *\n\t * ```ts\n\t * // Update all BMW cars with a green color\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n\t *\n\t * // Update all cars with the green or blue color\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n\t * ```\n\t */\n\twhere(where: SQL | undefined): GelUpdateWithout<this, TDynamic, 'where'> {\n\t\tthis.config.where = where;\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `returning` clause to the query.\n\t *\n\t * Calling this method will return the specified fields of the updated rows. If no fields are specified, all fields will be returned.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/update#update-with-returning}\n\t *\n\t * @example\n\t * ```ts\n\t * // Update all cars with the green color and return all fields\n\t * const updatedCars: Car[] = await db.update(cars)\n\t * .set({ color: 'red' })\n\t * .where(eq(cars.color, 'green'))\n\t * .returning();\n\t *\n\t * // Update all cars with the green color and return only their id and brand fields\n\t * const updatedCarsIdsAndBrands: { id: number, brand: string }[] = await db.update(cars)\n\t * .set({ color: 'red' })\n\t * .where(eq(cars.color, 'green'))\n\t * .returning({ id: cars.id, brand: cars.brand });\n\t * ```\n\t */\n\treturning(): GelUpdateReturningAll<this, TDynamic>;\n\treturning<TSelectedFields extends SelectedFields>(\n\t\tfields: TSelectedFields,\n\t): GelUpdateReturning<this, TDynamic, TSelectedFields>;\n\treturning(\n\t\tfields?: SelectedFields,\n\t): GelUpdateWithout<AnyGelUpdate, TDynamic, 'returning'> {\n\t\tif (!fields) {\n\t\t\tfields = Object.assign({}, this.config.table[Table.Symbol.Columns]);\n\n\t\t\tif (this.config.from) {\n\t\t\t\tconst tableName = getTableLikeName(this.config.from);\n\n\t\t\t\tif (typeof tableName === 'string' && this.config.from && !is(this.config.from, SQL)) {\n\t\t\t\t\tconst fromFields = this.getTableLikeFields(this.config.from);\n\t\t\t\t\tfields[tableName] = fromFields as any;\n\t\t\t\t}\n\n\t\t\t\tfor (const join of this.config.joins) {\n\t\t\t\t\tconst tableName = getTableLikeName(join.table);\n\n\t\t\t\t\tif (typeof tableName === 'string' && !is(join.table, SQL)) {\n\t\t\t\t\t\tconst fromFields = this.getTableLikeFields(join.table);\n\t\t\t\t\t\tfields[tableName] = fromFields as any;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthis.config.returning = orderSelectedFields<GelColumn>(fields);\n\t\treturn this as any;\n\t}\n\n\t/** @internal */\n\tgetSQL(): SQL {\n\t\treturn this.dialect.buildUpdateQuery(this.config);\n\t}\n\n\ttoSQL(): Query {\n\t\tconst { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n\t\treturn rest;\n\t}\n\n\t/** @internal */\n\t_prepare(name?: string, generateName = false): GelUpdatePrepare<this> {\n\t\tconst query = this.dialect.sqlToQuery(this.getSQL());\n\t\tconst preparedQuery = this.session.prepareQuery<\n\t\t\tPreparedQueryConfig & { execute: TReturning[] }\n\t\t>(\n\t\t\tquery,\n\t\t\tthis.config.returning,\n\t\t\tname ?? (generateName ? preparedStatementName(query.sql, query.params) : name),\n\t\t\tundefined,\n\t\t\t{\n\t\t\t\ttype: 'update',\n\t\t\t\ttables: extractUsedTable(this.config.table),\n\t\t\t},\n\t\t);\n\t\tpreparedQuery.joinsNotNullableMap = this.joinsNotNullableMap;\n\t\treturn preparedQuery;\n\t}\n\n\tprepare(name?: string): GelUpdatePrepare<this> {\n\t\treturn this._prepare(name, true);\n\t}\n\n\toverride execute: ReturnType<this['prepare']>['execute'] = (placeholderValues) => {\n\t\treturn this._prepare().execute(placeholderValues);\n\t};\n\n\t$dynamic(): GelUpdateDynamic<this> {\n\t\treturn this as any;\n\t}\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"update.cjs","names":["entityKind","QueryPromise","GelTable","Table","Subquery","ViewBaseConfig","SQL","SelectionProxyHandler","extractUsedTable"],"sources":["../../../src/gel-core/query-builders/update.ts"],"sourcesContent":["import type { GetColumnData } from '~/column.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport type { GelDialect } from '~/gel-core/dialect.ts';\nimport type {\n\tGelPreparedQuery,\n\tGelQueryResultHKT,\n\tGelQueryResultKind,\n\tGelSession,\n\tPreparedQueryConfig,\n} from '~/gel-core/session.ts';\nimport { GelTable } from '~/gel-core/table.ts';\nimport type {\n\tAppendToNullabilityMap,\n\tAppendToResult,\n\tGetSelectTableName,\n\tGetSelectTableSelection,\n\tJoinNullability,\n\tJoinType,\n\tSelectMode,\n\tSelectResult,\n} from '~/query-builders/select.types.ts';\nimport { preparedStatementName } from '~/query-name-generator.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport { type ColumnsSelection, type Placeholder, type Query, SQL, type SQLWrapper } from '~/sql/sql.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { type InferInsertModel, Table } from '~/table.ts';\nimport { type Assume, getTableLikeName, mapUpdateSet, orderSelectedFields, type UpdateSet } from '~/utils.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport type { GelColumn } from '../columns/common.ts';\nimport { extractUsedTable } from '../utils.ts';\nimport type { GelViewBase } from '../view-base.ts';\nimport type { GelSelectJoinConfig, SelectedFields, SelectedFieldsOrdered } from './select.types.ts';\n\nexport interface GelUpdateConfig {\n\twhere?: SQL | undefined;\n\tset: UpdateSet;\n\ttable: GelTable;\n\tfrom?: GelTable | Subquery | GelViewBase | SQL;\n\tjoins: GelSelectJoinConfig[];\n\treturning?: SelectedFieldsOrdered;\n\twithList?: Subquery[];\n}\n\nexport type GelUpdateSetSource<\n\tTTable extends GelTable,\n\tTModel extends Record<string, any> = InferInsertModel<TTable>,\n> =\n\t& {\n\t\t[Key in keyof TModel & string]?:\n\t\t\t| GetColumnData<TTable['_']['columns'][Key]>\n\t\t\t| SQL\n\t\t\t| Placeholder\n\t\t\t| GelColumn\n\t\t\t| undefined;\n\t}\n\t& {};\n\nexport class GelUpdateBuilder<TTable extends GelTable, TQueryResult extends GelQueryResultHKT> {\n\tstatic readonly [entityKind]: string = 'GelUpdateBuilder';\n\n\tdeclare readonly _: {\n\t\treadonly table: TTable;\n\t};\n\n\tconstructor(\n\t\tprivate table: TTable,\n\t\tprivate session: GelSession,\n\t\tprivate dialect: GelDialect,\n\t\tprivate withList?: Subquery[],\n\t) {}\n\n\tset(\n\t\tvalues: GelUpdateSetSource<TTable>,\n\t): GelUpdateWithout<GelUpdateBase<TTable, TQueryResult>, false, 'leftJoin' | 'rightJoin' | 'innerJoin' | 'fullJoin'> {\n\t\treturn new GelUpdateBase<TTable, TQueryResult>(\n\t\t\tthis.table,\n\t\t\tmapUpdateSet(this.table, values),\n\t\t\tthis.session,\n\t\t\tthis.dialect,\n\t\t\tthis.withList,\n\t\t);\n\t}\n}\n\nexport type GelUpdateWithout<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tK extends keyof T & string,\n> = TDynamic extends true ? T : Omit<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tT['_']['from'],\n\t\tT['_']['returning'],\n\t\tT['_']['nullabilityMap'],\n\t\tT['_']['joins'],\n\t\tTDynamic,\n\t\tT['_']['excludedMethods'] | K\n\t>,\n\tT['_']['excludedMethods'] | K\n>;\n\nexport type GelUpdateWithJoins<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL,\n> = TDynamic extends true ? T : Omit<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tTFrom,\n\t\tT['_']['returning'],\n\t\tAppendToNullabilityMap<T['_']['nullabilityMap'], GetSelectTableName<TFrom>, 'inner'>,\n\t\t[...T['_']['joins'], {\n\t\t\tname: GetSelectTableName<TFrom>;\n\t\t\tjoinType: 'inner';\n\t\t\ttable: TFrom;\n\t\t}],\n\t\tTDynamic,\n\t\tExclude<T['_']['excludedMethods'] | 'from', 'leftJoin' | 'rightJoin' | 'innerJoin' | 'fullJoin'>\n\t>,\n\tExclude<T['_']['excludedMethods'] | 'from', 'leftJoin' | 'rightJoin' | 'innerJoin' | 'fullJoin'>\n>;\n\nexport type GelUpdateJoinFn<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTJoinType extends JoinType,\n> = <\n\tTJoinedTable extends GelTable | Subquery | GelViewBase | SQL,\n>(\n\ttable: TJoinedTable,\n\ton:\n\t\t| (\n\t\t\t(\n\t\t\t\tupdateTable: T['_']['table']['_']['columns'],\n\t\t\t\tfrom: T['_']['from'] extends GelTable ? T['_']['from']['_']['columns']\n\t\t\t\t\t: T['_']['from'] extends Subquery | GelViewBase ? T['_']['from']['_']['selectedFields']\n\t\t\t\t\t: never,\n\t\t\t) => SQL | undefined\n\t\t)\n\t\t| SQL\n\t\t| undefined,\n) => GelUpdateJoin<T, TDynamic, TJoinType, TJoinedTable>;\n\nexport type GelUpdateJoin<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTJoinType extends JoinType,\n\tTJoinedTable extends GelTable | Subquery | GelViewBase | SQL,\n> = TDynamic extends true ? T : GelUpdateBase<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['from'],\n\tT['_']['returning'],\n\tAppendToNullabilityMap<T['_']['nullabilityMap'], GetSelectTableName<TJoinedTable>, TJoinType>,\n\t[...T['_']['joins'], {\n\t\tname: GetSelectTableName<TJoinedTable>;\n\t\tjoinType: TJoinType;\n\t\ttable: TJoinedTable;\n\t}],\n\tTDynamic,\n\tT['_']['excludedMethods']\n>;\n\ntype Join = {\n\tname: string | undefined;\n\tjoinType: JoinType;\n\ttable: GelTable | Subquery | GelViewBase | SQL;\n};\n\ntype AccumulateToResult<\n\tT extends AnyGelUpdate,\n\tTSelectMode extends SelectMode,\n\tTJoins extends Join[],\n\tTSelectedFields extends ColumnsSelection,\n> = TJoins extends [infer TJoin extends Join, ...infer TRest extends Join[]] ? AccumulateToResult<\n\t\tT,\n\t\tTSelectMode extends 'partial' ? TSelectMode : 'multiple',\n\t\tTRest,\n\t\tAppendToResult<\n\t\t\tT['_']['table']['_']['name'],\n\t\t\tTSelectedFields,\n\t\t\tTJoin['name'],\n\t\t\tTJoin['table'] extends Table ? TJoin['table']['_']['columns']\n\t\t\t\t: TJoin['table'] extends Subquery ? Assume<TJoin['table']['_']['selectedFields'], SelectedFields>\n\t\t\t\t: never,\n\t\t\tTSelectMode extends 'partial' ? TSelectMode : 'multiple'\n\t\t>\n\t>\n\t: TSelectedFields;\n\nexport type GelUpdateReturningAll<T extends AnyGelUpdate, TDynamic extends boolean> = GelUpdateWithout<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tT['_']['from'],\n\t\tSelectResult<\n\t\t\tAccumulateToResult<\n\t\t\t\tT,\n\t\t\t\t'single',\n\t\t\t\tT['_']['joins'],\n\t\t\t\tGetSelectTableSelection<T['_']['table']>\n\t\t\t>,\n\t\t\t'partial',\n\t\t\tT['_']['nullabilityMap']\n\t\t>,\n\t\tT['_']['nullabilityMap'],\n\t\tT['_']['joins'],\n\t\tTDynamic,\n\t\tT['_']['excludedMethods']\n\t>,\n\tTDynamic,\n\t'returning'\n>;\n\nexport type GelUpdateReturning<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTSelectedFields extends SelectedFields,\n> = GelUpdateWithout<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tT['_']['from'],\n\t\tSelectResult<\n\t\t\tAccumulateToResult<\n\t\t\t\tT,\n\t\t\t\t'partial',\n\t\t\t\tT['_']['joins'],\n\t\t\t\tTSelectedFields\n\t\t\t>,\n\t\t\t'partial',\n\t\t\tT['_']['nullabilityMap']\n\t\t>,\n\t\tT['_']['nullabilityMap'],\n\t\tT['_']['joins'],\n\t\tTDynamic,\n\t\tT['_']['excludedMethods']\n\t>,\n\tTDynamic,\n\t'returning'\n>;\n\nexport type GelUpdatePrepare<T extends AnyGelUpdate> = GelPreparedQuery<\n\tPreparedQueryConfig & {\n\t\texecute: T['_']['returning'] extends undefined ? GelQueryResultKind<T['_']['queryResult'], never>\n\t\t\t: T['_']['returning'][];\n\t}\n>;\n\nexport type GelUpdateDynamic<T extends AnyGelUpdate> = GelUpdate<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['from'],\n\tT['_']['returning'],\n\tT['_']['nullabilityMap']\n>;\n\nexport type GelUpdate<\n\tTTable extends GelTable = GelTable,\n\tTQueryResult extends GelQueryResultHKT = GelQueryResultHKT,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL | undefined = undefined,\n\tTReturning extends Record<string, unknown> | undefined = Record<string, unknown> | undefined,\n\tTNullabilityMap extends Record<string, JoinNullability> = Record<TTable['_']['name'], 'not-null'>,\n\tTJoins extends Join[] = [],\n> = GelUpdateBase<TTable, TQueryResult, TFrom, TReturning, TNullabilityMap, TJoins, true, never>;\n\nexport type AnyGelUpdate = GelUpdateBase<any, any, any, any, any, any, any, any>;\n\nexport interface GelUpdateBase<\n\tTTable extends GelTable,\n\tTQueryResult extends GelQueryResultHKT,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL | undefined = undefined,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\tTNullabilityMap extends Record<string, JoinNullability> = Record<TTable['_']['name'], 'not-null'>,\n\tTJoins extends Join[] = [],\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n> extends\n\tQueryPromise<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[]>,\n\tRunnableQuery<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[], 'gel'>,\n\tSQLWrapper\n{\n\treadonly _: {\n\t\treadonly dialect: 'gel';\n\t\treadonly table: TTable;\n\t\treadonly joins: TJoins;\n\t\treadonly nullabilityMap: TNullabilityMap;\n\t\treadonly queryResult: TQueryResult;\n\t\treadonly from: TFrom;\n\t\treadonly returning: TReturning;\n\t\treadonly dynamic: TDynamic;\n\t\treadonly excludedMethods: TExcludedMethods;\n\t\treadonly result: TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[];\n\t};\n}\n\nexport class GelUpdateBase<\n\tTTable extends GelTable,\n\tTQueryResult extends GelQueryResultHKT,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL | undefined = undefined,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTNullabilityMap extends Record<string, JoinNullability> = Record<TTable['_']['name'], 'not-null'>,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTJoins extends Join[] = [],\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTDynamic extends boolean = false,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTExcludedMethods extends string = never,\n> extends QueryPromise<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[]>\n\timplements\n\t\tRunnableQuery<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[], 'gel'>,\n\t\tSQLWrapper\n{\n\tstatic override readonly [entityKind]: string = 'GelUpdate';\n\n\tprivate config: GelUpdateConfig;\n\tprivate tableName: string | undefined;\n\tprivate joinsNotNullableMap: Record<string, boolean>;\n\n\tconstructor(\n\t\ttable: TTable,\n\t\tset: UpdateSet,\n\t\tprivate session: GelSession,\n\t\tprivate dialect: GelDialect,\n\t\twithList?: Subquery[],\n\t) {\n\t\tsuper();\n\t\tthis.config = { set, table, withList, joins: [] };\n\t\tthis.tableName = getTableLikeName(table);\n\t\tthis.joinsNotNullableMap = typeof this.tableName === 'string' ? { [this.tableName]: true } : {};\n\t}\n\n\tfrom<TFrom extends GelTable | Subquery | GelViewBase | SQL>(\n\t\tsource: TFrom,\n\t): GelUpdateWithJoins<this, TDynamic, TFrom> {\n\t\tconst tableName = getTableLikeName(source);\n\t\tif (typeof tableName === 'string') {\n\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t}\n\t\tthis.config.from = source;\n\t\treturn this as any;\n\t}\n\n\tprivate getTableLikeFields(table: GelTable | Subquery | GelViewBase): Record<string, unknown> {\n\t\tif (is(table, GelTable)) {\n\t\t\treturn table[Table.Symbol.Columns];\n\t\t} else if (is(table, Subquery)) {\n\t\t\treturn table._.selectedFields;\n\t\t}\n\t\treturn table[ViewBaseConfig].selectedFields;\n\t}\n\n\tprivate createJoin<TJoinType extends JoinType>(\n\t\tjoinType: TJoinType,\n\t): GelUpdateJoinFn<this, TDynamic, TJoinType> {\n\t\treturn ((\n\t\t\ttable: GelTable | Subquery | GelViewBase | SQL,\n\t\t\ton: ((updateTable: TTable, from: TFrom) => SQL | undefined) | SQL | undefined,\n\t\t) => {\n\t\t\tconst tableName = getTableLikeName(table);\n\n\t\t\tif (typeof tableName === 'string' && this.config.joins.some((join) => join.alias === tableName)) {\n\t\t\t\tthrow new Error(`Alias \"${tableName}\" is already used in this query`);\n\t\t\t}\n\n\t\t\tif (typeof on === 'function') {\n\t\t\t\tconst from = this.config.from && !is(this.config.from, SQL)\n\t\t\t\t\t? this.getTableLikeFields(this.config.from)\n\t\t\t\t\t: undefined;\n\t\t\t\ton = on(\n\t\t\t\t\tnew Proxy(\n\t\t\t\t\t\tthis.config.table[Table.Symbol.Columns],\n\t\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t\t) as any,\n\t\t\t\t\tfrom && new Proxy(\n\t\t\t\t\t\tfrom,\n\t\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t\t) as any,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tthis.config.joins.push({ on, table, joinType, alias: tableName });\n\n\t\t\tif (typeof tableName === 'string') {\n\t\t\t\tswitch (joinType) {\n\t\t\t\t\tcase 'left': {\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = false;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'right': {\n\t\t\t\t\t\tthis.joinsNotNullableMap = Object.fromEntries(\n\t\t\t\t\t\t\tObject.entries(this.joinsNotNullableMap).map(([key]) => [key, false]),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'inner': {\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'full': {\n\t\t\t\t\t\tthis.joinsNotNullableMap = Object.fromEntries(\n\t\t\t\t\t\t\tObject.entries(this.joinsNotNullableMap).map(([key]) => [key, false]),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = false;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn this as any;\n\t\t}) as any;\n\t}\n\n\tleftJoin = this.createJoin('left');\n\n\trightJoin = this.createJoin('right');\n\n\tinnerJoin = this.createJoin('inner');\n\n\tfullJoin = this.createJoin('full');\n\n\t/**\n\t * Adds a 'where' clause to the query.\n\t *\n\t * Calling this method will update only those rows that fulfill a specified condition.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/update}\n\t *\n\t * @param where the 'where' clause.\n\t *\n\t * @example\n\t * You can use conditional operators and `sql function` to filter the rows to be updated.\n\t *\n\t * ```ts\n\t * // Update all cars with green color\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(eq(cars.color, 'green'));\n\t * // or\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(sql`${cars.color} = 'green'`)\n\t * ```\n\t *\n\t * You can logically combine conditional operators with `and()` and `or()` operators:\n\t *\n\t * ```ts\n\t * // Update all BMW cars with a green color\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n\t *\n\t * // Update all cars with the green or blue color\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n\t * ```\n\t */\n\twhere(where: SQL | undefined): GelUpdateWithout<this, TDynamic, 'where'> {\n\t\tthis.config.where = where;\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `returning` clause to the query.\n\t *\n\t * Calling this method will return the specified fields of the updated rows. If no fields are specified, all fields will be returned.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/update#update-with-returning}\n\t *\n\t * @example\n\t * ```ts\n\t * // Update all cars with the green color and return all fields\n\t * const updatedCars: Car[] = await db.update(cars)\n\t * .set({ color: 'red' })\n\t * .where(eq(cars.color, 'green'))\n\t * .returning();\n\t *\n\t * // Update all cars with the green color and return only their id and brand fields\n\t * const updatedCarsIdsAndBrands: { id: number, brand: string }[] = await db.update(cars)\n\t * .set({ color: 'red' })\n\t * .where(eq(cars.color, 'green'))\n\t * .returning({ id: cars.id, brand: cars.brand });\n\t * ```\n\t */\n\treturning(): GelUpdateReturningAll<this, TDynamic>;\n\treturning<TSelectedFields extends SelectedFields>(\n\t\tfields: TSelectedFields,\n\t): GelUpdateReturning<this, TDynamic, TSelectedFields>;\n\treturning(\n\t\tfields?: SelectedFields,\n\t): GelUpdateWithout<AnyGelUpdate, TDynamic, 'returning'> {\n\t\tif (!fields) {\n\t\t\tfields = Object.assign({}, this.config.table[Table.Symbol.Columns]);\n\n\t\t\tif (this.config.from) {\n\t\t\t\tconst tableName = getTableLikeName(this.config.from);\n\n\t\t\t\tif (typeof tableName === 'string' && this.config.from && !is(this.config.from, SQL)) {\n\t\t\t\t\tconst fromFields = this.getTableLikeFields(this.config.from);\n\t\t\t\t\tfields[tableName] = fromFields as any;\n\t\t\t\t}\n\n\t\t\t\tfor (const join of this.config.joins) {\n\t\t\t\t\tconst tableName = getTableLikeName(join.table);\n\n\t\t\t\t\tif (typeof tableName === 'string' && !is(join.table, SQL)) {\n\t\t\t\t\t\tconst fromFields = this.getTableLikeFields(join.table);\n\t\t\t\t\t\tfields[tableName] = fromFields as any;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthis.config.returning = orderSelectedFields<GelColumn>(fields);\n\t\treturn this as any;\n\t}\n\n\t/** @internal */\n\tgetSQL(): SQL {\n\t\treturn this.dialect.buildUpdateQuery(this.config);\n\t}\n\n\ttoSQL(): Query {\n\t\tconst { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n\t\treturn rest;\n\t}\n\n\t/** @internal */\n\t_prepare(name?: string, generateName = false): GelUpdatePrepare<this> {\n\t\tconst query = this.dialect.sqlToQuery(this.getSQL());\n\t\tconst preparedQuery = this.session.prepareQuery<\n\t\t\tPreparedQueryConfig & { execute: TReturning[] }\n\t\t>(\n\t\t\tquery,\n\t\t\tthis.config.returning,\n\t\t\tname ?? (generateName ? preparedStatementName(query.sql, query.params) : name),\n\t\t\ttrue,\n\t\t\tundefined,\n\t\t\t{\n\t\t\t\ttype: 'update',\n\t\t\t\ttables: extractUsedTable(this.config.table),\n\t\t\t},\n\t\t);\n\t\tpreparedQuery.joinsNotNullableMap = this.joinsNotNullableMap;\n\t\treturn preparedQuery;\n\t}\n\n\tprepare(name?: string): GelUpdatePrepare<this> {\n\t\treturn this._prepare(name, true);\n\t}\n\n\toverride execute: ReturnType<this['prepare']>['execute'] = (placeholderValues) => {\n\t\treturn this._prepare().execute(placeholderValues);\n\t};\n\n\t$dynamic(): GelUpdateDynamic<this> {\n\t\treturn this as any;\n\t}\n}\n"],"mappings":"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"}
@@ -8,9 +8,9 @@ import { GetColumnData } from "../../column.js";
8
8
  import { Assume, UpdateSet } from "../../utils.js";
9
9
  import { ColumnsSelection, Placeholder, Query, SQL, SQLWrapper } from "../../sql/sql.js";
10
10
  import { QueryPromise } from "../../query-promise.js";
11
- import { GelPreparedQuery, GelQueryResultHKT, GelQueryResultKind, GelSession, PreparedQueryConfig } from "../session.js";
12
- import { GelDialect } from "../dialect.js";
13
11
  import { GelTable } from "../table.js";
12
+ import { GelDialect } from "../dialect.js";
13
+ import { GelPreparedQuery, GelQueryResultHKT, GelQueryResultKind, GelSession, PreparedQueryConfig } from "../session.js";
14
14
  import { AppendToNullabilityMap, AppendToResult, GetSelectTableName, GetSelectTableSelection, JoinNullability, JoinType, SelectMode, SelectResult } from "../../query-builders/select.types.js";
15
15
  import { RunnableQuery } from "../../runnable-query.js";
16
16
 
@@ -164,7 +164,7 @@ var GelUpdateBase = class extends QueryPromise {
164
164
  /** @internal */
165
165
  _prepare(name, generateName = false) {
166
166
  const query = this.dialect.sqlToQuery(this.getSQL());
167
- const preparedQuery = this.session.prepareQuery(query, this.config.returning, name ?? (generateName ? preparedStatementName(query.sql, query.params) : name), void 0, {
167
+ const preparedQuery = this.session.prepareQuery(query, this.config.returning, name ?? (generateName ? preparedStatementName(query.sql, query.params) : name), true, void 0, {
168
168
  type: "update",
169
169
  tables: extractUsedTable(this.config.table)
170
170
  });
@@ -1 +1 @@
1
- {"version":3,"file":"update.js","names":[],"sources":["../../../src/gel-core/query-builders/update.ts"],"sourcesContent":["import type { GetColumnData } from '~/column.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport type { GelDialect } from '~/gel-core/dialect.ts';\nimport type {\n\tGelPreparedQuery,\n\tGelQueryResultHKT,\n\tGelQueryResultKind,\n\tGelSession,\n\tPreparedQueryConfig,\n} from '~/gel-core/session.ts';\nimport { GelTable } from '~/gel-core/table.ts';\nimport type {\n\tAppendToNullabilityMap,\n\tAppendToResult,\n\tGetSelectTableName,\n\tGetSelectTableSelection,\n\tJoinNullability,\n\tJoinType,\n\tSelectMode,\n\tSelectResult,\n} from '~/query-builders/select.types.ts';\nimport { preparedStatementName } from '~/query-name-generator.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport { type ColumnsSelection, type Placeholder, type Query, SQL, type SQLWrapper } from '~/sql/sql.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { type InferInsertModel, Table } from '~/table.ts';\nimport { type Assume, getTableLikeName, mapUpdateSet, orderSelectedFields, type UpdateSet } from '~/utils.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport type { GelColumn } from '../columns/common.ts';\nimport { extractUsedTable } from '../utils.ts';\nimport type { GelViewBase } from '../view-base.ts';\nimport type { GelSelectJoinConfig, SelectedFields, SelectedFieldsOrdered } from './select.types.ts';\n\nexport interface GelUpdateConfig {\n\twhere?: SQL | undefined;\n\tset: UpdateSet;\n\ttable: GelTable;\n\tfrom?: GelTable | Subquery | GelViewBase | SQL;\n\tjoins: GelSelectJoinConfig[];\n\treturning?: SelectedFieldsOrdered;\n\twithList?: Subquery[];\n}\n\nexport type GelUpdateSetSource<\n\tTTable extends GelTable,\n\tTModel extends Record<string, any> = InferInsertModel<TTable>,\n> =\n\t& {\n\t\t[Key in keyof TModel & string]?:\n\t\t\t| GetColumnData<TTable['_']['columns'][Key]>\n\t\t\t| SQL\n\t\t\t| Placeholder\n\t\t\t| GelColumn\n\t\t\t| undefined;\n\t}\n\t& {};\n\nexport class GelUpdateBuilder<TTable extends GelTable, TQueryResult extends GelQueryResultHKT> {\n\tstatic readonly [entityKind]: string = 'GelUpdateBuilder';\n\n\tdeclare readonly _: {\n\t\treadonly table: TTable;\n\t};\n\n\tconstructor(\n\t\tprivate table: TTable,\n\t\tprivate session: GelSession,\n\t\tprivate dialect: GelDialect,\n\t\tprivate withList?: Subquery[],\n\t) {}\n\n\tset(\n\t\tvalues: GelUpdateSetSource<TTable>,\n\t): GelUpdateWithout<GelUpdateBase<TTable, TQueryResult>, false, 'leftJoin' | 'rightJoin' | 'innerJoin' | 'fullJoin'> {\n\t\treturn new GelUpdateBase<TTable, TQueryResult>(\n\t\t\tthis.table,\n\t\t\tmapUpdateSet(this.table, values),\n\t\t\tthis.session,\n\t\t\tthis.dialect,\n\t\t\tthis.withList,\n\t\t);\n\t}\n}\n\nexport type GelUpdateWithout<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tK extends keyof T & string,\n> = TDynamic extends true ? T : Omit<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tT['_']['from'],\n\t\tT['_']['returning'],\n\t\tT['_']['nullabilityMap'],\n\t\tT['_']['joins'],\n\t\tTDynamic,\n\t\tT['_']['excludedMethods'] | K\n\t>,\n\tT['_']['excludedMethods'] | K\n>;\n\nexport type GelUpdateWithJoins<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL,\n> = TDynamic extends true ? T : Omit<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tTFrom,\n\t\tT['_']['returning'],\n\t\tAppendToNullabilityMap<T['_']['nullabilityMap'], GetSelectTableName<TFrom>, 'inner'>,\n\t\t[...T['_']['joins'], {\n\t\t\tname: GetSelectTableName<TFrom>;\n\t\t\tjoinType: 'inner';\n\t\t\ttable: TFrom;\n\t\t}],\n\t\tTDynamic,\n\t\tExclude<T['_']['excludedMethods'] | 'from', 'leftJoin' | 'rightJoin' | 'innerJoin' | 'fullJoin'>\n\t>,\n\tExclude<T['_']['excludedMethods'] | 'from', 'leftJoin' | 'rightJoin' | 'innerJoin' | 'fullJoin'>\n>;\n\nexport type GelUpdateJoinFn<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTJoinType extends JoinType,\n> = <\n\tTJoinedTable extends GelTable | Subquery | GelViewBase | SQL,\n>(\n\ttable: TJoinedTable,\n\ton:\n\t\t| (\n\t\t\t(\n\t\t\t\tupdateTable: T['_']['table']['_']['columns'],\n\t\t\t\tfrom: T['_']['from'] extends GelTable ? T['_']['from']['_']['columns']\n\t\t\t\t\t: T['_']['from'] extends Subquery | GelViewBase ? T['_']['from']['_']['selectedFields']\n\t\t\t\t\t: never,\n\t\t\t) => SQL | undefined\n\t\t)\n\t\t| SQL\n\t\t| undefined,\n) => GelUpdateJoin<T, TDynamic, TJoinType, TJoinedTable>;\n\nexport type GelUpdateJoin<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTJoinType extends JoinType,\n\tTJoinedTable extends GelTable | Subquery | GelViewBase | SQL,\n> = TDynamic extends true ? T : GelUpdateBase<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['from'],\n\tT['_']['returning'],\n\tAppendToNullabilityMap<T['_']['nullabilityMap'], GetSelectTableName<TJoinedTable>, TJoinType>,\n\t[...T['_']['joins'], {\n\t\tname: GetSelectTableName<TJoinedTable>;\n\t\tjoinType: TJoinType;\n\t\ttable: TJoinedTable;\n\t}],\n\tTDynamic,\n\tT['_']['excludedMethods']\n>;\n\ntype Join = {\n\tname: string | undefined;\n\tjoinType: JoinType;\n\ttable: GelTable | Subquery | GelViewBase | SQL;\n};\n\ntype AccumulateToResult<\n\tT extends AnyGelUpdate,\n\tTSelectMode extends SelectMode,\n\tTJoins extends Join[],\n\tTSelectedFields extends ColumnsSelection,\n> = TJoins extends [infer TJoin extends Join, ...infer TRest extends Join[]] ? AccumulateToResult<\n\t\tT,\n\t\tTSelectMode extends 'partial' ? TSelectMode : 'multiple',\n\t\tTRest,\n\t\tAppendToResult<\n\t\t\tT['_']['table']['_']['name'],\n\t\t\tTSelectedFields,\n\t\t\tTJoin['name'],\n\t\t\tTJoin['table'] extends Table ? TJoin['table']['_']['columns']\n\t\t\t\t: TJoin['table'] extends Subquery ? Assume<TJoin['table']['_']['selectedFields'], SelectedFields>\n\t\t\t\t: never,\n\t\t\tTSelectMode extends 'partial' ? TSelectMode : 'multiple'\n\t\t>\n\t>\n\t: TSelectedFields;\n\nexport type GelUpdateReturningAll<T extends AnyGelUpdate, TDynamic extends boolean> = GelUpdateWithout<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tT['_']['from'],\n\t\tSelectResult<\n\t\t\tAccumulateToResult<\n\t\t\t\tT,\n\t\t\t\t'single',\n\t\t\t\tT['_']['joins'],\n\t\t\t\tGetSelectTableSelection<T['_']['table']>\n\t\t\t>,\n\t\t\t'partial',\n\t\t\tT['_']['nullabilityMap']\n\t\t>,\n\t\tT['_']['nullabilityMap'],\n\t\tT['_']['joins'],\n\t\tTDynamic,\n\t\tT['_']['excludedMethods']\n\t>,\n\tTDynamic,\n\t'returning'\n>;\n\nexport type GelUpdateReturning<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTSelectedFields extends SelectedFields,\n> = GelUpdateWithout<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tT['_']['from'],\n\t\tSelectResult<\n\t\t\tAccumulateToResult<\n\t\t\t\tT,\n\t\t\t\t'partial',\n\t\t\t\tT['_']['joins'],\n\t\t\t\tTSelectedFields\n\t\t\t>,\n\t\t\t'partial',\n\t\t\tT['_']['nullabilityMap']\n\t\t>,\n\t\tT['_']['nullabilityMap'],\n\t\tT['_']['joins'],\n\t\tTDynamic,\n\t\tT['_']['excludedMethods']\n\t>,\n\tTDynamic,\n\t'returning'\n>;\n\nexport type GelUpdatePrepare<T extends AnyGelUpdate> = GelPreparedQuery<\n\tPreparedQueryConfig & {\n\t\texecute: T['_']['returning'] extends undefined ? GelQueryResultKind<T['_']['queryResult'], never>\n\t\t\t: T['_']['returning'][];\n\t}\n>;\n\nexport type GelUpdateDynamic<T extends AnyGelUpdate> = GelUpdate<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['from'],\n\tT['_']['returning'],\n\tT['_']['nullabilityMap']\n>;\n\nexport type GelUpdate<\n\tTTable extends GelTable = GelTable,\n\tTQueryResult extends GelQueryResultHKT = GelQueryResultHKT,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL | undefined = undefined,\n\tTReturning extends Record<string, unknown> | undefined = Record<string, unknown> | undefined,\n\tTNullabilityMap extends Record<string, JoinNullability> = Record<TTable['_']['name'], 'not-null'>,\n\tTJoins extends Join[] = [],\n> = GelUpdateBase<TTable, TQueryResult, TFrom, TReturning, TNullabilityMap, TJoins, true, never>;\n\nexport type AnyGelUpdate = GelUpdateBase<any, any, any, any, any, any, any, any>;\n\nexport interface GelUpdateBase<\n\tTTable extends GelTable,\n\tTQueryResult extends GelQueryResultHKT,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL | undefined = undefined,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\tTNullabilityMap extends Record<string, JoinNullability> = Record<TTable['_']['name'], 'not-null'>,\n\tTJoins extends Join[] = [],\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n> extends\n\tQueryPromise<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[]>,\n\tRunnableQuery<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[], 'gel'>,\n\tSQLWrapper\n{\n\treadonly _: {\n\t\treadonly dialect: 'gel';\n\t\treadonly table: TTable;\n\t\treadonly joins: TJoins;\n\t\treadonly nullabilityMap: TNullabilityMap;\n\t\treadonly queryResult: TQueryResult;\n\t\treadonly from: TFrom;\n\t\treadonly returning: TReturning;\n\t\treadonly dynamic: TDynamic;\n\t\treadonly excludedMethods: TExcludedMethods;\n\t\treadonly result: TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[];\n\t};\n}\n\nexport class GelUpdateBase<\n\tTTable extends GelTable,\n\tTQueryResult extends GelQueryResultHKT,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL | undefined = undefined,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTNullabilityMap extends Record<string, JoinNullability> = Record<TTable['_']['name'], 'not-null'>,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTJoins extends Join[] = [],\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTDynamic extends boolean = false,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTExcludedMethods extends string = never,\n> extends QueryPromise<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[]>\n\timplements\n\t\tRunnableQuery<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[], 'gel'>,\n\t\tSQLWrapper\n{\n\tstatic override readonly [entityKind]: string = 'GelUpdate';\n\n\tprivate config: GelUpdateConfig;\n\tprivate tableName: string | undefined;\n\tprivate joinsNotNullableMap: Record<string, boolean>;\n\n\tconstructor(\n\t\ttable: TTable,\n\t\tset: UpdateSet,\n\t\tprivate session: GelSession,\n\t\tprivate dialect: GelDialect,\n\t\twithList?: Subquery[],\n\t) {\n\t\tsuper();\n\t\tthis.config = { set, table, withList, joins: [] };\n\t\tthis.tableName = getTableLikeName(table);\n\t\tthis.joinsNotNullableMap = typeof this.tableName === 'string' ? { [this.tableName]: true } : {};\n\t}\n\n\tfrom<TFrom extends GelTable | Subquery | GelViewBase | SQL>(\n\t\tsource: TFrom,\n\t): GelUpdateWithJoins<this, TDynamic, TFrom> {\n\t\tconst tableName = getTableLikeName(source);\n\t\tif (typeof tableName === 'string') {\n\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t}\n\t\tthis.config.from = source;\n\t\treturn this as any;\n\t}\n\n\tprivate getTableLikeFields(table: GelTable | Subquery | GelViewBase): Record<string, unknown> {\n\t\tif (is(table, GelTable)) {\n\t\t\treturn table[Table.Symbol.Columns];\n\t\t} else if (is(table, Subquery)) {\n\t\t\treturn table._.selectedFields;\n\t\t}\n\t\treturn table[ViewBaseConfig].selectedFields;\n\t}\n\n\tprivate createJoin<TJoinType extends JoinType>(\n\t\tjoinType: TJoinType,\n\t): GelUpdateJoinFn<this, TDynamic, TJoinType> {\n\t\treturn ((\n\t\t\ttable: GelTable | Subquery | GelViewBase | SQL,\n\t\t\ton: ((updateTable: TTable, from: TFrom) => SQL | undefined) | SQL | undefined,\n\t\t) => {\n\t\t\tconst tableName = getTableLikeName(table);\n\n\t\t\tif (typeof tableName === 'string' && this.config.joins.some((join) => join.alias === tableName)) {\n\t\t\t\tthrow new Error(`Alias \"${tableName}\" is already used in this query`);\n\t\t\t}\n\n\t\t\tif (typeof on === 'function') {\n\t\t\t\tconst from = this.config.from && !is(this.config.from, SQL)\n\t\t\t\t\t? this.getTableLikeFields(this.config.from)\n\t\t\t\t\t: undefined;\n\t\t\t\ton = on(\n\t\t\t\t\tnew Proxy(\n\t\t\t\t\t\tthis.config.table[Table.Symbol.Columns],\n\t\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t\t) as any,\n\t\t\t\t\tfrom && new Proxy(\n\t\t\t\t\t\tfrom,\n\t\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t\t) as any,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tthis.config.joins.push({ on, table, joinType, alias: tableName });\n\n\t\t\tif (typeof tableName === 'string') {\n\t\t\t\tswitch (joinType) {\n\t\t\t\t\tcase 'left': {\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = false;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'right': {\n\t\t\t\t\t\tthis.joinsNotNullableMap = Object.fromEntries(\n\t\t\t\t\t\t\tObject.entries(this.joinsNotNullableMap).map(([key]) => [key, false]),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'inner': {\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'full': {\n\t\t\t\t\t\tthis.joinsNotNullableMap = Object.fromEntries(\n\t\t\t\t\t\t\tObject.entries(this.joinsNotNullableMap).map(([key]) => [key, false]),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = false;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn this as any;\n\t\t}) as any;\n\t}\n\n\tleftJoin = this.createJoin('left');\n\n\trightJoin = this.createJoin('right');\n\n\tinnerJoin = this.createJoin('inner');\n\n\tfullJoin = this.createJoin('full');\n\n\t/**\n\t * Adds a 'where' clause to the query.\n\t *\n\t * Calling this method will update only those rows that fulfill a specified condition.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/update}\n\t *\n\t * @param where the 'where' clause.\n\t *\n\t * @example\n\t * You can use conditional operators and `sql function` to filter the rows to be updated.\n\t *\n\t * ```ts\n\t * // Update all cars with green color\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(eq(cars.color, 'green'));\n\t * // or\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(sql`${cars.color} = 'green'`)\n\t * ```\n\t *\n\t * You can logically combine conditional operators with `and()` and `or()` operators:\n\t *\n\t * ```ts\n\t * // Update all BMW cars with a green color\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n\t *\n\t * // Update all cars with the green or blue color\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n\t * ```\n\t */\n\twhere(where: SQL | undefined): GelUpdateWithout<this, TDynamic, 'where'> {\n\t\tthis.config.where = where;\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `returning` clause to the query.\n\t *\n\t * Calling this method will return the specified fields of the updated rows. If no fields are specified, all fields will be returned.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/update#update-with-returning}\n\t *\n\t * @example\n\t * ```ts\n\t * // Update all cars with the green color and return all fields\n\t * const updatedCars: Car[] = await db.update(cars)\n\t * .set({ color: 'red' })\n\t * .where(eq(cars.color, 'green'))\n\t * .returning();\n\t *\n\t * // Update all cars with the green color and return only their id and brand fields\n\t * const updatedCarsIdsAndBrands: { id: number, brand: string }[] = await db.update(cars)\n\t * .set({ color: 'red' })\n\t * .where(eq(cars.color, 'green'))\n\t * .returning({ id: cars.id, brand: cars.brand });\n\t * ```\n\t */\n\treturning(): GelUpdateReturningAll<this, TDynamic>;\n\treturning<TSelectedFields extends SelectedFields>(\n\t\tfields: TSelectedFields,\n\t): GelUpdateReturning<this, TDynamic, TSelectedFields>;\n\treturning(\n\t\tfields?: SelectedFields,\n\t): GelUpdateWithout<AnyGelUpdate, TDynamic, 'returning'> {\n\t\tif (!fields) {\n\t\t\tfields = Object.assign({}, this.config.table[Table.Symbol.Columns]);\n\n\t\t\tif (this.config.from) {\n\t\t\t\tconst tableName = getTableLikeName(this.config.from);\n\n\t\t\t\tif (typeof tableName === 'string' && this.config.from && !is(this.config.from, SQL)) {\n\t\t\t\t\tconst fromFields = this.getTableLikeFields(this.config.from);\n\t\t\t\t\tfields[tableName] = fromFields as any;\n\t\t\t\t}\n\n\t\t\t\tfor (const join of this.config.joins) {\n\t\t\t\t\tconst tableName = getTableLikeName(join.table);\n\n\t\t\t\t\tif (typeof tableName === 'string' && !is(join.table, SQL)) {\n\t\t\t\t\t\tconst fromFields = this.getTableLikeFields(join.table);\n\t\t\t\t\t\tfields[tableName] = fromFields as any;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthis.config.returning = orderSelectedFields<GelColumn>(fields);\n\t\treturn this as any;\n\t}\n\n\t/** @internal */\n\tgetSQL(): SQL {\n\t\treturn this.dialect.buildUpdateQuery(this.config);\n\t}\n\n\ttoSQL(): Query {\n\t\tconst { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n\t\treturn rest;\n\t}\n\n\t/** @internal */\n\t_prepare(name?: string, generateName = false): GelUpdatePrepare<this> {\n\t\tconst query = this.dialect.sqlToQuery(this.getSQL());\n\t\tconst preparedQuery = this.session.prepareQuery<\n\t\t\tPreparedQueryConfig & { execute: TReturning[] }\n\t\t>(\n\t\t\tquery,\n\t\t\tthis.config.returning,\n\t\t\tname ?? (generateName ? preparedStatementName(query.sql, query.params) : name),\n\t\t\tundefined,\n\t\t\t{\n\t\t\t\ttype: 'update',\n\t\t\t\ttables: extractUsedTable(this.config.table),\n\t\t\t},\n\t\t);\n\t\tpreparedQuery.joinsNotNullableMap = this.joinsNotNullableMap;\n\t\treturn preparedQuery;\n\t}\n\n\tprepare(name?: string): GelUpdatePrepare<this> {\n\t\treturn this._prepare(name, true);\n\t}\n\n\toverride execute: ReturnType<this['prepare']>['execute'] = (placeholderValues) => {\n\t\treturn this._prepare().execute(placeholderValues);\n\t};\n\n\t$dynamic(): GelUpdateDynamic<this> {\n\t\treturn this as any;\n\t}\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"update.js","names":[],"sources":["../../../src/gel-core/query-builders/update.ts"],"sourcesContent":["import type { GetColumnData } from '~/column.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport type { GelDialect } from '~/gel-core/dialect.ts';\nimport type {\n\tGelPreparedQuery,\n\tGelQueryResultHKT,\n\tGelQueryResultKind,\n\tGelSession,\n\tPreparedQueryConfig,\n} from '~/gel-core/session.ts';\nimport { GelTable } from '~/gel-core/table.ts';\nimport type {\n\tAppendToNullabilityMap,\n\tAppendToResult,\n\tGetSelectTableName,\n\tGetSelectTableSelection,\n\tJoinNullability,\n\tJoinType,\n\tSelectMode,\n\tSelectResult,\n} from '~/query-builders/select.types.ts';\nimport { preparedStatementName } from '~/query-name-generator.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport { type ColumnsSelection, type Placeholder, type Query, SQL, type SQLWrapper } from '~/sql/sql.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { type InferInsertModel, Table } from '~/table.ts';\nimport { type Assume, getTableLikeName, mapUpdateSet, orderSelectedFields, type UpdateSet } from '~/utils.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport type { GelColumn } from '../columns/common.ts';\nimport { extractUsedTable } from '../utils.ts';\nimport type { GelViewBase } from '../view-base.ts';\nimport type { GelSelectJoinConfig, SelectedFields, SelectedFieldsOrdered } from './select.types.ts';\n\nexport interface GelUpdateConfig {\n\twhere?: SQL | undefined;\n\tset: UpdateSet;\n\ttable: GelTable;\n\tfrom?: GelTable | Subquery | GelViewBase | SQL;\n\tjoins: GelSelectJoinConfig[];\n\treturning?: SelectedFieldsOrdered;\n\twithList?: Subquery[];\n}\n\nexport type GelUpdateSetSource<\n\tTTable extends GelTable,\n\tTModel extends Record<string, any> = InferInsertModel<TTable>,\n> =\n\t& {\n\t\t[Key in keyof TModel & string]?:\n\t\t\t| GetColumnData<TTable['_']['columns'][Key]>\n\t\t\t| SQL\n\t\t\t| Placeholder\n\t\t\t| GelColumn\n\t\t\t| undefined;\n\t}\n\t& {};\n\nexport class GelUpdateBuilder<TTable extends GelTable, TQueryResult extends GelQueryResultHKT> {\n\tstatic readonly [entityKind]: string = 'GelUpdateBuilder';\n\n\tdeclare readonly _: {\n\t\treadonly table: TTable;\n\t};\n\n\tconstructor(\n\t\tprivate table: TTable,\n\t\tprivate session: GelSession,\n\t\tprivate dialect: GelDialect,\n\t\tprivate withList?: Subquery[],\n\t) {}\n\n\tset(\n\t\tvalues: GelUpdateSetSource<TTable>,\n\t): GelUpdateWithout<GelUpdateBase<TTable, TQueryResult>, false, 'leftJoin' | 'rightJoin' | 'innerJoin' | 'fullJoin'> {\n\t\treturn new GelUpdateBase<TTable, TQueryResult>(\n\t\t\tthis.table,\n\t\t\tmapUpdateSet(this.table, values),\n\t\t\tthis.session,\n\t\t\tthis.dialect,\n\t\t\tthis.withList,\n\t\t);\n\t}\n}\n\nexport type GelUpdateWithout<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tK extends keyof T & string,\n> = TDynamic extends true ? T : Omit<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tT['_']['from'],\n\t\tT['_']['returning'],\n\t\tT['_']['nullabilityMap'],\n\t\tT['_']['joins'],\n\t\tTDynamic,\n\t\tT['_']['excludedMethods'] | K\n\t>,\n\tT['_']['excludedMethods'] | K\n>;\n\nexport type GelUpdateWithJoins<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL,\n> = TDynamic extends true ? T : Omit<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tTFrom,\n\t\tT['_']['returning'],\n\t\tAppendToNullabilityMap<T['_']['nullabilityMap'], GetSelectTableName<TFrom>, 'inner'>,\n\t\t[...T['_']['joins'], {\n\t\t\tname: GetSelectTableName<TFrom>;\n\t\t\tjoinType: 'inner';\n\t\t\ttable: TFrom;\n\t\t}],\n\t\tTDynamic,\n\t\tExclude<T['_']['excludedMethods'] | 'from', 'leftJoin' | 'rightJoin' | 'innerJoin' | 'fullJoin'>\n\t>,\n\tExclude<T['_']['excludedMethods'] | 'from', 'leftJoin' | 'rightJoin' | 'innerJoin' | 'fullJoin'>\n>;\n\nexport type GelUpdateJoinFn<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTJoinType extends JoinType,\n> = <\n\tTJoinedTable extends GelTable | Subquery | GelViewBase | SQL,\n>(\n\ttable: TJoinedTable,\n\ton:\n\t\t| (\n\t\t\t(\n\t\t\t\tupdateTable: T['_']['table']['_']['columns'],\n\t\t\t\tfrom: T['_']['from'] extends GelTable ? T['_']['from']['_']['columns']\n\t\t\t\t\t: T['_']['from'] extends Subquery | GelViewBase ? T['_']['from']['_']['selectedFields']\n\t\t\t\t\t: never,\n\t\t\t) => SQL | undefined\n\t\t)\n\t\t| SQL\n\t\t| undefined,\n) => GelUpdateJoin<T, TDynamic, TJoinType, TJoinedTable>;\n\nexport type GelUpdateJoin<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTJoinType extends JoinType,\n\tTJoinedTable extends GelTable | Subquery | GelViewBase | SQL,\n> = TDynamic extends true ? T : GelUpdateBase<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['from'],\n\tT['_']['returning'],\n\tAppendToNullabilityMap<T['_']['nullabilityMap'], GetSelectTableName<TJoinedTable>, TJoinType>,\n\t[...T['_']['joins'], {\n\t\tname: GetSelectTableName<TJoinedTable>;\n\t\tjoinType: TJoinType;\n\t\ttable: TJoinedTable;\n\t}],\n\tTDynamic,\n\tT['_']['excludedMethods']\n>;\n\ntype Join = {\n\tname: string | undefined;\n\tjoinType: JoinType;\n\ttable: GelTable | Subquery | GelViewBase | SQL;\n};\n\ntype AccumulateToResult<\n\tT extends AnyGelUpdate,\n\tTSelectMode extends SelectMode,\n\tTJoins extends Join[],\n\tTSelectedFields extends ColumnsSelection,\n> = TJoins extends [infer TJoin extends Join, ...infer TRest extends Join[]] ? AccumulateToResult<\n\t\tT,\n\t\tTSelectMode extends 'partial' ? TSelectMode : 'multiple',\n\t\tTRest,\n\t\tAppendToResult<\n\t\t\tT['_']['table']['_']['name'],\n\t\t\tTSelectedFields,\n\t\t\tTJoin['name'],\n\t\t\tTJoin['table'] extends Table ? TJoin['table']['_']['columns']\n\t\t\t\t: TJoin['table'] extends Subquery ? Assume<TJoin['table']['_']['selectedFields'], SelectedFields>\n\t\t\t\t: never,\n\t\t\tTSelectMode extends 'partial' ? TSelectMode : 'multiple'\n\t\t>\n\t>\n\t: TSelectedFields;\n\nexport type GelUpdateReturningAll<T extends AnyGelUpdate, TDynamic extends boolean> = GelUpdateWithout<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tT['_']['from'],\n\t\tSelectResult<\n\t\t\tAccumulateToResult<\n\t\t\t\tT,\n\t\t\t\t'single',\n\t\t\t\tT['_']['joins'],\n\t\t\t\tGetSelectTableSelection<T['_']['table']>\n\t\t\t>,\n\t\t\t'partial',\n\t\t\tT['_']['nullabilityMap']\n\t\t>,\n\t\tT['_']['nullabilityMap'],\n\t\tT['_']['joins'],\n\t\tTDynamic,\n\t\tT['_']['excludedMethods']\n\t>,\n\tTDynamic,\n\t'returning'\n>;\n\nexport type GelUpdateReturning<\n\tT extends AnyGelUpdate,\n\tTDynamic extends boolean,\n\tTSelectedFields extends SelectedFields,\n> = GelUpdateWithout<\n\tGelUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['queryResult'],\n\t\tT['_']['from'],\n\t\tSelectResult<\n\t\t\tAccumulateToResult<\n\t\t\t\tT,\n\t\t\t\t'partial',\n\t\t\t\tT['_']['joins'],\n\t\t\t\tTSelectedFields\n\t\t\t>,\n\t\t\t'partial',\n\t\t\tT['_']['nullabilityMap']\n\t\t>,\n\t\tT['_']['nullabilityMap'],\n\t\tT['_']['joins'],\n\t\tTDynamic,\n\t\tT['_']['excludedMethods']\n\t>,\n\tTDynamic,\n\t'returning'\n>;\n\nexport type GelUpdatePrepare<T extends AnyGelUpdate> = GelPreparedQuery<\n\tPreparedQueryConfig & {\n\t\texecute: T['_']['returning'] extends undefined ? GelQueryResultKind<T['_']['queryResult'], never>\n\t\t\t: T['_']['returning'][];\n\t}\n>;\n\nexport type GelUpdateDynamic<T extends AnyGelUpdate> = GelUpdate<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['from'],\n\tT['_']['returning'],\n\tT['_']['nullabilityMap']\n>;\n\nexport type GelUpdate<\n\tTTable extends GelTable = GelTable,\n\tTQueryResult extends GelQueryResultHKT = GelQueryResultHKT,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL | undefined = undefined,\n\tTReturning extends Record<string, unknown> | undefined = Record<string, unknown> | undefined,\n\tTNullabilityMap extends Record<string, JoinNullability> = Record<TTable['_']['name'], 'not-null'>,\n\tTJoins extends Join[] = [],\n> = GelUpdateBase<TTable, TQueryResult, TFrom, TReturning, TNullabilityMap, TJoins, true, never>;\n\nexport type AnyGelUpdate = GelUpdateBase<any, any, any, any, any, any, any, any>;\n\nexport interface GelUpdateBase<\n\tTTable extends GelTable,\n\tTQueryResult extends GelQueryResultHKT,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL | undefined = undefined,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\tTNullabilityMap extends Record<string, JoinNullability> = Record<TTable['_']['name'], 'not-null'>,\n\tTJoins extends Join[] = [],\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n> extends\n\tQueryPromise<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[]>,\n\tRunnableQuery<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[], 'gel'>,\n\tSQLWrapper\n{\n\treadonly _: {\n\t\treadonly dialect: 'gel';\n\t\treadonly table: TTable;\n\t\treadonly joins: TJoins;\n\t\treadonly nullabilityMap: TNullabilityMap;\n\t\treadonly queryResult: TQueryResult;\n\t\treadonly from: TFrom;\n\t\treadonly returning: TReturning;\n\t\treadonly dynamic: TDynamic;\n\t\treadonly excludedMethods: TExcludedMethods;\n\t\treadonly result: TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[];\n\t};\n}\n\nexport class GelUpdateBase<\n\tTTable extends GelTable,\n\tTQueryResult extends GelQueryResultHKT,\n\tTFrom extends GelTable | Subquery | GelViewBase | SQL | undefined = undefined,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTNullabilityMap extends Record<string, JoinNullability> = Record<TTable['_']['name'], 'not-null'>,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTJoins extends Join[] = [],\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTDynamic extends boolean = false,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTExcludedMethods extends string = never,\n> extends QueryPromise<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[]>\n\timplements\n\t\tRunnableQuery<TReturning extends undefined ? GelQueryResultKind<TQueryResult, never> : TReturning[], 'gel'>,\n\t\tSQLWrapper\n{\n\tstatic override readonly [entityKind]: string = 'GelUpdate';\n\n\tprivate config: GelUpdateConfig;\n\tprivate tableName: string | undefined;\n\tprivate joinsNotNullableMap: Record<string, boolean>;\n\n\tconstructor(\n\t\ttable: TTable,\n\t\tset: UpdateSet,\n\t\tprivate session: GelSession,\n\t\tprivate dialect: GelDialect,\n\t\twithList?: Subquery[],\n\t) {\n\t\tsuper();\n\t\tthis.config = { set, table, withList, joins: [] };\n\t\tthis.tableName = getTableLikeName(table);\n\t\tthis.joinsNotNullableMap = typeof this.tableName === 'string' ? { [this.tableName]: true } : {};\n\t}\n\n\tfrom<TFrom extends GelTable | Subquery | GelViewBase | SQL>(\n\t\tsource: TFrom,\n\t): GelUpdateWithJoins<this, TDynamic, TFrom> {\n\t\tconst tableName = getTableLikeName(source);\n\t\tif (typeof tableName === 'string') {\n\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t}\n\t\tthis.config.from = source;\n\t\treturn this as any;\n\t}\n\n\tprivate getTableLikeFields(table: GelTable | Subquery | GelViewBase): Record<string, unknown> {\n\t\tif (is(table, GelTable)) {\n\t\t\treturn table[Table.Symbol.Columns];\n\t\t} else if (is(table, Subquery)) {\n\t\t\treturn table._.selectedFields;\n\t\t}\n\t\treturn table[ViewBaseConfig].selectedFields;\n\t}\n\n\tprivate createJoin<TJoinType extends JoinType>(\n\t\tjoinType: TJoinType,\n\t): GelUpdateJoinFn<this, TDynamic, TJoinType> {\n\t\treturn ((\n\t\t\ttable: GelTable | Subquery | GelViewBase | SQL,\n\t\t\ton: ((updateTable: TTable, from: TFrom) => SQL | undefined) | SQL | undefined,\n\t\t) => {\n\t\t\tconst tableName = getTableLikeName(table);\n\n\t\t\tif (typeof tableName === 'string' && this.config.joins.some((join) => join.alias === tableName)) {\n\t\t\t\tthrow new Error(`Alias \"${tableName}\" is already used in this query`);\n\t\t\t}\n\n\t\t\tif (typeof on === 'function') {\n\t\t\t\tconst from = this.config.from && !is(this.config.from, SQL)\n\t\t\t\t\t? this.getTableLikeFields(this.config.from)\n\t\t\t\t\t: undefined;\n\t\t\t\ton = on(\n\t\t\t\t\tnew Proxy(\n\t\t\t\t\t\tthis.config.table[Table.Symbol.Columns],\n\t\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t\t) as any,\n\t\t\t\t\tfrom && new Proxy(\n\t\t\t\t\t\tfrom,\n\t\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t\t) as any,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tthis.config.joins.push({ on, table, joinType, alias: tableName });\n\n\t\t\tif (typeof tableName === 'string') {\n\t\t\t\tswitch (joinType) {\n\t\t\t\t\tcase 'left': {\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = false;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'right': {\n\t\t\t\t\t\tthis.joinsNotNullableMap = Object.fromEntries(\n\t\t\t\t\t\t\tObject.entries(this.joinsNotNullableMap).map(([key]) => [key, false]),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'inner': {\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'full': {\n\t\t\t\t\t\tthis.joinsNotNullableMap = Object.fromEntries(\n\t\t\t\t\t\t\tObject.entries(this.joinsNotNullableMap).map(([key]) => [key, false]),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = false;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn this as any;\n\t\t}) as any;\n\t}\n\n\tleftJoin = this.createJoin('left');\n\n\trightJoin = this.createJoin('right');\n\n\tinnerJoin = this.createJoin('inner');\n\n\tfullJoin = this.createJoin('full');\n\n\t/**\n\t * Adds a 'where' clause to the query.\n\t *\n\t * Calling this method will update only those rows that fulfill a specified condition.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/update}\n\t *\n\t * @param where the 'where' clause.\n\t *\n\t * @example\n\t * You can use conditional operators and `sql function` to filter the rows to be updated.\n\t *\n\t * ```ts\n\t * // Update all cars with green color\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(eq(cars.color, 'green'));\n\t * // or\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(sql`${cars.color} = 'green'`)\n\t * ```\n\t *\n\t * You can logically combine conditional operators with `and()` and `or()` operators:\n\t *\n\t * ```ts\n\t * // Update all BMW cars with a green color\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n\t *\n\t * // Update all cars with the green or blue color\n\t * await db.update(cars).set({ color: 'red' })\n\t * .where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n\t * ```\n\t */\n\twhere(where: SQL | undefined): GelUpdateWithout<this, TDynamic, 'where'> {\n\t\tthis.config.where = where;\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `returning` clause to the query.\n\t *\n\t * Calling this method will return the specified fields of the updated rows. If no fields are specified, all fields will be returned.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/update#update-with-returning}\n\t *\n\t * @example\n\t * ```ts\n\t * // Update all cars with the green color and return all fields\n\t * const updatedCars: Car[] = await db.update(cars)\n\t * .set({ color: 'red' })\n\t * .where(eq(cars.color, 'green'))\n\t * .returning();\n\t *\n\t * // Update all cars with the green color and return only their id and brand fields\n\t * const updatedCarsIdsAndBrands: { id: number, brand: string }[] = await db.update(cars)\n\t * .set({ color: 'red' })\n\t * .where(eq(cars.color, 'green'))\n\t * .returning({ id: cars.id, brand: cars.brand });\n\t * ```\n\t */\n\treturning(): GelUpdateReturningAll<this, TDynamic>;\n\treturning<TSelectedFields extends SelectedFields>(\n\t\tfields: TSelectedFields,\n\t): GelUpdateReturning<this, TDynamic, TSelectedFields>;\n\treturning(\n\t\tfields?: SelectedFields,\n\t): GelUpdateWithout<AnyGelUpdate, TDynamic, 'returning'> {\n\t\tif (!fields) {\n\t\t\tfields = Object.assign({}, this.config.table[Table.Symbol.Columns]);\n\n\t\t\tif (this.config.from) {\n\t\t\t\tconst tableName = getTableLikeName(this.config.from);\n\n\t\t\t\tif (typeof tableName === 'string' && this.config.from && !is(this.config.from, SQL)) {\n\t\t\t\t\tconst fromFields = this.getTableLikeFields(this.config.from);\n\t\t\t\t\tfields[tableName] = fromFields as any;\n\t\t\t\t}\n\n\t\t\t\tfor (const join of this.config.joins) {\n\t\t\t\t\tconst tableName = getTableLikeName(join.table);\n\n\t\t\t\t\tif (typeof tableName === 'string' && !is(join.table, SQL)) {\n\t\t\t\t\t\tconst fromFields = this.getTableLikeFields(join.table);\n\t\t\t\t\t\tfields[tableName] = fromFields as any;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthis.config.returning = orderSelectedFields<GelColumn>(fields);\n\t\treturn this as any;\n\t}\n\n\t/** @internal */\n\tgetSQL(): SQL {\n\t\treturn this.dialect.buildUpdateQuery(this.config);\n\t}\n\n\ttoSQL(): Query {\n\t\tconst { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n\t\treturn rest;\n\t}\n\n\t/** @internal */\n\t_prepare(name?: string, generateName = false): GelUpdatePrepare<this> {\n\t\tconst query = this.dialect.sqlToQuery(this.getSQL());\n\t\tconst preparedQuery = this.session.prepareQuery<\n\t\t\tPreparedQueryConfig & { execute: TReturning[] }\n\t\t>(\n\t\t\tquery,\n\t\t\tthis.config.returning,\n\t\t\tname ?? (generateName ? preparedStatementName(query.sql, query.params) : name),\n\t\t\ttrue,\n\t\t\tundefined,\n\t\t\t{\n\t\t\t\ttype: 'update',\n\t\t\t\ttables: extractUsedTable(this.config.table),\n\t\t\t},\n\t\t);\n\t\tpreparedQuery.joinsNotNullableMap = this.joinsNotNullableMap;\n\t\treturn preparedQuery;\n\t}\n\n\tprepare(name?: string): GelUpdatePrepare<this> {\n\t\treturn this._prepare(name, true);\n\t}\n\n\toverride execute: ReturnType<this['prepare']>['execute'] = (placeholderValues) => {\n\t\treturn this._prepare().execute(placeholderValues);\n\t};\n\n\t$dynamic(): GelUpdateDynamic<this> {\n\t\treturn this as any;\n\t}\n}\n"],"mappings":"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"}
@@ -81,12 +81,12 @@ var GelSession = class {
81
81
  execute(query) {
82
82
  return __tracing_ts.tracer.startActiveSpan("drizzle.operation", () => {
83
83
  return __tracing_ts.tracer.startActiveSpan("drizzle.prepareQuery", () => {
84
- return this.prepareQuery(this.dialect.sqlToQuery(query), void 0, void 0);
84
+ return this.prepareQuery(this.dialect.sqlToQuery(query), void 0, void 0, false);
85
85
  }).execute(void 0);
86
86
  });
87
87
  }
88
88
  all(query) {
89
- return this.prepareQuery(this.dialect.sqlToQuery(query), void 0, void 0).all();
89
+ return this.prepareQuery(this.dialect.sqlToQuery(query), void 0, void 0, false).all();
90
90
  }
91
91
  async count(sql) {
92
92
  const res = await this.execute(sql);
@@ -1 +1 @@
1
- {"version":3,"file":"session.cjs","names":["NoopCache","DrizzleQueryError","entityKind","tracer","GelDatabase","TransactionRollbackError"],"sources":["../../src/gel-core/session.ts"],"sourcesContent":["import type * as V1 from '~/_relations.ts';\nimport { type Cache, hashQuery, NoopCache } from '~/cache/core/cache.ts';\nimport type { WithCacheConfig } from '~/cache/core/types.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { DrizzleQueryError, TransactionRollbackError } from '~/errors.ts';\nimport type { AnyRelations, EmptyRelations, RelationalQueryMapperConfig } from '~/relations.ts';\nimport type { PreparedQuery } from '~/session.ts';\nimport type { Query, SQL } from '~/sql/index.ts';\nimport { tracer } from '~/tracing.ts';\nimport type { NeonAuthToken } from '~/utils.ts';\nimport { GelDatabase } from './db.ts';\nimport type { GelDialect } from './dialect.ts';\nimport type { SelectedFieldsOrdered } from './query-builders/select.types.ts';\n\nexport interface PreparedQueryConfig {\n\texecute: unknown;\n\tall: unknown;\n\tvalues: unknown;\n}\n\nexport abstract class GelPreparedQuery<T extends PreparedQueryConfig> implements PreparedQuery {\n\tconstructor(\n\t\tprotected query: Query,\n\t\tprivate cache?: Cache,\n\t\t// per query related metadata\n\t\tprivate queryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t} | undefined,\n\t\t// config that was passed through $withCache\n\t\tprivate cacheConfig?: WithCacheConfig,\n\t) {\n\t\t// it means that no $withCache options were passed and it should be just enabled\n\t\tif (cache && cache.strategy() === 'all' && cacheConfig === undefined) {\n\t\t\tthis.cacheConfig = { enabled: true, autoInvalidate: true };\n\t\t}\n\t\tif (!this.cacheConfig?.enabled) {\n\t\t\tthis.cacheConfig = undefined;\n\t\t}\n\t}\n\n\t/** @internal */\n\tprotected async queryWithCache<T>(\n\t\tqueryString: string,\n\t\tparams: any[],\n\t\tquery: () => Promise<T>,\n\t): Promise<T> {\n\t\tif (this.cache === undefined || is(this.cache, NoopCache) || this.queryMetadata === undefined) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// don't do any mutations, if globally is false\n\t\tif (this.cacheConfig && !this.cacheConfig.enabled) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// For mutate queries, we should query the database, wait for a response, and then perform invalidation\n\t\tif (\n\t\t\t(\n\t\t\t\tthis.queryMetadata.type === 'insert' || this.queryMetadata.type === 'update'\n\t\t\t\t|| this.queryMetadata.type === 'delete'\n\t\t\t) && this.queryMetadata.tables.length > 0\n\t\t) {\n\t\t\ttry {\n\t\t\t\tconst [res] = await Promise.all([\n\t\t\t\t\tquery(),\n\t\t\t\t\tthis.cache.onMutate({ tables: this.queryMetadata.tables }),\n\t\t\t\t]);\n\t\t\t\treturn res;\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// don't do any reads if globally disabled\n\t\tif (!this.cacheConfig) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\tif (this.queryMetadata.type === 'select') {\n\t\t\tconst fromCache = await this.cache.get(\n\t\t\t\tthis.cacheConfig.tag ?? await hashQuery(queryString, params),\n\t\t\t\tthis.queryMetadata.tables,\n\t\t\t\tthis.cacheConfig.tag !== undefined,\n\t\t\t\tthis.cacheConfig.autoInvalidate,\n\t\t\t);\n\t\t\tif (fromCache === undefined) {\n\t\t\t\tlet result;\n\t\t\t\ttry {\n\t\t\t\t\tresult = await query();\n\t\t\t\t} catch (e) {\n\t\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t\t}\n\n\t\t\t\t// put actual key\n\t\t\t\tawait this.cache.put(\n\t\t\t\t\tthis.cacheConfig.tag ?? await hashQuery(queryString, params),\n\t\t\t\t\tresult,\n\t\t\t\t\t// make sure we send tables that were used in a query only if user wants to invalidate it on each write\n\t\t\t\t\tthis.cacheConfig.autoInvalidate ? this.queryMetadata.tables : [],\n\t\t\t\t\tthis.cacheConfig.tag !== undefined,\n\t\t\t\t\tthis.cacheConfig.config,\n\t\t\t\t);\n\t\t\t\t// put flag if we should invalidate or not\n\t\t\t\treturn result;\n\t\t\t}\n\n\t\t\treturn fromCache as unknown as T;\n\t\t}\n\t\ttry {\n\t\t\treturn await query();\n\t\t} catch (e) {\n\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t}\n\t}\n\n\tprotected authToken?: NeonAuthToken;\n\n\tgetQuery(): Query {\n\t\treturn this.query;\n\t}\n\n\tmapResult(response: unknown, _isFromBatch?: boolean): unknown {\n\t\treturn response;\n\t}\n\n\tstatic readonly [entityKind]: string = 'GelPreparedQuery';\n\n\t/** @internal */\n\tjoinsNotNullableMap?: Record<string, boolean>;\n\n\tabstract execute(placeholderValues?: Record<string, unknown>): Promise<T['execute']>;\n\n\t/** @internal */\n\tabstract all(placeholderValues?: Record<string, unknown>): Promise<T['all']>;\n}\n\nexport abstract class GelSession<\n\tTQueryResult extends GelQueryResultHKT = any, // TO\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTRelations extends AnyRelations = EmptyRelations,\n\tTSchema extends V1.TablesRelationalConfig = Record<string, never>,\n> {\n\tstatic readonly [entityKind]: string = 'GelSession';\n\n\tconstructor(protected dialect: GelDialect) {}\n\n\tabstract prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(\n\t\tquery: Query,\n\t\tfields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tcustomResultMapper?: (rows: unknown[][], mapColumnValue?: (value: unknown) => unknown) => T['execute'],\n\t\tqueryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t},\n\t\tcacheConfig?: WithCacheConfig,\n\t): GelPreparedQuery<T>;\n\n\tabstract prepareRelationalQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(\n\t\tquery: Query,\n\t\tfields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tcustomResultMapper: (\n\t\t\trows: Record<string, unknown>[],\n\t\t\tmapColumnValue?: (value: unknown) => unknown,\n\t\t) => T['execute'],\n\t\tconfig: RelationalQueryMapperConfig,\n\t): GelPreparedQuery<T>;\n\n\texecute<T>(query: SQL): Promise<T> {\n\t\treturn tracer.startActiveSpan('drizzle.operation', () => {\n\t\t\tconst prepared = tracer.startActiveSpan('drizzle.prepareQuery', () => {\n\t\t\t\treturn this.prepareQuery<PreparedQueryConfig & { execute: T }>(\n\t\t\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\t\t\tundefined,\n\t\t\t\t\tundefined,\n\t\t\t\t);\n\t\t\t});\n\n\t\t\treturn prepared.execute(undefined);\n\t\t});\n\t}\n\n\tall<T = unknown>(query: SQL): Promise<T[]> {\n\t\treturn this.prepareQuery<PreparedQueryConfig & { all: T[] }>(\n\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\tundefined,\n\t\t\tundefined,\n\t\t).all();\n\t}\n\n\tasync count(sql: SQL): Promise<number> {\n\t\tconst res = await this.execute<[{ count: string }]>(sql);\n\n\t\treturn Number(\n\t\t\tres[0]['count'],\n\t\t);\n\t}\n\n\tabstract transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TRelations, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport abstract class GelTransaction<\n\tTQueryResult extends GelQueryResultHKT,\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTRelations extends AnyRelations = EmptyRelations,\n\tTSchema extends V1.TablesRelationalConfig = Record<string, never>,\n> extends GelDatabase<TQueryResult, TFullSchema, TRelations, TSchema> {\n\tstatic override readonly [entityKind]: string = 'GelTransaction';\n\n\tconstructor(\n\t\tdialect: GelDialect,\n\t\tsession: GelSession<any, any, any, any>,\n\t\tprotected relations: TRelations,\n\t\tprotected schema: {\n\t\t\tfullSchema: Record<string, unknown>;\n\t\t\tschema: TSchema;\n\t\t\ttableNamesMap: Record<string, string>;\n\t\t} | undefined,\n\t) {\n\t\tsuper(dialect, session, relations, schema);\n\t}\n\n\trollback(): never {\n\t\tthrow new TransactionRollbackError();\n\t}\n\n\tabstract override transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TRelations, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport interface GelQueryResultHKT {\n\treadonly $brand: 'GelQueryResultHKT';\n\treadonly row: unknown;\n\treadonly type: unknown;\n}\n\nexport type GelQueryResultKind<TKind extends GelQueryResultHKT, TRow> = (TKind & {\n\treadonly row: TRow;\n})['type'];\n"],"mappings":"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"}
1
+ {"version":3,"file":"session.cjs","names":["NoopCache","DrizzleQueryError","entityKind","tracer","GelDatabase","TransactionRollbackError"],"sources":["../../src/gel-core/session.ts"],"sourcesContent":["import type * as V1 from '~/_relations.ts';\nimport { type Cache, hashQuery, NoopCache } from '~/cache/core/cache.ts';\nimport type { WithCacheConfig } from '~/cache/core/types.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { DrizzleQueryError, TransactionRollbackError } from '~/errors.ts';\nimport type { AnyRelations, EmptyRelations } from '~/relations.ts';\nimport type { PreparedQuery } from '~/session.ts';\nimport type { Query, SQL } from '~/sql/index.ts';\nimport { tracer } from '~/tracing.ts';\nimport type { NeonAuthToken } from '~/utils.ts';\nimport { GelDatabase } from './db.ts';\nimport type { GelDialect } from './dialect.ts';\nimport type { SelectedFieldsOrdered } from './query-builders/select.types.ts';\n\nexport interface PreparedQueryConfig {\n\texecute: unknown;\n\tall: unknown;\n\tvalues: unknown;\n}\n\nexport abstract class GelPreparedQuery<T extends PreparedQueryConfig> implements PreparedQuery {\n\tconstructor(\n\t\tprotected query: Query,\n\t\tprivate cache?: Cache,\n\t\t// per query related metadata\n\t\tprivate queryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t} | undefined,\n\t\t// config that was passed through $withCache\n\t\tprivate cacheConfig?: WithCacheConfig,\n\t) {\n\t\t// it means that no $withCache options were passed and it should be just enabled\n\t\tif (cache && cache.strategy() === 'all' && cacheConfig === undefined) {\n\t\t\tthis.cacheConfig = { enabled: true, autoInvalidate: true };\n\t\t}\n\t\tif (!this.cacheConfig?.enabled) {\n\t\t\tthis.cacheConfig = undefined;\n\t\t}\n\t}\n\n\t/** @internal */\n\tprotected async queryWithCache<T>(\n\t\tqueryString: string,\n\t\tparams: any[],\n\t\tquery: () => Promise<T>,\n\t): Promise<T> {\n\t\tif (this.cache === undefined || is(this.cache, NoopCache) || this.queryMetadata === undefined) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// don't do any mutations, if globally is false\n\t\tif (this.cacheConfig && !this.cacheConfig.enabled) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// For mutate queries, we should query the database, wait for a response, and then perform invalidation\n\t\tif (\n\t\t\t(\n\t\t\t\tthis.queryMetadata.type === 'insert' || this.queryMetadata.type === 'update'\n\t\t\t\t|| this.queryMetadata.type === 'delete'\n\t\t\t) && this.queryMetadata.tables.length > 0\n\t\t) {\n\t\t\ttry {\n\t\t\t\tconst [res] = await Promise.all([\n\t\t\t\t\tquery(),\n\t\t\t\t\tthis.cache.onMutate({ tables: this.queryMetadata.tables }),\n\t\t\t\t]);\n\t\t\t\treturn res;\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// don't do any reads if globally disabled\n\t\tif (!this.cacheConfig) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\tif (this.queryMetadata.type === 'select') {\n\t\t\tconst fromCache = await this.cache.get(\n\t\t\t\tthis.cacheConfig.tag ?? await hashQuery(queryString, params),\n\t\t\t\tthis.queryMetadata.tables,\n\t\t\t\tthis.cacheConfig.tag !== undefined,\n\t\t\t\tthis.cacheConfig.autoInvalidate,\n\t\t\t);\n\t\t\tif (fromCache === undefined) {\n\t\t\t\tlet result;\n\t\t\t\ttry {\n\t\t\t\t\tresult = await query();\n\t\t\t\t} catch (e) {\n\t\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t\t}\n\n\t\t\t\t// put actual key\n\t\t\t\tawait this.cache.put(\n\t\t\t\t\tthis.cacheConfig.tag ?? await hashQuery(queryString, params),\n\t\t\t\t\tresult,\n\t\t\t\t\t// make sure we send tables that were used in a query only if user wants to invalidate it on each write\n\t\t\t\t\tthis.cacheConfig.autoInvalidate ? this.queryMetadata.tables : [],\n\t\t\t\t\tthis.cacheConfig.tag !== undefined,\n\t\t\t\t\tthis.cacheConfig.config,\n\t\t\t\t);\n\t\t\t\t// put flag if we should invalidate or not\n\t\t\t\treturn result;\n\t\t\t}\n\n\t\t\treturn fromCache as unknown as T;\n\t\t}\n\t\ttry {\n\t\t\treturn await query();\n\t\t} catch (e) {\n\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t}\n\t}\n\n\tprotected authToken?: NeonAuthToken;\n\n\tgetQuery(): Query {\n\t\treturn this.query;\n\t}\n\n\tmapResult(response: unknown, _isFromBatch?: boolean): unknown {\n\t\treturn response;\n\t}\n\n\tstatic readonly [entityKind]: string = 'GelPreparedQuery';\n\n\t/** @internal */\n\tjoinsNotNullableMap?: Record<string, boolean>;\n\n\tabstract execute(placeholderValues?: Record<string, unknown>): Promise<T['execute']>;\n\n\t/** @internal */\n\tabstract all(placeholderValues?: Record<string, unknown>): Promise<T['all']>;\n\n\t/** @internal */\n\tabstract isResponseInArrayMode(): boolean;\n}\n\nexport abstract class GelSession<\n\tTQueryResult extends GelQueryResultHKT = any, // TO\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTRelations extends AnyRelations = EmptyRelations,\n\tTSchema extends V1.TablesRelationalConfig = Record<string, never>,\n> {\n\tstatic readonly [entityKind]: string = 'GelSession';\n\n\tconstructor(protected dialect: GelDialect) {}\n\n\tabstract prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(\n\t\tquery: Query,\n\t\tfields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tisResponseInArrayMode: boolean,\n\t\tcustomResultMapper?: (rows: unknown[][], mapColumnValue?: (value: unknown) => unknown) => T['execute'],\n\t\tqueryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t},\n\t\tcacheConfig?: WithCacheConfig,\n\t): GelPreparedQuery<T>;\n\n\tabstract prepareRelationalQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(\n\t\tquery: Query,\n\t\tfields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tcustomResultMapper?: (\n\t\t\trows: Record<string, unknown>[],\n\t\t\tmapColumnValue?: (value: unknown) => unknown,\n\t\t) => T['execute'],\n\t): GelPreparedQuery<T>;\n\n\texecute<T>(query: SQL): Promise<T> {\n\t\treturn tracer.startActiveSpan('drizzle.operation', () => {\n\t\t\tconst prepared = tracer.startActiveSpan('drizzle.prepareQuery', () => {\n\t\t\t\treturn this.prepareQuery<PreparedQueryConfig & { execute: T }>(\n\t\t\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\t\t\tundefined,\n\t\t\t\t\tundefined,\n\t\t\t\t\tfalse,\n\t\t\t\t);\n\t\t\t});\n\n\t\t\treturn prepared.execute(undefined);\n\t\t});\n\t}\n\n\tall<T = unknown>(query: SQL): Promise<T[]> {\n\t\treturn this.prepareQuery<PreparedQueryConfig & { all: T[] }>(\n\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\tundefined,\n\t\t\tundefined,\n\t\t\tfalse,\n\t\t).all();\n\t}\n\n\tasync count(sql: SQL): Promise<number> {\n\t\tconst res = await this.execute<[{ count: string }]>(sql);\n\n\t\treturn Number(\n\t\t\tres[0]['count'],\n\t\t);\n\t}\n\n\tabstract transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TRelations, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport abstract class GelTransaction<\n\tTQueryResult extends GelQueryResultHKT,\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTRelations extends AnyRelations = EmptyRelations,\n\tTSchema extends V1.TablesRelationalConfig = Record<string, never>,\n> extends GelDatabase<TQueryResult, TFullSchema, TRelations, TSchema> {\n\tstatic override readonly [entityKind]: string = 'GelTransaction';\n\n\tconstructor(\n\t\tdialect: GelDialect,\n\t\tsession: GelSession<any, any, any, any>,\n\t\tprotected relations: TRelations,\n\t\tprotected schema: {\n\t\t\tfullSchema: Record<string, unknown>;\n\t\t\tschema: TSchema;\n\t\t\ttableNamesMap: Record<string, string>;\n\t\t} | undefined,\n\t) {\n\t\tsuper(dialect, session, relations, schema);\n\t}\n\n\trollback(): never {\n\t\tthrow new TransactionRollbackError();\n\t}\n\n\tabstract override transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TRelations, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport interface GelQueryResultHKT {\n\treadonly $brand: 'GelQueryResultHKT';\n\treadonly row: unknown;\n\treadonly type: unknown;\n}\n\nexport type GelQueryResultKind<TKind extends GelQueryResultHKT, TRow> = (TKind & {\n\treadonly row: TRow;\n})['type'];\n"],"mappings":"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"}
@@ -8,7 +8,7 @@ import { PreparedQuery } from "../session.cjs";
8
8
  import { Query, SQL } from "../sql/index.cjs";
9
9
  import { Cache } from "../cache/core/cache.cjs";
10
10
  import { WithCacheConfig } from "../cache/core/types.cjs";
11
- import { AnyRelations, EmptyRelations, RelationalQueryMapperConfig } from "../relations.cjs";
11
+ import { AnyRelations, EmptyRelations } from "../relations.cjs";
12
12
 
13
13
  //#region src/gel-core/session.d.ts
14
14
  interface PreparedQueryConfig {
@@ -36,11 +36,11 @@ TFullSchema extends Record<string, unknown> = Record<string, never>, TRelations
36
36
  protected dialect: GelDialect;
37
37
  static readonly [entityKind]: string;
38
38
  constructor(dialect: GelDialect);
39
- abstract prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, customResultMapper?: (rows: unknown[][], mapColumnValue?: (value: unknown) => unknown) => T['execute'], queryMetadata?: {
39
+ abstract prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, isResponseInArrayMode: boolean, customResultMapper?: (rows: unknown[][], mapColumnValue?: (value: unknown) => unknown) => T['execute'], queryMetadata?: {
40
40
  type: 'select' | 'update' | 'delete' | 'insert';
41
41
  tables: string[];
42
42
  }, cacheConfig?: WithCacheConfig): GelPreparedQuery<T>;
43
- abstract prepareRelationalQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, customResultMapper: (rows: Record<string, unknown>[], mapColumnValue?: (value: unknown) => unknown) => T['execute'], config: RelationalQueryMapperConfig): GelPreparedQuery<T>;
43
+ abstract prepareRelationalQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, customResultMapper?: (rows: Record<string, unknown>[], mapColumnValue?: (value: unknown) => unknown) => T['execute']): GelPreparedQuery<T>;
44
44
  execute<T>(query: SQL): Promise<T>;
45
45
  all<T = unknown>(query: SQL): Promise<T[]>;
46
46
  count(sql: SQL): Promise<number>;
@@ -4,8 +4,8 @@ import { SelectedFieldsOrdered } from "./query-builders/select.types.js";
4
4
  import { entityKind } from "../entity.js";
5
5
  import { NeonAuthToken } from "../utils.js";
6
6
  import * as V1 from "../_relations.js";
7
- import { AnyRelations, EmptyRelations, RelationalQueryMapperConfig } from "../relations.js";
8
7
  import { Cache } from "../cache/core/cache.js";
8
+ import { AnyRelations, EmptyRelations } from "../relations.js";
9
9
  import { Query, SQL } from "../sql/index.js";
10
10
  import { PreparedQuery } from "../session.js";
11
11
  import { WithCacheConfig } from "../cache/core/types.js";
@@ -36,11 +36,11 @@ TFullSchema extends Record<string, unknown> = Record<string, never>, TRelations
36
36
  protected dialect: GelDialect;
37
37
  static readonly [entityKind]: string;
38
38
  constructor(dialect: GelDialect);
39
- abstract prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, customResultMapper?: (rows: unknown[][], mapColumnValue?: (value: unknown) => unknown) => T['execute'], queryMetadata?: {
39
+ abstract prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, isResponseInArrayMode: boolean, customResultMapper?: (rows: unknown[][], mapColumnValue?: (value: unknown) => unknown) => T['execute'], queryMetadata?: {
40
40
  type: 'select' | 'update' | 'delete' | 'insert';
41
41
  tables: string[];
42
42
  }, cacheConfig?: WithCacheConfig): GelPreparedQuery<T>;
43
- abstract prepareRelationalQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, customResultMapper: (rows: Record<string, unknown>[], mapColumnValue?: (value: unknown) => unknown) => T['execute'], config: RelationalQueryMapperConfig): GelPreparedQuery<T>;
43
+ abstract prepareRelationalQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, customResultMapper?: (rows: Record<string, unknown>[], mapColumnValue?: (value: unknown) => unknown) => T['execute']): GelPreparedQuery<T>;
44
44
  execute<T>(query: SQL): Promise<T>;
45
45
  all<T = unknown>(query: SQL): Promise<T[]>;
46
46
  count(sql: SQL): Promise<number>;
@@ -79,12 +79,12 @@ var GelSession = class {
79
79
  execute(query) {
80
80
  return tracer.startActiveSpan("drizzle.operation", () => {
81
81
  return tracer.startActiveSpan("drizzle.prepareQuery", () => {
82
- return this.prepareQuery(this.dialect.sqlToQuery(query), void 0, void 0);
82
+ return this.prepareQuery(this.dialect.sqlToQuery(query), void 0, void 0, false);
83
83
  }).execute(void 0);
84
84
  });
85
85
  }
86
86
  all(query) {
87
- return this.prepareQuery(this.dialect.sqlToQuery(query), void 0, void 0).all();
87
+ return this.prepareQuery(this.dialect.sqlToQuery(query), void 0, void 0, false).all();
88
88
  }
89
89
  async count(sql) {
90
90
  const res = await this.execute(sql);
@@ -1 +1 @@
1
- {"version":3,"file":"session.js","names":[],"sources":["../../src/gel-core/session.ts"],"sourcesContent":["import type * as V1 from '~/_relations.ts';\nimport { type Cache, hashQuery, NoopCache } from '~/cache/core/cache.ts';\nimport type { WithCacheConfig } from '~/cache/core/types.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { DrizzleQueryError, TransactionRollbackError } from '~/errors.ts';\nimport type { AnyRelations, EmptyRelations, RelationalQueryMapperConfig } from '~/relations.ts';\nimport type { PreparedQuery } from '~/session.ts';\nimport type { Query, SQL } from '~/sql/index.ts';\nimport { tracer } from '~/tracing.ts';\nimport type { NeonAuthToken } from '~/utils.ts';\nimport { GelDatabase } from './db.ts';\nimport type { GelDialect } from './dialect.ts';\nimport type { SelectedFieldsOrdered } from './query-builders/select.types.ts';\n\nexport interface PreparedQueryConfig {\n\texecute: unknown;\n\tall: unknown;\n\tvalues: unknown;\n}\n\nexport abstract class GelPreparedQuery<T extends PreparedQueryConfig> implements PreparedQuery {\n\tconstructor(\n\t\tprotected query: Query,\n\t\tprivate cache?: Cache,\n\t\t// per query related metadata\n\t\tprivate queryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t} | undefined,\n\t\t// config that was passed through $withCache\n\t\tprivate cacheConfig?: WithCacheConfig,\n\t) {\n\t\t// it means that no $withCache options were passed and it should be just enabled\n\t\tif (cache && cache.strategy() === 'all' && cacheConfig === undefined) {\n\t\t\tthis.cacheConfig = { enabled: true, autoInvalidate: true };\n\t\t}\n\t\tif (!this.cacheConfig?.enabled) {\n\t\t\tthis.cacheConfig = undefined;\n\t\t}\n\t}\n\n\t/** @internal */\n\tprotected async queryWithCache<T>(\n\t\tqueryString: string,\n\t\tparams: any[],\n\t\tquery: () => Promise<T>,\n\t): Promise<T> {\n\t\tif (this.cache === undefined || is(this.cache, NoopCache) || this.queryMetadata === undefined) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// don't do any mutations, if globally is false\n\t\tif (this.cacheConfig && !this.cacheConfig.enabled) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// For mutate queries, we should query the database, wait for a response, and then perform invalidation\n\t\tif (\n\t\t\t(\n\t\t\t\tthis.queryMetadata.type === 'insert' || this.queryMetadata.type === 'update'\n\t\t\t\t|| this.queryMetadata.type === 'delete'\n\t\t\t) && this.queryMetadata.tables.length > 0\n\t\t) {\n\t\t\ttry {\n\t\t\t\tconst [res] = await Promise.all([\n\t\t\t\t\tquery(),\n\t\t\t\t\tthis.cache.onMutate({ tables: this.queryMetadata.tables }),\n\t\t\t\t]);\n\t\t\t\treturn res;\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// don't do any reads if globally disabled\n\t\tif (!this.cacheConfig) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\tif (this.queryMetadata.type === 'select') {\n\t\t\tconst fromCache = await this.cache.get(\n\t\t\t\tthis.cacheConfig.tag ?? await hashQuery(queryString, params),\n\t\t\t\tthis.queryMetadata.tables,\n\t\t\t\tthis.cacheConfig.tag !== undefined,\n\t\t\t\tthis.cacheConfig.autoInvalidate,\n\t\t\t);\n\t\t\tif (fromCache === undefined) {\n\t\t\t\tlet result;\n\t\t\t\ttry {\n\t\t\t\t\tresult = await query();\n\t\t\t\t} catch (e) {\n\t\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t\t}\n\n\t\t\t\t// put actual key\n\t\t\t\tawait this.cache.put(\n\t\t\t\t\tthis.cacheConfig.tag ?? await hashQuery(queryString, params),\n\t\t\t\t\tresult,\n\t\t\t\t\t// make sure we send tables that were used in a query only if user wants to invalidate it on each write\n\t\t\t\t\tthis.cacheConfig.autoInvalidate ? this.queryMetadata.tables : [],\n\t\t\t\t\tthis.cacheConfig.tag !== undefined,\n\t\t\t\t\tthis.cacheConfig.config,\n\t\t\t\t);\n\t\t\t\t// put flag if we should invalidate or not\n\t\t\t\treturn result;\n\t\t\t}\n\n\t\t\treturn fromCache as unknown as T;\n\t\t}\n\t\ttry {\n\t\t\treturn await query();\n\t\t} catch (e) {\n\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t}\n\t}\n\n\tprotected authToken?: NeonAuthToken;\n\n\tgetQuery(): Query {\n\t\treturn this.query;\n\t}\n\n\tmapResult(response: unknown, _isFromBatch?: boolean): unknown {\n\t\treturn response;\n\t}\n\n\tstatic readonly [entityKind]: string = 'GelPreparedQuery';\n\n\t/** @internal */\n\tjoinsNotNullableMap?: Record<string, boolean>;\n\n\tabstract execute(placeholderValues?: Record<string, unknown>): Promise<T['execute']>;\n\n\t/** @internal */\n\tabstract all(placeholderValues?: Record<string, unknown>): Promise<T['all']>;\n}\n\nexport abstract class GelSession<\n\tTQueryResult extends GelQueryResultHKT = any, // TO\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTRelations extends AnyRelations = EmptyRelations,\n\tTSchema extends V1.TablesRelationalConfig = Record<string, never>,\n> {\n\tstatic readonly [entityKind]: string = 'GelSession';\n\n\tconstructor(protected dialect: GelDialect) {}\n\n\tabstract prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(\n\t\tquery: Query,\n\t\tfields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tcustomResultMapper?: (rows: unknown[][], mapColumnValue?: (value: unknown) => unknown) => T['execute'],\n\t\tqueryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t},\n\t\tcacheConfig?: WithCacheConfig,\n\t): GelPreparedQuery<T>;\n\n\tabstract prepareRelationalQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(\n\t\tquery: Query,\n\t\tfields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tcustomResultMapper: (\n\t\t\trows: Record<string, unknown>[],\n\t\t\tmapColumnValue?: (value: unknown) => unknown,\n\t\t) => T['execute'],\n\t\tconfig: RelationalQueryMapperConfig,\n\t): GelPreparedQuery<T>;\n\n\texecute<T>(query: SQL): Promise<T> {\n\t\treturn tracer.startActiveSpan('drizzle.operation', () => {\n\t\t\tconst prepared = tracer.startActiveSpan('drizzle.prepareQuery', () => {\n\t\t\t\treturn this.prepareQuery<PreparedQueryConfig & { execute: T }>(\n\t\t\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\t\t\tundefined,\n\t\t\t\t\tundefined,\n\t\t\t\t);\n\t\t\t});\n\n\t\t\treturn prepared.execute(undefined);\n\t\t});\n\t}\n\n\tall<T = unknown>(query: SQL): Promise<T[]> {\n\t\treturn this.prepareQuery<PreparedQueryConfig & { all: T[] }>(\n\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\tundefined,\n\t\t\tundefined,\n\t\t).all();\n\t}\n\n\tasync count(sql: SQL): Promise<number> {\n\t\tconst res = await this.execute<[{ count: string }]>(sql);\n\n\t\treturn Number(\n\t\t\tres[0]['count'],\n\t\t);\n\t}\n\n\tabstract transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TRelations, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport abstract class GelTransaction<\n\tTQueryResult extends GelQueryResultHKT,\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTRelations extends AnyRelations = EmptyRelations,\n\tTSchema extends V1.TablesRelationalConfig = Record<string, never>,\n> extends GelDatabase<TQueryResult, TFullSchema, TRelations, TSchema> {\n\tstatic override readonly [entityKind]: string = 'GelTransaction';\n\n\tconstructor(\n\t\tdialect: GelDialect,\n\t\tsession: GelSession<any, any, any, any>,\n\t\tprotected relations: TRelations,\n\t\tprotected schema: {\n\t\t\tfullSchema: Record<string, unknown>;\n\t\t\tschema: TSchema;\n\t\t\ttableNamesMap: Record<string, string>;\n\t\t} | undefined,\n\t) {\n\t\tsuper(dialect, session, relations, schema);\n\t}\n\n\trollback(): never {\n\t\tthrow new TransactionRollbackError();\n\t}\n\n\tabstract override transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TRelations, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport interface GelQueryResultHKT {\n\treadonly $brand: 'GelQueryResultHKT';\n\treadonly row: unknown;\n\treadonly type: unknown;\n}\n\nexport type GelQueryResultKind<TKind extends GelQueryResultHKT, TRow> = (TKind & {\n\treadonly row: TRow;\n})['type'];\n"],"mappings":"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"}
1
+ {"version":3,"file":"session.js","names":[],"sources":["../../src/gel-core/session.ts"],"sourcesContent":["import type * as V1 from '~/_relations.ts';\nimport { type Cache, hashQuery, NoopCache } from '~/cache/core/cache.ts';\nimport type { WithCacheConfig } from '~/cache/core/types.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { DrizzleQueryError, TransactionRollbackError } from '~/errors.ts';\nimport type { AnyRelations, EmptyRelations } from '~/relations.ts';\nimport type { PreparedQuery } from '~/session.ts';\nimport type { Query, SQL } from '~/sql/index.ts';\nimport { tracer } from '~/tracing.ts';\nimport type { NeonAuthToken } from '~/utils.ts';\nimport { GelDatabase } from './db.ts';\nimport type { GelDialect } from './dialect.ts';\nimport type { SelectedFieldsOrdered } from './query-builders/select.types.ts';\n\nexport interface PreparedQueryConfig {\n\texecute: unknown;\n\tall: unknown;\n\tvalues: unknown;\n}\n\nexport abstract class GelPreparedQuery<T extends PreparedQueryConfig> implements PreparedQuery {\n\tconstructor(\n\t\tprotected query: Query,\n\t\tprivate cache?: Cache,\n\t\t// per query related metadata\n\t\tprivate queryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t} | undefined,\n\t\t// config that was passed through $withCache\n\t\tprivate cacheConfig?: WithCacheConfig,\n\t) {\n\t\t// it means that no $withCache options were passed and it should be just enabled\n\t\tif (cache && cache.strategy() === 'all' && cacheConfig === undefined) {\n\t\t\tthis.cacheConfig = { enabled: true, autoInvalidate: true };\n\t\t}\n\t\tif (!this.cacheConfig?.enabled) {\n\t\t\tthis.cacheConfig = undefined;\n\t\t}\n\t}\n\n\t/** @internal */\n\tprotected async queryWithCache<T>(\n\t\tqueryString: string,\n\t\tparams: any[],\n\t\tquery: () => Promise<T>,\n\t): Promise<T> {\n\t\tif (this.cache === undefined || is(this.cache, NoopCache) || this.queryMetadata === undefined) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// don't do any mutations, if globally is false\n\t\tif (this.cacheConfig && !this.cacheConfig.enabled) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// For mutate queries, we should query the database, wait for a response, and then perform invalidation\n\t\tif (\n\t\t\t(\n\t\t\t\tthis.queryMetadata.type === 'insert' || this.queryMetadata.type === 'update'\n\t\t\t\t|| this.queryMetadata.type === 'delete'\n\t\t\t) && this.queryMetadata.tables.length > 0\n\t\t) {\n\t\t\ttry {\n\t\t\t\tconst [res] = await Promise.all([\n\t\t\t\t\tquery(),\n\t\t\t\t\tthis.cache.onMutate({ tables: this.queryMetadata.tables }),\n\t\t\t\t]);\n\t\t\t\treturn res;\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// don't do any reads if globally disabled\n\t\tif (!this.cacheConfig) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\tif (this.queryMetadata.type === 'select') {\n\t\t\tconst fromCache = await this.cache.get(\n\t\t\t\tthis.cacheConfig.tag ?? await hashQuery(queryString, params),\n\t\t\t\tthis.queryMetadata.tables,\n\t\t\t\tthis.cacheConfig.tag !== undefined,\n\t\t\t\tthis.cacheConfig.autoInvalidate,\n\t\t\t);\n\t\t\tif (fromCache === undefined) {\n\t\t\t\tlet result;\n\t\t\t\ttry {\n\t\t\t\t\tresult = await query();\n\t\t\t\t} catch (e) {\n\t\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t\t}\n\n\t\t\t\t// put actual key\n\t\t\t\tawait this.cache.put(\n\t\t\t\t\tthis.cacheConfig.tag ?? await hashQuery(queryString, params),\n\t\t\t\t\tresult,\n\t\t\t\t\t// make sure we send tables that were used in a query only if user wants to invalidate it on each write\n\t\t\t\t\tthis.cacheConfig.autoInvalidate ? this.queryMetadata.tables : [],\n\t\t\t\t\tthis.cacheConfig.tag !== undefined,\n\t\t\t\t\tthis.cacheConfig.config,\n\t\t\t\t);\n\t\t\t\t// put flag if we should invalidate or not\n\t\t\t\treturn result;\n\t\t\t}\n\n\t\t\treturn fromCache as unknown as T;\n\t\t}\n\t\ttry {\n\t\t\treturn await query();\n\t\t} catch (e) {\n\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t}\n\t}\n\n\tprotected authToken?: NeonAuthToken;\n\n\tgetQuery(): Query {\n\t\treturn this.query;\n\t}\n\n\tmapResult(response: unknown, _isFromBatch?: boolean): unknown {\n\t\treturn response;\n\t}\n\n\tstatic readonly [entityKind]: string = 'GelPreparedQuery';\n\n\t/** @internal */\n\tjoinsNotNullableMap?: Record<string, boolean>;\n\n\tabstract execute(placeholderValues?: Record<string, unknown>): Promise<T['execute']>;\n\n\t/** @internal */\n\tabstract all(placeholderValues?: Record<string, unknown>): Promise<T['all']>;\n\n\t/** @internal */\n\tabstract isResponseInArrayMode(): boolean;\n}\n\nexport abstract class GelSession<\n\tTQueryResult extends GelQueryResultHKT = any, // TO\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTRelations extends AnyRelations = EmptyRelations,\n\tTSchema extends V1.TablesRelationalConfig = Record<string, never>,\n> {\n\tstatic readonly [entityKind]: string = 'GelSession';\n\n\tconstructor(protected dialect: GelDialect) {}\n\n\tabstract prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(\n\t\tquery: Query,\n\t\tfields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tisResponseInArrayMode: boolean,\n\t\tcustomResultMapper?: (rows: unknown[][], mapColumnValue?: (value: unknown) => unknown) => T['execute'],\n\t\tqueryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t},\n\t\tcacheConfig?: WithCacheConfig,\n\t): GelPreparedQuery<T>;\n\n\tabstract prepareRelationalQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(\n\t\tquery: Query,\n\t\tfields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tcustomResultMapper?: (\n\t\t\trows: Record<string, unknown>[],\n\t\t\tmapColumnValue?: (value: unknown) => unknown,\n\t\t) => T['execute'],\n\t): GelPreparedQuery<T>;\n\n\texecute<T>(query: SQL): Promise<T> {\n\t\treturn tracer.startActiveSpan('drizzle.operation', () => {\n\t\t\tconst prepared = tracer.startActiveSpan('drizzle.prepareQuery', () => {\n\t\t\t\treturn this.prepareQuery<PreparedQueryConfig & { execute: T }>(\n\t\t\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\t\t\tundefined,\n\t\t\t\t\tundefined,\n\t\t\t\t\tfalse,\n\t\t\t\t);\n\t\t\t});\n\n\t\t\treturn prepared.execute(undefined);\n\t\t});\n\t}\n\n\tall<T = unknown>(query: SQL): Promise<T[]> {\n\t\treturn this.prepareQuery<PreparedQueryConfig & { all: T[] }>(\n\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\tundefined,\n\t\t\tundefined,\n\t\t\tfalse,\n\t\t).all();\n\t}\n\n\tasync count(sql: SQL): Promise<number> {\n\t\tconst res = await this.execute<[{ count: string }]>(sql);\n\n\t\treturn Number(\n\t\t\tres[0]['count'],\n\t\t);\n\t}\n\n\tabstract transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TRelations, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport abstract class GelTransaction<\n\tTQueryResult extends GelQueryResultHKT,\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTRelations extends AnyRelations = EmptyRelations,\n\tTSchema extends V1.TablesRelationalConfig = Record<string, never>,\n> extends GelDatabase<TQueryResult, TFullSchema, TRelations, TSchema> {\n\tstatic override readonly [entityKind]: string = 'GelTransaction';\n\n\tconstructor(\n\t\tdialect: GelDialect,\n\t\tsession: GelSession<any, any, any, any>,\n\t\tprotected relations: TRelations,\n\t\tprotected schema: {\n\t\t\tfullSchema: Record<string, unknown>;\n\t\t\tschema: TSchema;\n\t\t\ttableNamesMap: Record<string, string>;\n\t\t} | undefined,\n\t) {\n\t\tsuper(dialect, session, relations, schema);\n\t}\n\n\trollback(): never {\n\t\tthrow new TransactionRollbackError();\n\t}\n\n\tabstract override transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TRelations, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport interface GelQueryResultHKT {\n\treadonly $brand: 'GelQueryResultHKT';\n\treadonly row: unknown;\n\treadonly type: unknown;\n}\n\nexport type GelQueryResultKind<TKind extends GelQueryResultHKT, TRow> = (TKind & {\n\treadonly row: TRow;\n})['type'];\n"],"mappings":"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"}
@@ -32,7 +32,7 @@ function gelTableWithSchema(name, columns, extraConfig, schema, baseName = name)
32
32
  const builtColumns = Object.fromEntries(Object.entries(parsedColumns).map(([name, colBuilderBase]) => {
33
33
  const colBuilder = colBuilderBase;
34
34
  colBuilder.setName(name);
35
- const column = colBuilder.build(rawTable).postBuild();
35
+ const column = colBuilder.build(rawTable);
36
36
  rawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));
37
37
  return [name, column];
38
38
  }));
@@ -1 +1 @@
1
- {"version":3,"file":"table.cjs","names":["Table","entityKind","getGelColumnBuilders"],"sources":["../../src/gel-core/table.ts"],"sourcesContent":["import type { BuildColumns, BuildExtraConfigColumns, ColumnBuilderBase } from '~/column-builder.ts';\nimport { entityKind } from '~/entity.ts';\nimport {\n\ttype InferTableColumnsModels,\n\tTable,\n\ttype TableConfig as TableConfigBase,\n\ttype UpdateTableConfig,\n} from '~/table.ts';\nimport type { CheckBuilder } from './checks.ts';\nimport { type GelColumnsBuilders, getGelColumnBuilders } from './columns/all.ts';\nimport type { GelColumn, GelColumnBuilder, GelColumns, GelExtraConfigColumn } from './columns/common.ts';\nimport type { ForeignKey, ForeignKeyBuilder } from './foreign-keys.ts';\nimport type { AnyIndexBuilder } from './indexes.ts';\nimport type { GelPolicy } from './policies.ts';\nimport type { PrimaryKeyBuilder } from './primary-keys.ts';\nimport type { UniqueConstraintBuilder } from './unique-constraint.ts';\n\nexport type GelTableExtraConfigValue =\n\t| AnyIndexBuilder\n\t| CheckBuilder\n\t| ForeignKeyBuilder\n\t| PrimaryKeyBuilder\n\t| UniqueConstraintBuilder\n\t| GelPolicy;\n\nexport type GelTableExtraConfig = Record<\n\tstring,\n\tGelTableExtraConfigValue\n>;\n\nexport type TableConfig = TableConfigBase<GelColumns>;\n\n/** @internal */\nexport const InlineForeignKeys = Symbol.for('drizzle:GelInlineForeignKeys');\n/** @internal */\nexport const EnableRLS = Symbol.for('drizzle:EnableRLS');\n\nexport class GelTable<T extends TableConfig = TableConfig> extends Table<T> {\n\tstatic override readonly [entityKind]: string = 'GelTable';\n\n\t/** @internal */\n\tstatic override readonly Symbol = Object.assign({}, Table.Symbol, {\n\t\tInlineForeignKeys: InlineForeignKeys as typeof InlineForeignKeys,\n\t\tEnableRLS: EnableRLS as typeof EnableRLS,\n\t});\n\n\t/**@internal */\n\t[InlineForeignKeys]: ForeignKey[] = [];\n\n\t/** @internal */\n\t[EnableRLS]: boolean = false;\n\n\t/** @internal */\n\toverride [Table.Symbol.ExtraConfigBuilder]: ((self: Record<string, GelColumn>) => GelTableExtraConfig) | undefined =\n\t\tundefined;\n\n\t/** @internal */\n\toverride [Table.Symbol.ExtraConfigColumns]: Record<string, GelExtraConfigColumn> = {};\n}\n\nexport type AnyGelTable<TPartial extends Partial<TableConfig> = {}> = GelTable<\n\tUpdateTableConfig<TableConfig, TPartial>\n>;\n\nexport type GelTableWithColumns<T extends TableConfig> =\n\t& GelTable<T>\n\t& T['columns']\n\t& InferTableColumnsModels<T['columns']>\n\t& {\n\t\tenableRLS: () => Omit<\n\t\t\tGelTableWithColumns<T>,\n\t\t\t'enableRLS'\n\t\t>;\n\t};\n\n/** @internal */\nexport function gelTableWithSchema<\n\tTTableName extends string,\n\tTSchemaName extends string | undefined,\n\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n>(\n\tname: TTableName,\n\tcolumns: TColumnsMap | ((columnTypes: GelColumnsBuilders) => TColumnsMap),\n\textraConfig:\n\t\t| ((\n\t\t\tself: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>,\n\t\t) => GelTableExtraConfig | GelTableExtraConfigValue[])\n\t\t| undefined,\n\tschema: TSchemaName,\n\tbaseName = name,\n): GelTableWithColumns<{\n\tname: TTableName;\n\tschema: TSchemaName;\n\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\tdialect: 'gel';\n}> {\n\tconst rawTable = new GelTable<{\n\t\tname: TTableName;\n\t\tschema: TSchemaName;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>(name, schema, baseName);\n\n\tconst parsedColumns: TColumnsMap = typeof columns === 'function' ? columns(getGelColumnBuilders()) : columns;\n\n\tconst builtColumns = Object.fromEntries(\n\t\tObject.entries(parsedColumns).map(([name, colBuilderBase]) => {\n\t\t\tconst colBuilder = colBuilderBase as GelColumnBuilder;\n\t\t\tcolBuilder.setName(name);\n\t\t\tconst column = colBuilder.build(rawTable).postBuild();\n\t\t\trawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n\t\t\treturn [name, column];\n\t\t}),\n\t) as unknown as BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\n\tconst builtColumnsForExtraConfig = Object.fromEntries(\n\t\tObject.entries(parsedColumns).map(([name, colBuilderBase]) => {\n\t\t\tconst colBuilder = colBuilderBase as GelColumnBuilder;\n\t\t\tcolBuilder.setName(name);\n\t\t\tconst column = colBuilder.buildExtraConfigColumn(rawTable);\n\t\t\treturn [name, column];\n\t\t}),\n\t) as unknown as BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>;\n\n\tconst table = Object.assign(rawTable, builtColumns);\n\n\ttable[Table.Symbol.Columns] = builtColumns;\n\ttable[Table.Symbol.ExtraConfigColumns] = builtColumnsForExtraConfig;\n\n\tif (extraConfig) {\n\t\ttable[GelTable.Symbol.ExtraConfigBuilder] = extraConfig as any;\n\t}\n\n\treturn Object.assign(table, {\n\t\tenableRLS: () => {\n\t\t\ttable[GelTable.Symbol.EnableRLS] = true;\n\t\t\treturn table as GelTableWithColumns<{\n\t\t\t\tname: TTableName;\n\t\t\t\tschema: TSchemaName;\n\t\t\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\t\t\tdialect: 'gel';\n\t\t\t}>;\n\t\t},\n\t}) as any;\n}\n\nexport interface GelTableFn<TSchema extends string | undefined = undefined> {\n\t/**\n\t * @deprecated The third parameter of GelTable is changing and will only accept an array instead of an object\n\t *\n\t * @example\n\t * Deprecated version:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => ({\n\t * \tidx: index('custom_name').on(t.id)\n\t * }));\n\t * ```\n\t *\n\t * New API:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => [\n\t * \tindex('custom_name').on(t.id)\n\t * ]);\n\t * ```\n\t */\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig: (\n\t\t\tself: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>,\n\t\t) => GelTableExtraConfig,\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n\n\t/**\n\t * @deprecated The third parameter of gelTable is changing and will only accept an array instead of an object\n\t *\n\t * @example\n\t * Deprecated version:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => ({\n\t * \tidx: index('custom_name').on(t.id)\n\t * }));\n\t * ```\n\t *\n\t * New API:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => [\n\t * \tindex('custom_name').on(t.id)\n\t * ]);\n\t * ```\n\t */\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: (columnTypes: GelColumnsBuilders) => TColumnsMap,\n\t\textraConfig: (self: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>) => GelTableExtraConfig,\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig?: (\n\t\t\tself: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>,\n\t\t) => GelTableExtraConfigValue[],\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: (columnTypes: GelColumnsBuilders) => TColumnsMap,\n\t\textraConfig?: (self: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>) => GelTableExtraConfigValue[],\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n}\n\nexport const gelTable: GelTableFn = (name, columns, extraConfig) => {\n\treturn gelTableWithSchema(name, columns, extraConfig, undefined);\n};\n\nexport function gelTableCreator(customizeTableName: (name: string) => string): GelTableFn {\n\treturn (name, columns, extraConfig) => {\n\t\treturn gelTableWithSchema(customizeTableName(name) as typeof name, columns, extraConfig, undefined, name);\n\t};\n}\n"],"mappings":";;;;;;;;AAiCA,MAAa,oBAAoB,OAAO,IAAI,+BAA+B;;AAE3E,MAAa,YAAY,OAAO,IAAI,oBAAoB;AAExD,IAAa,WAAb,cAAmEA,iBAAS;CAC3E,QAA0BC,0BAAsB;;CAGhD,OAAyB,SAAS,OAAO,OAAO,EAAE,EAAED,iBAAM,QAAQ;EAC9C;EACR;EACX,CAAC;;CAGF,CAAC,qBAAmC,EAAE;;CAGtC,CAAC,aAAsB;;CAGvB,CAAUA,iBAAM,OAAO,sBACtB;;CAGD,CAAUA,iBAAM,OAAO,sBAA4D,EAAE;;;AAmBtF,SAAgB,mBAKf,MACA,SACA,aAKA,QACA,WAAW,MAMT;CACF,MAAM,WAAW,IAAI,SAKlB,MAAM,QAAQ,SAAS;CAE1B,MAAM,gBAA6B,OAAO,YAAY,aAAa,QAAQE,mDAAsB,CAAC,GAAG;CAErG,MAAM,eAAe,OAAO,YAC3B,OAAO,QAAQ,cAAc,CAAC,KAAK,CAAC,MAAM,oBAAoB;EAC7D,MAAM,aAAa;AACnB,aAAW,QAAQ,KAAK;EACxB,MAAM,SAAS,WAAW,MAAM,SAAS,CAAC,WAAW;AACrD,WAAS,mBAAmB,KAAK,GAAG,WAAW,iBAAiB,QAAQ,SAAS,CAAC;AAClF,SAAO,CAAC,MAAM,OAAO;GACpB,CACF;CAED,MAAM,6BAA6B,OAAO,YACzC,OAAO,QAAQ,cAAc,CAAC,KAAK,CAAC,MAAM,oBAAoB;EAC7D,MAAM,aAAa;AACnB,aAAW,QAAQ,KAAK;AAExB,SAAO,CAAC,MADO,WAAW,uBAAuB,SAAS,CACrC;GACpB,CACF;CAED,MAAM,QAAQ,OAAO,OAAO,UAAU,aAAa;AAEnD,OAAMF,iBAAM,OAAO,WAAW;AAC9B,OAAMA,iBAAM,OAAO,sBAAsB;AAEzC,KAAI,YACH,OAAM,SAAS,OAAO,sBAAsB;AAG7C,QAAO,OAAO,OAAO,OAAO,EAC3B,iBAAiB;AAChB,QAAM,SAAS,OAAO,aAAa;AACnC,SAAO;IAOR,CAAC;;AA6GH,MAAa,YAAwB,MAAM,SAAS,gBAAgB;AACnE,QAAO,mBAAmB,MAAM,SAAS,aAAa,OAAU;;AAGjE,SAAgB,gBAAgB,oBAA0D;AACzF,SAAQ,MAAM,SAAS,gBAAgB;AACtC,SAAO,mBAAmB,mBAAmB,KAAK,EAAiB,SAAS,aAAa,QAAW,KAAK"}
1
+ {"version":3,"file":"table.cjs","names":["Table","entityKind","getGelColumnBuilders"],"sources":["../../src/gel-core/table.ts"],"sourcesContent":["import type { BuildColumns, BuildExtraConfigColumns, ColumnBuilderBase } from '~/column-builder.ts';\nimport { entityKind } from '~/entity.ts';\nimport {\n\ttype InferTableColumnsModels,\n\tTable,\n\ttype TableConfig as TableConfigBase,\n\ttype UpdateTableConfig,\n} from '~/table.ts';\nimport type { CheckBuilder } from './checks.ts';\nimport { type GelColumnsBuilders, getGelColumnBuilders } from './columns/all.ts';\nimport type { GelColumn, GelColumnBuilder, GelColumns, GelExtraConfigColumn } from './columns/common.ts';\nimport type { ForeignKey, ForeignKeyBuilder } from './foreign-keys.ts';\nimport type { AnyIndexBuilder } from './indexes.ts';\nimport type { GelPolicy } from './policies.ts';\nimport type { PrimaryKeyBuilder } from './primary-keys.ts';\nimport type { UniqueConstraintBuilder } from './unique-constraint.ts';\n\nexport type GelTableExtraConfigValue =\n\t| AnyIndexBuilder\n\t| CheckBuilder\n\t| ForeignKeyBuilder\n\t| PrimaryKeyBuilder\n\t| UniqueConstraintBuilder\n\t| GelPolicy;\n\nexport type GelTableExtraConfig = Record<\n\tstring,\n\tGelTableExtraConfigValue\n>;\n\nexport type TableConfig = TableConfigBase<GelColumns>;\n\n/** @internal */\nexport const InlineForeignKeys = Symbol.for('drizzle:GelInlineForeignKeys');\n/** @internal */\nexport const EnableRLS = Symbol.for('drizzle:EnableRLS');\n\nexport class GelTable<T extends TableConfig = TableConfig> extends Table<T> {\n\tstatic override readonly [entityKind]: string = 'GelTable';\n\n\t/** @internal */\n\tstatic override readonly Symbol = Object.assign({}, Table.Symbol, {\n\t\tInlineForeignKeys: InlineForeignKeys as typeof InlineForeignKeys,\n\t\tEnableRLS: EnableRLS as typeof EnableRLS,\n\t});\n\n\t/**@internal */\n\t[InlineForeignKeys]: ForeignKey[] = [];\n\n\t/** @internal */\n\t[EnableRLS]: boolean = false;\n\n\t/** @internal */\n\toverride [Table.Symbol.ExtraConfigBuilder]: ((self: Record<string, GelColumn>) => GelTableExtraConfig) | undefined =\n\t\tundefined;\n\n\t/** @internal */\n\toverride [Table.Symbol.ExtraConfigColumns]: Record<string, GelExtraConfigColumn> = {};\n}\n\nexport type AnyGelTable<TPartial extends Partial<TableConfig> = {}> = GelTable<\n\tUpdateTableConfig<TableConfig, TPartial>\n>;\n\nexport type GelTableWithColumns<T extends TableConfig> =\n\t& GelTable<T>\n\t& T['columns']\n\t& InferTableColumnsModels<T['columns']>\n\t& {\n\t\tenableRLS: () => Omit<\n\t\t\tGelTableWithColumns<T>,\n\t\t\t'enableRLS'\n\t\t>;\n\t};\n\n/** @internal */\nexport function gelTableWithSchema<\n\tTTableName extends string,\n\tTSchemaName extends string | undefined,\n\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n>(\n\tname: TTableName,\n\tcolumns: TColumnsMap | ((columnTypes: GelColumnsBuilders) => TColumnsMap),\n\textraConfig:\n\t\t| ((\n\t\t\tself: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>,\n\t\t) => GelTableExtraConfig | GelTableExtraConfigValue[])\n\t\t| undefined,\n\tschema: TSchemaName,\n\tbaseName = name,\n): GelTableWithColumns<{\n\tname: TTableName;\n\tschema: TSchemaName;\n\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\tdialect: 'gel';\n}> {\n\tconst rawTable = new GelTable<{\n\t\tname: TTableName;\n\t\tschema: TSchemaName;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>(name, schema, baseName);\n\n\tconst parsedColumns: TColumnsMap = typeof columns === 'function' ? columns(getGelColumnBuilders()) : columns;\n\n\tconst builtColumns = Object.fromEntries(\n\t\tObject.entries(parsedColumns).map(([name, colBuilderBase]) => {\n\t\t\tconst colBuilder = colBuilderBase as GelColumnBuilder;\n\t\t\tcolBuilder.setName(name);\n\t\t\tconst column = colBuilder.build(rawTable);\n\t\t\trawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n\t\t\treturn [name, column];\n\t\t}),\n\t) as unknown as BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\n\tconst builtColumnsForExtraConfig = Object.fromEntries(\n\t\tObject.entries(parsedColumns).map(([name, colBuilderBase]) => {\n\t\t\tconst colBuilder = colBuilderBase as GelColumnBuilder;\n\t\t\tcolBuilder.setName(name);\n\t\t\tconst column = colBuilder.buildExtraConfigColumn(rawTable);\n\t\t\treturn [name, column];\n\t\t}),\n\t) as unknown as BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>;\n\n\tconst table = Object.assign(rawTable, builtColumns);\n\n\ttable[Table.Symbol.Columns] = builtColumns;\n\ttable[Table.Symbol.ExtraConfigColumns] = builtColumnsForExtraConfig;\n\n\tif (extraConfig) {\n\t\ttable[GelTable.Symbol.ExtraConfigBuilder] = extraConfig as any;\n\t}\n\n\treturn Object.assign(table, {\n\t\tenableRLS: () => {\n\t\t\ttable[GelTable.Symbol.EnableRLS] = true;\n\t\t\treturn table as GelTableWithColumns<{\n\t\t\t\tname: TTableName;\n\t\t\t\tschema: TSchemaName;\n\t\t\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\t\t\tdialect: 'gel';\n\t\t\t}>;\n\t\t},\n\t}) as any;\n}\n\nexport interface GelTableFn<TSchema extends string | undefined = undefined> {\n\t/**\n\t * @deprecated The third parameter of GelTable is changing and will only accept an array instead of an object\n\t *\n\t * @example\n\t * Deprecated version:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => ({\n\t * \tidx: index('custom_name').on(t.id)\n\t * }));\n\t * ```\n\t *\n\t * New API:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => [\n\t * \tindex('custom_name').on(t.id)\n\t * ]);\n\t * ```\n\t */\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig: (\n\t\t\tself: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>,\n\t\t) => GelTableExtraConfig,\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n\n\t/**\n\t * @deprecated The third parameter of gelTable is changing and will only accept an array instead of an object\n\t *\n\t * @example\n\t * Deprecated version:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => ({\n\t * \tidx: index('custom_name').on(t.id)\n\t * }));\n\t * ```\n\t *\n\t * New API:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => [\n\t * \tindex('custom_name').on(t.id)\n\t * ]);\n\t * ```\n\t */\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: (columnTypes: GelColumnsBuilders) => TColumnsMap,\n\t\textraConfig: (self: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>) => GelTableExtraConfig,\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig?: (\n\t\t\tself: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>,\n\t\t) => GelTableExtraConfigValue[],\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: (columnTypes: GelColumnsBuilders) => TColumnsMap,\n\t\textraConfig?: (self: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>) => GelTableExtraConfigValue[],\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n}\n\nexport const gelTable: GelTableFn = (name, columns, extraConfig) => {\n\treturn gelTableWithSchema(name, columns, extraConfig, undefined);\n};\n\nexport function gelTableCreator(customizeTableName: (name: string) => string): GelTableFn {\n\treturn (name, columns, extraConfig) => {\n\t\treturn gelTableWithSchema(customizeTableName(name) as typeof name, columns, extraConfig, undefined, name);\n\t};\n}\n"],"mappings":";;;;;;;;AAiCA,MAAa,oBAAoB,OAAO,IAAI,+BAA+B;;AAE3E,MAAa,YAAY,OAAO,IAAI,oBAAoB;AAExD,IAAa,WAAb,cAAmEA,iBAAS;CAC3E,QAA0BC,0BAAsB;;CAGhD,OAAyB,SAAS,OAAO,OAAO,EAAE,EAAED,iBAAM,QAAQ;EAC9C;EACR;EACX,CAAC;;CAGF,CAAC,qBAAmC,EAAE;;CAGtC,CAAC,aAAsB;;CAGvB,CAAUA,iBAAM,OAAO,sBACtB;;CAGD,CAAUA,iBAAM,OAAO,sBAA4D,EAAE;;;AAmBtF,SAAgB,mBAKf,MACA,SACA,aAKA,QACA,WAAW,MAMT;CACF,MAAM,WAAW,IAAI,SAKlB,MAAM,QAAQ,SAAS;CAE1B,MAAM,gBAA6B,OAAO,YAAY,aAAa,QAAQE,mDAAsB,CAAC,GAAG;CAErG,MAAM,eAAe,OAAO,YAC3B,OAAO,QAAQ,cAAc,CAAC,KAAK,CAAC,MAAM,oBAAoB;EAC7D,MAAM,aAAa;AACnB,aAAW,QAAQ,KAAK;EACxB,MAAM,SAAS,WAAW,MAAM,SAAS;AACzC,WAAS,mBAAmB,KAAK,GAAG,WAAW,iBAAiB,QAAQ,SAAS,CAAC;AAClF,SAAO,CAAC,MAAM,OAAO;GACpB,CACF;CAED,MAAM,6BAA6B,OAAO,YACzC,OAAO,QAAQ,cAAc,CAAC,KAAK,CAAC,MAAM,oBAAoB;EAC7D,MAAM,aAAa;AACnB,aAAW,QAAQ,KAAK;AAExB,SAAO,CAAC,MADO,WAAW,uBAAuB,SAAS,CACrC;GACpB,CACF;CAED,MAAM,QAAQ,OAAO,OAAO,UAAU,aAAa;AAEnD,OAAMF,iBAAM,OAAO,WAAW;AAC9B,OAAMA,iBAAM,OAAO,sBAAsB;AAEzC,KAAI,YACH,OAAM,SAAS,OAAO,sBAAsB;AAG7C,QAAO,OAAO,OAAO,OAAO,EAC3B,iBAAiB;AAChB,QAAM,SAAS,OAAO,aAAa;AACnC,SAAO;IAOR,CAAC;;AA6GH,MAAa,YAAwB,MAAM,SAAS,gBAAgB;AACnE,QAAO,mBAAmB,MAAM,SAAS,aAAa,OAAU;;AAGjE,SAAgB,gBAAgB,oBAA0D;AACzF,SAAQ,MAAM,SAAS,gBAAgB;AACtC,SAAO,mBAAmB,mBAAmB,KAAK,EAAiB,SAAS,aAAa,QAAW,KAAK"}
package/gel-core/table.js CHANGED
@@ -30,7 +30,7 @@ function gelTableWithSchema(name, columns, extraConfig, schema, baseName = name)
30
30
  const builtColumns = Object.fromEntries(Object.entries(parsedColumns).map(([name, colBuilderBase]) => {
31
31
  const colBuilder = colBuilderBase;
32
32
  colBuilder.setName(name);
33
- const column = colBuilder.build(rawTable).postBuild();
33
+ const column = colBuilder.build(rawTable);
34
34
  rawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));
35
35
  return [name, column];
36
36
  }));
@@ -1 +1 @@
1
- {"version":3,"file":"table.js","names":[],"sources":["../../src/gel-core/table.ts"],"sourcesContent":["import type { BuildColumns, BuildExtraConfigColumns, ColumnBuilderBase } from '~/column-builder.ts';\nimport { entityKind } from '~/entity.ts';\nimport {\n\ttype InferTableColumnsModels,\n\tTable,\n\ttype TableConfig as TableConfigBase,\n\ttype UpdateTableConfig,\n} from '~/table.ts';\nimport type { CheckBuilder } from './checks.ts';\nimport { type GelColumnsBuilders, getGelColumnBuilders } from './columns/all.ts';\nimport type { GelColumn, GelColumnBuilder, GelColumns, GelExtraConfigColumn } from './columns/common.ts';\nimport type { ForeignKey, ForeignKeyBuilder } from './foreign-keys.ts';\nimport type { AnyIndexBuilder } from './indexes.ts';\nimport type { GelPolicy } from './policies.ts';\nimport type { PrimaryKeyBuilder } from './primary-keys.ts';\nimport type { UniqueConstraintBuilder } from './unique-constraint.ts';\n\nexport type GelTableExtraConfigValue =\n\t| AnyIndexBuilder\n\t| CheckBuilder\n\t| ForeignKeyBuilder\n\t| PrimaryKeyBuilder\n\t| UniqueConstraintBuilder\n\t| GelPolicy;\n\nexport type GelTableExtraConfig = Record<\n\tstring,\n\tGelTableExtraConfigValue\n>;\n\nexport type TableConfig = TableConfigBase<GelColumns>;\n\n/** @internal */\nexport const InlineForeignKeys = Symbol.for('drizzle:GelInlineForeignKeys');\n/** @internal */\nexport const EnableRLS = Symbol.for('drizzle:EnableRLS');\n\nexport class GelTable<T extends TableConfig = TableConfig> extends Table<T> {\n\tstatic override readonly [entityKind]: string = 'GelTable';\n\n\t/** @internal */\n\tstatic override readonly Symbol = Object.assign({}, Table.Symbol, {\n\t\tInlineForeignKeys: InlineForeignKeys as typeof InlineForeignKeys,\n\t\tEnableRLS: EnableRLS as typeof EnableRLS,\n\t});\n\n\t/**@internal */\n\t[InlineForeignKeys]: ForeignKey[] = [];\n\n\t/** @internal */\n\t[EnableRLS]: boolean = false;\n\n\t/** @internal */\n\toverride [Table.Symbol.ExtraConfigBuilder]: ((self: Record<string, GelColumn>) => GelTableExtraConfig) | undefined =\n\t\tundefined;\n\n\t/** @internal */\n\toverride [Table.Symbol.ExtraConfigColumns]: Record<string, GelExtraConfigColumn> = {};\n}\n\nexport type AnyGelTable<TPartial extends Partial<TableConfig> = {}> = GelTable<\n\tUpdateTableConfig<TableConfig, TPartial>\n>;\n\nexport type GelTableWithColumns<T extends TableConfig> =\n\t& GelTable<T>\n\t& T['columns']\n\t& InferTableColumnsModels<T['columns']>\n\t& {\n\t\tenableRLS: () => Omit<\n\t\t\tGelTableWithColumns<T>,\n\t\t\t'enableRLS'\n\t\t>;\n\t};\n\n/** @internal */\nexport function gelTableWithSchema<\n\tTTableName extends string,\n\tTSchemaName extends string | undefined,\n\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n>(\n\tname: TTableName,\n\tcolumns: TColumnsMap | ((columnTypes: GelColumnsBuilders) => TColumnsMap),\n\textraConfig:\n\t\t| ((\n\t\t\tself: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>,\n\t\t) => GelTableExtraConfig | GelTableExtraConfigValue[])\n\t\t| undefined,\n\tschema: TSchemaName,\n\tbaseName = name,\n): GelTableWithColumns<{\n\tname: TTableName;\n\tschema: TSchemaName;\n\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\tdialect: 'gel';\n}> {\n\tconst rawTable = new GelTable<{\n\t\tname: TTableName;\n\t\tschema: TSchemaName;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>(name, schema, baseName);\n\n\tconst parsedColumns: TColumnsMap = typeof columns === 'function' ? columns(getGelColumnBuilders()) : columns;\n\n\tconst builtColumns = Object.fromEntries(\n\t\tObject.entries(parsedColumns).map(([name, colBuilderBase]) => {\n\t\t\tconst colBuilder = colBuilderBase as GelColumnBuilder;\n\t\t\tcolBuilder.setName(name);\n\t\t\tconst column = colBuilder.build(rawTable).postBuild();\n\t\t\trawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n\t\t\treturn [name, column];\n\t\t}),\n\t) as unknown as BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\n\tconst builtColumnsForExtraConfig = Object.fromEntries(\n\t\tObject.entries(parsedColumns).map(([name, colBuilderBase]) => {\n\t\t\tconst colBuilder = colBuilderBase as GelColumnBuilder;\n\t\t\tcolBuilder.setName(name);\n\t\t\tconst column = colBuilder.buildExtraConfigColumn(rawTable);\n\t\t\treturn [name, column];\n\t\t}),\n\t) as unknown as BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>;\n\n\tconst table = Object.assign(rawTable, builtColumns);\n\n\ttable[Table.Symbol.Columns] = builtColumns;\n\ttable[Table.Symbol.ExtraConfigColumns] = builtColumnsForExtraConfig;\n\n\tif (extraConfig) {\n\t\ttable[GelTable.Symbol.ExtraConfigBuilder] = extraConfig as any;\n\t}\n\n\treturn Object.assign(table, {\n\t\tenableRLS: () => {\n\t\t\ttable[GelTable.Symbol.EnableRLS] = true;\n\t\t\treturn table as GelTableWithColumns<{\n\t\t\t\tname: TTableName;\n\t\t\t\tschema: TSchemaName;\n\t\t\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\t\t\tdialect: 'gel';\n\t\t\t}>;\n\t\t},\n\t}) as any;\n}\n\nexport interface GelTableFn<TSchema extends string | undefined = undefined> {\n\t/**\n\t * @deprecated The third parameter of GelTable is changing and will only accept an array instead of an object\n\t *\n\t * @example\n\t * Deprecated version:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => ({\n\t * \tidx: index('custom_name').on(t.id)\n\t * }));\n\t * ```\n\t *\n\t * New API:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => [\n\t * \tindex('custom_name').on(t.id)\n\t * ]);\n\t * ```\n\t */\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig: (\n\t\t\tself: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>,\n\t\t) => GelTableExtraConfig,\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n\n\t/**\n\t * @deprecated The third parameter of gelTable is changing and will only accept an array instead of an object\n\t *\n\t * @example\n\t * Deprecated version:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => ({\n\t * \tidx: index('custom_name').on(t.id)\n\t * }));\n\t * ```\n\t *\n\t * New API:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => [\n\t * \tindex('custom_name').on(t.id)\n\t * ]);\n\t * ```\n\t */\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: (columnTypes: GelColumnsBuilders) => TColumnsMap,\n\t\textraConfig: (self: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>) => GelTableExtraConfig,\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig?: (\n\t\t\tself: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>,\n\t\t) => GelTableExtraConfigValue[],\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: (columnTypes: GelColumnsBuilders) => TColumnsMap,\n\t\textraConfig?: (self: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>) => GelTableExtraConfigValue[],\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n}\n\nexport const gelTable: GelTableFn = (name, columns, extraConfig) => {\n\treturn gelTableWithSchema(name, columns, extraConfig, undefined);\n};\n\nexport function gelTableCreator(customizeTableName: (name: string) => string): GelTableFn {\n\treturn (name, columns, extraConfig) => {\n\t\treturn gelTableWithSchema(customizeTableName(name) as typeof name, columns, extraConfig, undefined, name);\n\t};\n}\n"],"mappings":";;;;;;AAiCA,MAAa,oBAAoB,OAAO,IAAI,+BAA+B;;AAE3E,MAAa,YAAY,OAAO,IAAI,oBAAoB;AAExD,IAAa,WAAb,cAAmE,MAAS;CAC3E,QAA0B,cAAsB;;CAGhD,OAAyB,SAAS,OAAO,OAAO,EAAE,EAAE,MAAM,QAAQ;EAC9C;EACR;EACX,CAAC;;CAGF,CAAC,qBAAmC,EAAE;;CAGtC,CAAC,aAAsB;;CAGvB,CAAU,MAAM,OAAO,sBACtB;;CAGD,CAAU,MAAM,OAAO,sBAA4D,EAAE;;;AAmBtF,SAAgB,mBAKf,MACA,SACA,aAKA,QACA,WAAW,MAMT;CACF,MAAM,WAAW,IAAI,SAKlB,MAAM,QAAQ,SAAS;CAE1B,MAAM,gBAA6B,OAAO,YAAY,aAAa,QAAQ,sBAAsB,CAAC,GAAG;CAErG,MAAM,eAAe,OAAO,YAC3B,OAAO,QAAQ,cAAc,CAAC,KAAK,CAAC,MAAM,oBAAoB;EAC7D,MAAM,aAAa;AACnB,aAAW,QAAQ,KAAK;EACxB,MAAM,SAAS,WAAW,MAAM,SAAS,CAAC,WAAW;AACrD,WAAS,mBAAmB,KAAK,GAAG,WAAW,iBAAiB,QAAQ,SAAS,CAAC;AAClF,SAAO,CAAC,MAAM,OAAO;GACpB,CACF;CAED,MAAM,6BAA6B,OAAO,YACzC,OAAO,QAAQ,cAAc,CAAC,KAAK,CAAC,MAAM,oBAAoB;EAC7D,MAAM,aAAa;AACnB,aAAW,QAAQ,KAAK;AAExB,SAAO,CAAC,MADO,WAAW,uBAAuB,SAAS,CACrC;GACpB,CACF;CAED,MAAM,QAAQ,OAAO,OAAO,UAAU,aAAa;AAEnD,OAAM,MAAM,OAAO,WAAW;AAC9B,OAAM,MAAM,OAAO,sBAAsB;AAEzC,KAAI,YACH,OAAM,SAAS,OAAO,sBAAsB;AAG7C,QAAO,OAAO,OAAO,OAAO,EAC3B,iBAAiB;AAChB,QAAM,SAAS,OAAO,aAAa;AACnC,SAAO;IAOR,CAAC;;AA6GH,MAAa,YAAwB,MAAM,SAAS,gBAAgB;AACnE,QAAO,mBAAmB,MAAM,SAAS,aAAa,OAAU;;AAGjE,SAAgB,gBAAgB,oBAA0D;AACzF,SAAQ,MAAM,SAAS,gBAAgB;AACtC,SAAO,mBAAmB,mBAAmB,KAAK,EAAiB,SAAS,aAAa,QAAW,KAAK"}
1
+ {"version":3,"file":"table.js","names":[],"sources":["../../src/gel-core/table.ts"],"sourcesContent":["import type { BuildColumns, BuildExtraConfigColumns, ColumnBuilderBase } from '~/column-builder.ts';\nimport { entityKind } from '~/entity.ts';\nimport {\n\ttype InferTableColumnsModels,\n\tTable,\n\ttype TableConfig as TableConfigBase,\n\ttype UpdateTableConfig,\n} from '~/table.ts';\nimport type { CheckBuilder } from './checks.ts';\nimport { type GelColumnsBuilders, getGelColumnBuilders } from './columns/all.ts';\nimport type { GelColumn, GelColumnBuilder, GelColumns, GelExtraConfigColumn } from './columns/common.ts';\nimport type { ForeignKey, ForeignKeyBuilder } from './foreign-keys.ts';\nimport type { AnyIndexBuilder } from './indexes.ts';\nimport type { GelPolicy } from './policies.ts';\nimport type { PrimaryKeyBuilder } from './primary-keys.ts';\nimport type { UniqueConstraintBuilder } from './unique-constraint.ts';\n\nexport type GelTableExtraConfigValue =\n\t| AnyIndexBuilder\n\t| CheckBuilder\n\t| ForeignKeyBuilder\n\t| PrimaryKeyBuilder\n\t| UniqueConstraintBuilder\n\t| GelPolicy;\n\nexport type GelTableExtraConfig = Record<\n\tstring,\n\tGelTableExtraConfigValue\n>;\n\nexport type TableConfig = TableConfigBase<GelColumns>;\n\n/** @internal */\nexport const InlineForeignKeys = Symbol.for('drizzle:GelInlineForeignKeys');\n/** @internal */\nexport const EnableRLS = Symbol.for('drizzle:EnableRLS');\n\nexport class GelTable<T extends TableConfig = TableConfig> extends Table<T> {\n\tstatic override readonly [entityKind]: string = 'GelTable';\n\n\t/** @internal */\n\tstatic override readonly Symbol = Object.assign({}, Table.Symbol, {\n\t\tInlineForeignKeys: InlineForeignKeys as typeof InlineForeignKeys,\n\t\tEnableRLS: EnableRLS as typeof EnableRLS,\n\t});\n\n\t/**@internal */\n\t[InlineForeignKeys]: ForeignKey[] = [];\n\n\t/** @internal */\n\t[EnableRLS]: boolean = false;\n\n\t/** @internal */\n\toverride [Table.Symbol.ExtraConfigBuilder]: ((self: Record<string, GelColumn>) => GelTableExtraConfig) | undefined =\n\t\tundefined;\n\n\t/** @internal */\n\toverride [Table.Symbol.ExtraConfigColumns]: Record<string, GelExtraConfigColumn> = {};\n}\n\nexport type AnyGelTable<TPartial extends Partial<TableConfig> = {}> = GelTable<\n\tUpdateTableConfig<TableConfig, TPartial>\n>;\n\nexport type GelTableWithColumns<T extends TableConfig> =\n\t& GelTable<T>\n\t& T['columns']\n\t& InferTableColumnsModels<T['columns']>\n\t& {\n\t\tenableRLS: () => Omit<\n\t\t\tGelTableWithColumns<T>,\n\t\t\t'enableRLS'\n\t\t>;\n\t};\n\n/** @internal */\nexport function gelTableWithSchema<\n\tTTableName extends string,\n\tTSchemaName extends string | undefined,\n\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n>(\n\tname: TTableName,\n\tcolumns: TColumnsMap | ((columnTypes: GelColumnsBuilders) => TColumnsMap),\n\textraConfig:\n\t\t| ((\n\t\t\tself: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>,\n\t\t) => GelTableExtraConfig | GelTableExtraConfigValue[])\n\t\t| undefined,\n\tschema: TSchemaName,\n\tbaseName = name,\n): GelTableWithColumns<{\n\tname: TTableName;\n\tschema: TSchemaName;\n\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\tdialect: 'gel';\n}> {\n\tconst rawTable = new GelTable<{\n\t\tname: TTableName;\n\t\tschema: TSchemaName;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>(name, schema, baseName);\n\n\tconst parsedColumns: TColumnsMap = typeof columns === 'function' ? columns(getGelColumnBuilders()) : columns;\n\n\tconst builtColumns = Object.fromEntries(\n\t\tObject.entries(parsedColumns).map(([name, colBuilderBase]) => {\n\t\t\tconst colBuilder = colBuilderBase as GelColumnBuilder;\n\t\t\tcolBuilder.setName(name);\n\t\t\tconst column = colBuilder.build(rawTable);\n\t\t\trawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n\t\t\treturn [name, column];\n\t\t}),\n\t) as unknown as BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\n\tconst builtColumnsForExtraConfig = Object.fromEntries(\n\t\tObject.entries(parsedColumns).map(([name, colBuilderBase]) => {\n\t\t\tconst colBuilder = colBuilderBase as GelColumnBuilder;\n\t\t\tcolBuilder.setName(name);\n\t\t\tconst column = colBuilder.buildExtraConfigColumn(rawTable);\n\t\t\treturn [name, column];\n\t\t}),\n\t) as unknown as BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>;\n\n\tconst table = Object.assign(rawTable, builtColumns);\n\n\ttable[Table.Symbol.Columns] = builtColumns;\n\ttable[Table.Symbol.ExtraConfigColumns] = builtColumnsForExtraConfig;\n\n\tif (extraConfig) {\n\t\ttable[GelTable.Symbol.ExtraConfigBuilder] = extraConfig as any;\n\t}\n\n\treturn Object.assign(table, {\n\t\tenableRLS: () => {\n\t\t\ttable[GelTable.Symbol.EnableRLS] = true;\n\t\t\treturn table as GelTableWithColumns<{\n\t\t\t\tname: TTableName;\n\t\t\t\tschema: TSchemaName;\n\t\t\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\t\t\tdialect: 'gel';\n\t\t\t}>;\n\t\t},\n\t}) as any;\n}\n\nexport interface GelTableFn<TSchema extends string | undefined = undefined> {\n\t/**\n\t * @deprecated The third parameter of GelTable is changing and will only accept an array instead of an object\n\t *\n\t * @example\n\t * Deprecated version:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => ({\n\t * \tidx: index('custom_name').on(t.id)\n\t * }));\n\t * ```\n\t *\n\t * New API:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => [\n\t * \tindex('custom_name').on(t.id)\n\t * ]);\n\t * ```\n\t */\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig: (\n\t\t\tself: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>,\n\t\t) => GelTableExtraConfig,\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n\n\t/**\n\t * @deprecated The third parameter of gelTable is changing and will only accept an array instead of an object\n\t *\n\t * @example\n\t * Deprecated version:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => ({\n\t * \tidx: index('custom_name').on(t.id)\n\t * }));\n\t * ```\n\t *\n\t * New API:\n\t * ```ts\n\t * export const users = gelTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => [\n\t * \tindex('custom_name').on(t.id)\n\t * ]);\n\t * ```\n\t */\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: (columnTypes: GelColumnsBuilders) => TColumnsMap,\n\t\textraConfig: (self: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>) => GelTableExtraConfig,\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig?: (\n\t\t\tself: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>,\n\t\t) => GelTableExtraConfigValue[],\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, ColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: (columnTypes: GelColumnsBuilders) => TColumnsMap,\n\t\textraConfig?: (self: BuildExtraConfigColumns<TTableName, TColumnsMap, 'gel'>) => GelTableExtraConfigValue[],\n\t): GelTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'gel'>;\n\t\tdialect: 'gel';\n\t}>;\n}\n\nexport const gelTable: GelTableFn = (name, columns, extraConfig) => {\n\treturn gelTableWithSchema(name, columns, extraConfig, undefined);\n};\n\nexport function gelTableCreator(customizeTableName: (name: string) => string): GelTableFn {\n\treturn (name, columns, extraConfig) => {\n\t\treturn gelTableWithSchema(customizeTableName(name) as typeof name, columns, extraConfig, undefined, name);\n\t};\n}\n"],"mappings":";;;;;;AAiCA,MAAa,oBAAoB,OAAO,IAAI,+BAA+B;;AAE3E,MAAa,YAAY,OAAO,IAAI,oBAAoB;AAExD,IAAa,WAAb,cAAmE,MAAS;CAC3E,QAA0B,cAAsB;;CAGhD,OAAyB,SAAS,OAAO,OAAO,EAAE,EAAE,MAAM,QAAQ;EAC9C;EACR;EACX,CAAC;;CAGF,CAAC,qBAAmC,EAAE;;CAGtC,CAAC,aAAsB;;CAGvB,CAAU,MAAM,OAAO,sBACtB;;CAGD,CAAU,MAAM,OAAO,sBAA4D,EAAE;;;AAmBtF,SAAgB,mBAKf,MACA,SACA,aAKA,QACA,WAAW,MAMT;CACF,MAAM,WAAW,IAAI,SAKlB,MAAM,QAAQ,SAAS;CAE1B,MAAM,gBAA6B,OAAO,YAAY,aAAa,QAAQ,sBAAsB,CAAC,GAAG;CAErG,MAAM,eAAe,OAAO,YAC3B,OAAO,QAAQ,cAAc,CAAC,KAAK,CAAC,MAAM,oBAAoB;EAC7D,MAAM,aAAa;AACnB,aAAW,QAAQ,KAAK;EACxB,MAAM,SAAS,WAAW,MAAM,SAAS;AACzC,WAAS,mBAAmB,KAAK,GAAG,WAAW,iBAAiB,QAAQ,SAAS,CAAC;AAClF,SAAO,CAAC,MAAM,OAAO;GACpB,CACF;CAED,MAAM,6BAA6B,OAAO,YACzC,OAAO,QAAQ,cAAc,CAAC,KAAK,CAAC,MAAM,oBAAoB;EAC7D,MAAM,aAAa;AACnB,aAAW,QAAQ,KAAK;AAExB,SAAO,CAAC,MADO,WAAW,uBAAuB,SAAS,CACrC;GACpB,CACF;CAED,MAAM,QAAQ,OAAO,OAAO,UAAU,aAAa;AAEnD,OAAM,MAAM,OAAO,WAAW;AAC9B,OAAM,MAAM,OAAO,sBAAsB;AAEzC,KAAI,YACH,OAAM,SAAS,OAAO,sBAAsB;AAG7C,QAAO,OAAO,OAAO,OAAO,EAC3B,iBAAiB;AAChB,QAAM,SAAS,OAAO,aAAa;AACnC,SAAO;IAOR,CAAC;;AA6GH,MAAa,YAAwB,MAAM,SAAS,gBAAgB;AACnE,QAAO,mBAAmB,MAAM,SAAS,aAAa,OAAU;;AAGjE,SAAgB,gBAAgB,oBAA0D;AACzF,SAAQ,MAAM,SAAS,gBAAgB;AACtC,SAAO,mBAAmB,mBAAmB,KAAK,EAAiB,SAAS,aAAa,QAAW,KAAK"}