drizzle-orm 0.39.2-1177ad8 → 0.39.2-8628c8a

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 (587) hide show
  1. package/aws-data-api/pg/driver.cjs +1 -5
  2. package/aws-data-api/pg/driver.cjs.map +1 -1
  3. package/aws-data-api/pg/driver.d.cts +0 -1
  4. package/aws-data-api/pg/driver.d.ts +0 -1
  5. package/aws-data-api/pg/driver.js +1 -5
  6. package/aws-data-api/pg/driver.js.map +1 -1
  7. package/aws-data-api/pg/session.cjs +4 -15
  8. package/aws-data-api/pg/session.cjs.map +1 -1
  9. package/aws-data-api/pg/session.d.cts +3 -13
  10. package/aws-data-api/pg/session.d.ts +3 -13
  11. package/aws-data-api/pg/session.js +4 -15
  12. package/aws-data-api/pg/session.js.map +1 -1
  13. package/bun-sql/driver.cjs +1 -5
  14. package/bun-sql/driver.cjs.map +1 -1
  15. package/bun-sql/driver.js +1 -5
  16. package/bun-sql/driver.js.map +1 -1
  17. package/bun-sql/session.cjs +9 -21
  18. package/bun-sql/session.cjs.map +1 -1
  19. package/bun-sql/session.d.cts +3 -12
  20. package/bun-sql/session.d.ts +3 -12
  21. package/bun-sql/session.js +9 -21
  22. package/bun-sql/session.js.map +1 -1
  23. package/column-builder.cjs.map +1 -1
  24. package/column-builder.d.cts +6 -5
  25. package/column-builder.d.ts +6 -5
  26. package/column-builder.js.map +1 -1
  27. package/gel/driver.cjs +97 -0
  28. package/gel/driver.cjs.map +1 -0
  29. package/gel/driver.d.cts +38 -0
  30. package/gel/driver.d.ts +38 -0
  31. package/gel/driver.js +74 -0
  32. package/gel/driver.js.map +1 -0
  33. package/{cache/core → gel}/index.cjs +6 -4
  34. package/gel/index.cjs.map +1 -0
  35. package/gel/index.d.cts +2 -0
  36. package/gel/index.d.ts +2 -0
  37. package/gel/index.js +3 -0
  38. package/gel/index.js.map +1 -0
  39. package/gel/migrator.cjs +5 -0
  40. package/gel/migrator.cjs.map +1 -0
  41. package/gel/migrator.d.cts +1 -0
  42. package/gel/migrator.d.ts +1 -0
  43. package/gel/migrator.js +4 -0
  44. package/gel/migrator.js.map +1 -0
  45. package/gel/session.cjs +139 -0
  46. package/gel/session.cjs.map +1 -0
  47. package/gel/session.d.cts +47 -0
  48. package/gel/session.d.ts +47 -0
  49. package/gel/session.js +113 -0
  50. package/gel/session.js.map +1 -0
  51. package/gel-core/alias.cjs +32 -0
  52. package/gel-core/alias.cjs.map +1 -0
  53. package/gel-core/alias.d.cts +4 -0
  54. package/gel-core/alias.d.ts +4 -0
  55. package/gel-core/alias.js +8 -0
  56. package/gel-core/alias.js.map +1 -0
  57. package/gel-core/checks.cjs +58 -0
  58. package/gel-core/checks.cjs.map +1 -0
  59. package/gel-core/checks.d.cts +18 -0
  60. package/gel-core/checks.d.ts +18 -0
  61. package/gel-core/checks.js +32 -0
  62. package/gel-core/checks.js.map +1 -0
  63. package/gel-core/columns/all.cjs +72 -0
  64. package/gel-core/columns/all.cjs.map +1 -0
  65. package/gel-core/columns/all.d.cts +43 -0
  66. package/gel-core/columns/all.d.ts +43 -0
  67. package/gel-core/columns/all.js +48 -0
  68. package/gel-core/columns/all.js.map +1 -0
  69. package/gel-core/columns/bigint.cjs +54 -0
  70. package/gel-core/columns/bigint.cjs.map +1 -0
  71. package/gel-core/columns/bigint.d.cts +23 -0
  72. package/gel-core/columns/bigint.d.ts +23 -0
  73. package/gel-core/columns/bigint.js +28 -0
  74. package/gel-core/columns/bigint.js.map +1 -0
  75. package/gel-core/columns/bigintT.cjs +60 -0
  76. package/gel-core/columns/bigintT.cjs.map +1 -0
  77. package/gel-core/columns/bigintT.d.cts +24 -0
  78. package/gel-core/columns/bigintT.d.ts +24 -0
  79. package/gel-core/columns/bigintT.js +34 -0
  80. package/gel-core/columns/bigintT.js.map +1 -0
  81. package/gel-core/columns/boolean.cjs +53 -0
  82. package/gel-core/columns/boolean.cjs.map +1 -0
  83. package/gel-core/columns/boolean.d.cts +22 -0
  84. package/gel-core/columns/boolean.d.ts +22 -0
  85. package/gel-core/columns/boolean.js +27 -0
  86. package/gel-core/columns/boolean.js.map +1 -0
  87. package/gel-core/columns/bytes.cjs +56 -0
  88. package/gel-core/columns/bytes.cjs.map +1 -0
  89. package/gel-core/columns/bytes.d.cts +22 -0
  90. package/gel-core/columns/bytes.d.ts +22 -0
  91. package/gel-core/columns/bytes.js +30 -0
  92. package/gel-core/columns/bytes.js.map +1 -0
  93. package/gel-core/columns/common.cjs +213 -0
  94. package/gel-core/columns/common.cjs.map +1 -0
  95. package/gel-core/columns/common.d.cts +147 -0
  96. package/gel-core/columns/common.d.ts +147 -0
  97. package/gel-core/columns/common.js +184 -0
  98. package/gel-core/columns/common.js.map +1 -0
  99. package/gel-core/columns/custom.cjs +77 -0
  100. package/gel-core/columns/custom.cjs.map +1 -0
  101. package/gel-core/columns/custom.d.cts +155 -0
  102. package/gel-core/columns/custom.d.ts +155 -0
  103. package/gel-core/columns/custom.js +51 -0
  104. package/gel-core/columns/custom.js.map +1 -0
  105. package/gel-core/columns/date-duration.cjs +56 -0
  106. package/gel-core/columns/date-duration.cjs.map +1 -0
  107. package/gel-core/columns/date-duration.d.cts +23 -0
  108. package/gel-core/columns/date-duration.d.ts +23 -0
  109. package/gel-core/columns/date-duration.js +30 -0
  110. package/gel-core/columns/date-duration.js.map +1 -0
  111. package/{cache/core/cache.cjs → gel-core/columns/date.common.cjs} +12 -22
  112. package/gel-core/columns/date.common.cjs.map +1 -0
  113. package/gel-core/columns/date.common.d.cts +7 -0
  114. package/gel-core/columns/date.common.d.ts +7 -0
  115. package/gel-core/columns/date.common.js +13 -0
  116. package/gel-core/columns/date.common.js.map +1 -0
  117. package/gel-core/columns/decimal.cjs +56 -0
  118. package/gel-core/columns/decimal.cjs.map +1 -0
  119. package/gel-core/columns/decimal.d.cts +26 -0
  120. package/gel-core/columns/decimal.d.ts +26 -0
  121. package/gel-core/columns/decimal.js +30 -0
  122. package/gel-core/columns/decimal.js.map +1 -0
  123. package/gel-core/columns/double-precision.cjs +62 -0
  124. package/gel-core/columns/double-precision.cjs.map +1 -0
  125. package/gel-core/columns/double-precision.d.cts +23 -0
  126. package/gel-core/columns/double-precision.d.ts +23 -0
  127. package/gel-core/columns/double-precision.js +36 -0
  128. package/gel-core/columns/double-precision.js.map +1 -0
  129. package/gel-core/columns/duration.cjs +53 -0
  130. package/gel-core/columns/duration.cjs.map +1 -0
  131. package/gel-core/columns/duration.d.cts +23 -0
  132. package/gel-core/columns/duration.d.ts +23 -0
  133. package/gel-core/columns/duration.js +27 -0
  134. package/gel-core/columns/duration.js.map +1 -0
  135. package/gel-core/columns/index.cjs +65 -0
  136. package/gel-core/columns/index.cjs.map +1 -0
  137. package/gel-core/columns/index.d.cts +22 -0
  138. package/gel-core/columns/index.d.ts +22 -0
  139. package/gel-core/columns/index.js +23 -0
  140. package/gel-core/columns/index.js.map +1 -0
  141. package/gel-core/columns/int.common.cjs +67 -0
  142. package/gel-core/columns/int.common.cjs.map +1 -0
  143. package/gel-core/columns/int.common.d.cts +15 -0
  144. package/gel-core/columns/int.common.d.ts +15 -0
  145. package/gel-core/columns/int.common.js +43 -0
  146. package/gel-core/columns/int.common.js.map +1 -0
  147. package/gel-core/columns/integer.cjs +54 -0
  148. package/gel-core/columns/integer.cjs.map +1 -0
  149. package/gel-core/columns/integer.d.cts +23 -0
  150. package/gel-core/columns/integer.d.ts +23 -0
  151. package/gel-core/columns/integer.js +28 -0
  152. package/gel-core/columns/integer.js.map +1 -0
  153. package/gel-core/columns/json.cjs +56 -0
  154. package/gel-core/columns/json.cjs.map +1 -0
  155. package/gel-core/columns/json.d.cts +26 -0
  156. package/gel-core/columns/json.d.ts +26 -0
  157. package/gel-core/columns/json.js +30 -0
  158. package/gel-core/columns/json.js.map +1 -0
  159. package/gel-core/columns/localdate.cjs +57 -0
  160. package/gel-core/columns/localdate.cjs.map +1 -0
  161. package/gel-core/columns/localdate.d.cts +24 -0
  162. package/gel-core/columns/localdate.d.ts +24 -0
  163. package/gel-core/columns/localdate.js +31 -0
  164. package/gel-core/columns/localdate.js.map +1 -0
  165. package/gel-core/columns/localtime.cjs +57 -0
  166. package/gel-core/columns/localtime.cjs.map +1 -0
  167. package/gel-core/columns/localtime.d.cts +24 -0
  168. package/gel-core/columns/localtime.d.ts +24 -0
  169. package/gel-core/columns/localtime.js +31 -0
  170. package/gel-core/columns/localtime.js.map +1 -0
  171. package/gel-core/columns/real.cjs +57 -0
  172. package/gel-core/columns/real.cjs.map +1 -0
  173. package/gel-core/columns/real.d.cts +28 -0
  174. package/gel-core/columns/real.d.ts +28 -0
  175. package/gel-core/columns/real.js +31 -0
  176. package/gel-core/columns/real.js.map +1 -0
  177. package/gel-core/columns/relative-duration.cjs +56 -0
  178. package/gel-core/columns/relative-duration.cjs.map +1 -0
  179. package/gel-core/columns/relative-duration.d.cts +23 -0
  180. package/gel-core/columns/relative-duration.d.ts +23 -0
  181. package/gel-core/columns/relative-duration.js +30 -0
  182. package/gel-core/columns/relative-duration.js.map +1 -0
  183. package/gel-core/columns/smallint.cjs +54 -0
  184. package/gel-core/columns/smallint.cjs.map +1 -0
  185. package/gel-core/columns/smallint.d.cts +23 -0
  186. package/gel-core/columns/smallint.d.ts +23 -0
  187. package/gel-core/columns/smallint.js +28 -0
  188. package/gel-core/columns/smallint.js.map +1 -0
  189. package/gel-core/columns/text.cjs +54 -0
  190. package/gel-core/columns/text.cjs.map +1 -0
  191. package/gel-core/columns/text.d.cts +26 -0
  192. package/gel-core/columns/text.d.ts +26 -0
  193. package/gel-core/columns/text.js +28 -0
  194. package/gel-core/columns/text.js.map +1 -0
  195. package/gel-core/columns/timestamp.cjs +60 -0
  196. package/gel-core/columns/timestamp.cjs.map +1 -0
  197. package/gel-core/columns/timestamp.d.cts +28 -0
  198. package/gel-core/columns/timestamp.d.ts +28 -0
  199. package/gel-core/columns/timestamp.js +34 -0
  200. package/gel-core/columns/timestamp.js.map +1 -0
  201. package/gel-core/columns/timestamptz.cjs +60 -0
  202. package/gel-core/columns/timestamptz.cjs.map +1 -0
  203. package/gel-core/columns/timestamptz.d.cts +27 -0
  204. package/gel-core/columns/timestamptz.d.ts +27 -0
  205. package/gel-core/columns/timestamptz.js +34 -0
  206. package/gel-core/columns/timestamptz.js.map +1 -0
  207. package/gel-core/columns/uuid.cjs +53 -0
  208. package/gel-core/columns/uuid.cjs.map +1 -0
  209. package/gel-core/columns/uuid.d.cts +22 -0
  210. package/gel-core/columns/uuid.d.ts +22 -0
  211. package/gel-core/columns/uuid.js +27 -0
  212. package/gel-core/columns/uuid.js.map +1 -0
  213. package/gel-core/db.cjs +338 -0
  214. package/gel-core/db.cjs.map +1 -0
  215. package/gel-core/db.d.cts +281 -0
  216. package/gel-core/db.d.ts +281 -0
  217. package/gel-core/db.js +319 -0
  218. package/gel-core/db.js.map +1 -0
  219. package/gel-core/dialect.cjs +1142 -0
  220. package/gel-core/dialect.cjs.map +1 -0
  221. package/gel-core/dialect.d.cts +62 -0
  222. package/gel-core/dialect.d.ts +62 -0
  223. package/gel-core/dialect.js +1128 -0
  224. package/gel-core/dialect.js.map +1 -0
  225. package/gel-core/expressions.cjs +49 -0
  226. package/gel-core/expressions.cjs.map +1 -0
  227. package/gel-core/expressions.d.cts +8 -0
  228. package/gel-core/expressions.d.ts +8 -0
  229. package/gel-core/expressions.js +22 -0
  230. package/gel-core/expressions.js.map +1 -0
  231. package/gel-core/foreign-keys.cjs +100 -0
  232. package/gel-core/foreign-keys.cjs.map +1 -0
  233. package/gel-core/foreign-keys.d.cts +48 -0
  234. package/gel-core/foreign-keys.d.ts +48 -0
  235. package/gel-core/foreign-keys.js +74 -0
  236. package/gel-core/foreign-keys.js.map +1 -0
  237. package/gel-core/index.cjs +61 -0
  238. package/gel-core/index.cjs.map +1 -0
  239. package/gel-core/index.d.cts +20 -0
  240. package/gel-core/index.d.ts +20 -0
  241. package/gel-core/index.js +21 -0
  242. package/gel-core/index.js.map +1 -0
  243. package/gel-core/indexes.cjs +149 -0
  244. package/gel-core/indexes.cjs.map +1 -0
  245. package/gel-core/indexes.d.cts +79 -0
  246. package/gel-core/indexes.d.ts +79 -0
  247. package/gel-core/indexes.js +121 -0
  248. package/gel-core/indexes.js.map +1 -0
  249. package/gel-core/policies.cjs +58 -0
  250. package/gel-core/policies.cjs.map +1 -0
  251. package/gel-core/policies.d.cts +24 -0
  252. package/gel-core/policies.d.ts +24 -0
  253. package/gel-core/policies.js +33 -0
  254. package/gel-core/policies.js.map +1 -0
  255. package/gel-core/primary-keys.cjs +68 -0
  256. package/gel-core/primary-keys.cjs.map +1 -0
  257. package/gel-core/primary-keys.d.cts +30 -0
  258. package/gel-core/primary-keys.d.ts +30 -0
  259. package/gel-core/primary-keys.js +42 -0
  260. package/gel-core/primary-keys.js.map +1 -0
  261. package/gel-core/query-builders/count.cjs +73 -0
  262. package/gel-core/query-builders/count.cjs.map +1 -0
  263. package/gel-core/query-builders/count.d.cts +25 -0
  264. package/gel-core/query-builders/count.d.ts +25 -0
  265. package/gel-core/query-builders/count.js +49 -0
  266. package/gel-core/query-builders/count.js.map +1 -0
  267. package/gel-core/query-builders/delete.cjs +105 -0
  268. package/gel-core/query-builders/delete.cjs.map +1 -0
  269. package/gel-core/query-builders/delete.d.cts +99 -0
  270. package/gel-core/query-builders/delete.d.ts +99 -0
  271. package/gel-core/query-builders/delete.js +81 -0
  272. package/gel-core/query-builders/delete.js.map +1 -0
  273. package/gel-core/query-builders/index.cjs +35 -0
  274. package/gel-core/query-builders/index.cjs.map +1 -0
  275. package/gel-core/query-builders/index.d.cts +7 -0
  276. package/gel-core/query-builders/index.d.ts +7 -0
  277. package/gel-core/query-builders/index.js +8 -0
  278. package/gel-core/query-builders/index.js.map +1 -0
  279. package/gel-core/query-builders/insert.cjs +218 -0
  280. package/gel-core/query-builders/insert.cjs.map +1 -0
  281. package/gel-core/query-builders/insert.d.cts +116 -0
  282. package/gel-core/query-builders/insert.d.ts +116 -0
  283. package/gel-core/query-builders/insert.js +193 -0
  284. package/gel-core/query-builders/insert.js.map +1 -0
  285. package/gel-core/query-builders/query-builder.cjs +114 -0
  286. package/gel-core/query-builders/query-builder.cjs.map +1 -0
  287. package/gel-core/query-builders/query-builder.d.cts +40 -0
  288. package/gel-core/query-builders/query-builder.d.ts +40 -0
  289. package/gel-core/query-builders/query-builder.js +90 -0
  290. package/gel-core/query-builders/query-builder.js.map +1 -0
  291. package/gel-core/query-builders/query.cjs +139 -0
  292. package/gel-core/query-builders/query.cjs.map +1 -0
  293. package/gel-core/query-builders/query.d.cts +46 -0
  294. package/gel-core/query-builders/query.d.ts +46 -0
  295. package/gel-core/query-builders/query.js +116 -0
  296. package/gel-core/query-builders/query.js.map +1 -0
  297. package/gel-core/query-builders/raw.cjs +57 -0
  298. package/gel-core/query-builders/raw.cjs.map +1 -0
  299. package/gel-core/query-builders/raw.d.cts +22 -0
  300. package/gel-core/query-builders/raw.d.ts +22 -0
  301. package/gel-core/query-builders/raw.js +33 -0
  302. package/gel-core/query-builders/raw.js.map +1 -0
  303. package/gel-core/query-builders/refresh-materialized-view.cjs +77 -0
  304. package/gel-core/query-builders/refresh-materialized-view.cjs.map +1 -0
  305. package/gel-core/query-builders/refresh-materialized-view.d.cts +27 -0
  306. package/gel-core/query-builders/refresh-materialized-view.d.ts +27 -0
  307. package/gel-core/query-builders/refresh-materialized-view.js +53 -0
  308. package/gel-core/query-builders/refresh-materialized-view.js.map +1 -0
  309. package/gel-core/query-builders/select.cjs +775 -0
  310. package/gel-core/query-builders/select.cjs.map +1 -0
  311. package/gel-core/query-builders/select.d.cts +721 -0
  312. package/gel-core/query-builders/select.d.ts +721 -0
  313. package/gel-core/query-builders/select.js +748 -0
  314. package/gel-core/query-builders/select.js.map +1 -0
  315. package/gel-core/query-builders/select.types.cjs +17 -0
  316. package/gel-core/query-builders/select.types.cjs.map +1 -0
  317. package/gel-core/query-builders/select.types.d.cts +138 -0
  318. package/gel-core/query-builders/select.types.d.ts +138 -0
  319. package/gel-core/query-builders/select.types.js +1 -0
  320. package/gel-core/query-builders/update.cjs +226 -0
  321. package/gel-core/query-builders/update.cjs.map +1 -0
  322. package/gel-core/query-builders/update.d.cts +166 -0
  323. package/gel-core/query-builders/update.d.ts +166 -0
  324. package/gel-core/query-builders/update.js +205 -0
  325. package/gel-core/query-builders/update.js.map +1 -0
  326. package/gel-core/roles.cjs +57 -0
  327. package/gel-core/roles.cjs.map +1 -0
  328. package/gel-core/roles.d.cts +13 -0
  329. package/gel-core/roles.d.ts +13 -0
  330. package/gel-core/roles.js +32 -0
  331. package/gel-core/roles.js.map +1 -0
  332. package/gel-core/schema.cjs +74 -0
  333. package/gel-core/schema.cjs.map +1 -0
  334. package/gel-core/schema.d.cts +15 -0
  335. package/gel-core/schema.d.ts +15 -0
  336. package/gel-core/schema.js +48 -0
  337. package/gel-core/schema.js.map +1 -0
  338. package/gel-core/sequence.cjs +52 -0
  339. package/gel-core/sequence.cjs.map +1 -0
  340. package/gel-core/sequence.d.cts +18 -0
  341. package/gel-core/sequence.d.ts +18 -0
  342. package/gel-core/sequence.js +25 -0
  343. package/gel-core/sequence.js.map +1 -0
  344. package/gel-core/session.cjs +94 -0
  345. package/gel-core/session.cjs.map +1 -0
  346. package/gel-core/session.d.cts +56 -0
  347. package/gel-core/session.d.ts +56 -0
  348. package/gel-core/session.js +68 -0
  349. package/gel-core/session.js.map +1 -0
  350. package/{cache/core/types.cjs → gel-core/subquery.cjs} +3 -3
  351. package/gel-core/subquery.cjs.map +1 -0
  352. package/gel-core/subquery.d.cts +5 -0
  353. package/gel-core/subquery.d.ts +5 -0
  354. package/gel-core/subquery.js +1 -0
  355. package/gel-core/subquery.js.map +1 -0
  356. package/gel-core/table.cjs +100 -0
  357. package/gel-core/table.cjs.map +1 -0
  358. package/gel-core/table.d.cts +95 -0
  359. package/gel-core/table.d.ts +95 -0
  360. package/gel-core/table.js +71 -0
  361. package/gel-core/table.js.map +1 -0
  362. package/gel-core/unique-constraint.cjs +89 -0
  363. package/gel-core/unique-constraint.cjs.map +1 -0
  364. package/gel-core/unique-constraint.d.cts +25 -0
  365. package/gel-core/unique-constraint.d.ts +25 -0
  366. package/gel-core/unique-constraint.js +61 -0
  367. package/gel-core/unique-constraint.js.map +1 -0
  368. package/gel-core/utils.cjs +100 -0
  369. package/gel-core/utils.cjs.map +1 -0
  370. package/gel-core/utils.d.cts +51 -0
  371. package/gel-core/utils.d.ts +51 -0
  372. package/gel-core/utils.js +74 -0
  373. package/gel-core/utils.js.map +1 -0
  374. package/gel-core/view-base.cjs +33 -0
  375. package/gel-core/view-base.cjs.map +1 -0
  376. package/gel-core/view-base.d.cts +8 -0
  377. package/gel-core/view-base.d.ts +8 -0
  378. package/gel-core/view-base.js +9 -0
  379. package/gel-core/view-base.js.map +1 -0
  380. package/{cache/upstash/index.cjs → gel-core/view-common.cjs} +12 -6
  381. package/gel-core/view-common.cjs.map +1 -0
  382. package/gel-core/view-common.d.cts +1 -0
  383. package/gel-core/view-common.d.ts +1 -0
  384. package/gel-core/view-common.js +5 -0
  385. package/gel-core/view-common.js.map +1 -0
  386. package/gel-core/view.cjs +302 -0
  387. package/gel-core/view.cjs.map +1 -0
  388. package/gel-core/view.d.cts +150 -0
  389. package/gel-core/view.d.ts +150 -0
  390. package/gel-core/view.js +268 -0
  391. package/gel-core/view.js.map +1 -0
  392. package/neon-http/driver.cjs +2 -9
  393. package/neon-http/driver.cjs.map +1 -1
  394. package/neon-http/driver.d.cts +0 -2
  395. package/neon-http/driver.d.ts +0 -2
  396. package/neon-http/driver.js +2 -9
  397. package/neon-http/driver.js.map +1 -1
  398. package/neon-http/session.cjs +15 -25
  399. package/neon-http/session.cjs.map +1 -1
  400. package/neon-http/session.d.cts +3 -12
  401. package/neon-http/session.d.ts +3 -12
  402. package/neon-http/session.js +15 -25
  403. package/neon-http/session.js.map +1 -1
  404. package/neon-serverless/driver.cjs +2 -9
  405. package/neon-serverless/driver.cjs.map +1 -1
  406. package/neon-serverless/driver.d.cts +0 -2
  407. package/neon-serverless/driver.d.ts +0 -2
  408. package/neon-serverless/driver.js +2 -9
  409. package/neon-serverless/driver.js.map +1 -1
  410. package/neon-serverless/session.cjs +7 -21
  411. package/neon-serverless/session.cjs.map +1 -1
  412. package/neon-serverless/session.d.cts +3 -12
  413. package/neon-serverless/session.d.ts +3 -12
  414. package/neon-serverless/session.js +7 -21
  415. package/neon-serverless/session.js.map +1 -1
  416. package/node-postgres/driver.cjs +2 -9
  417. package/node-postgres/driver.cjs.map +1 -1
  418. package/node-postgres/driver.d.cts +0 -2
  419. package/node-postgres/driver.d.ts +0 -2
  420. package/node-postgres/driver.js +2 -9
  421. package/node-postgres/driver.js.map +1 -1
  422. package/node-postgres/session.cjs +6 -19
  423. package/node-postgres/session.cjs.map +1 -1
  424. package/node-postgres/session.d.cts +3 -13
  425. package/node-postgres/session.d.ts +3 -13
  426. package/node-postgres/session.js +6 -19
  427. package/node-postgres/session.js.map +1 -1
  428. package/package.json +1036 -364
  429. package/pg-core/db.cjs +0 -1
  430. package/pg-core/db.cjs.map +1 -1
  431. package/pg-core/db.d.cts +0 -4
  432. package/pg-core/db.d.ts +0 -4
  433. package/pg-core/db.js +0 -1
  434. package/pg-core/db.js.map +1 -1
  435. package/pg-core/query-builders/delete.cjs +1 -6
  436. package/pg-core/query-builders/delete.cjs.map +1 -1
  437. package/pg-core/query-builders/delete.d.cts +1 -2
  438. package/pg-core/query-builders/delete.d.ts +1 -2
  439. package/pg-core/query-builders/delete.js +1 -6
  440. package/pg-core/query-builders/delete.js.map +1 -1
  441. package/pg-core/query-builders/insert.cjs +1 -6
  442. package/pg-core/query-builders/insert.cjs.map +1 -1
  443. package/pg-core/query-builders/insert.d.cts +1 -2
  444. package/pg-core/query-builders/insert.d.ts +1 -2
  445. package/pg-core/query-builders/insert.js +1 -6
  446. package/pg-core/query-builders/insert.js.map +1 -1
  447. package/pg-core/query-builders/select.cjs +5 -31
  448. package/pg-core/query-builders/select.cjs.map +1 -1
  449. package/pg-core/query-builders/select.d.cts +2 -11
  450. package/pg-core/query-builders/select.d.ts +2 -11
  451. package/pg-core/query-builders/select.js +5 -31
  452. package/pg-core/query-builders/select.js.map +1 -1
  453. package/pg-core/query-builders/select.types.cjs.map +1 -1
  454. package/pg-core/query-builders/select.types.d.cts +0 -7
  455. package/pg-core/query-builders/select.types.d.ts +0 -7
  456. package/pg-core/query-builders/update.cjs +1 -6
  457. package/pg-core/query-builders/update.cjs.map +1 -1
  458. package/pg-core/query-builders/update.d.cts +3 -4
  459. package/pg-core/query-builders/update.d.ts +3 -4
  460. package/pg-core/query-builders/update.js +1 -6
  461. package/pg-core/query-builders/update.js.map +1 -1
  462. package/pg-core/session.cjs +1 -53
  463. package/pg-core/session.cjs.map +1 -1
  464. package/pg-core/session.d.cts +3 -14
  465. package/pg-core/session.d.ts +3 -14
  466. package/pg-core/session.js +2 -54
  467. package/pg-core/session.js.map +1 -1
  468. package/pg-core/table.cjs +2 -0
  469. package/pg-core/table.cjs.map +1 -1
  470. package/pg-core/table.js +2 -0
  471. package/pg-core/table.js.map +1 -1
  472. package/pg-core/utils.cjs +0 -16
  473. package/pg-core/utils.cjs.map +1 -1
  474. package/pg-core/utils.d.cts +4 -8
  475. package/pg-core/utils.d.ts +4 -8
  476. package/pg-core/utils.js +1 -16
  477. package/pg-core/utils.js.map +1 -1
  478. package/pg-proxy/driver.cjs +2 -7
  479. package/pg-proxy/driver.cjs.map +1 -1
  480. package/pg-proxy/driver.js +2 -7
  481. package/pg-proxy/driver.js.map +1 -1
  482. package/pg-proxy/session.cjs +5 -15
  483. package/pg-proxy/session.cjs.map +1 -1
  484. package/pg-proxy/session.d.cts +3 -12
  485. package/pg-proxy/session.d.ts +3 -12
  486. package/pg-proxy/session.js +5 -15
  487. package/pg-proxy/session.js.map +1 -1
  488. package/pglite/driver.cjs +2 -9
  489. package/pglite/driver.cjs.map +1 -1
  490. package/pglite/driver.d.cts +0 -2
  491. package/pglite/driver.d.ts +0 -2
  492. package/pglite/driver.js +2 -9
  493. package/pglite/driver.js.map +1 -1
  494. package/pglite/session.cjs +7 -19
  495. package/pglite/session.cjs.map +1 -1
  496. package/pglite/session.d.cts +3 -12
  497. package/pglite/session.d.ts +3 -12
  498. package/pglite/session.js +7 -19
  499. package/pglite/session.js.map +1 -1
  500. package/postgres-js/driver.cjs +1 -5
  501. package/postgres-js/driver.cjs.map +1 -1
  502. package/postgres-js/driver.js +1 -5
  503. package/postgres-js/driver.js.map +1 -1
  504. package/postgres-js/session.cjs +6 -18
  505. package/postgres-js/session.cjs.map +1 -1
  506. package/postgres-js/session.d.cts +3 -12
  507. package/postgres-js/session.d.ts +3 -12
  508. package/postgres-js/session.js +6 -18
  509. package/postgres-js/session.js.map +1 -1
  510. package/prisma/pg/session.cjs +1 -1
  511. package/prisma/pg/session.cjs.map +1 -1
  512. package/prisma/pg/session.js +1 -1
  513. package/prisma/pg/session.js.map +1 -1
  514. package/query-builders/query-builder.cjs.map +1 -1
  515. package/query-builders/query-builder.d.cts +1 -2
  516. package/query-builders/query-builder.d.ts +1 -2
  517. package/query-builders/query-builder.js.map +1 -1
  518. package/sql/sql.cjs +0 -7
  519. package/sql/sql.cjs.map +1 -1
  520. package/sql/sql.js +0 -7
  521. package/sql/sql.js.map +1 -1
  522. package/subquery.cjs +3 -4
  523. package/subquery.cjs.map +1 -1
  524. package/subquery.d.cts +1 -2
  525. package/subquery.d.ts +1 -2
  526. package/subquery.js +3 -4
  527. package/subquery.js.map +1 -1
  528. package/table.cjs.map +1 -1
  529. package/table.js.map +1 -1
  530. package/utils.cjs.map +1 -1
  531. package/utils.d.cts +0 -2
  532. package/utils.d.ts +0 -2
  533. package/utils.js.map +1 -1
  534. package/vercel-postgres/driver.cjs +2 -9
  535. package/vercel-postgres/driver.cjs.map +1 -1
  536. package/vercel-postgres/driver.d.cts +0 -2
  537. package/vercel-postgres/driver.d.ts +0 -2
  538. package/vercel-postgres/driver.js +2 -9
  539. package/vercel-postgres/driver.js.map +1 -1
  540. package/vercel-postgres/session.cjs +7 -21
  541. package/vercel-postgres/session.cjs.map +1 -1
  542. package/vercel-postgres/session.d.cts +3 -12
  543. package/vercel-postgres/session.d.ts +3 -12
  544. package/vercel-postgres/session.js +7 -21
  545. package/vercel-postgres/session.js.map +1 -1
  546. package/version.cjs +1 -1
  547. package/version.d.cts +1 -1
  548. package/version.d.ts +1 -1
  549. package/version.js +1 -1
  550. package/xata-http/driver.cjs +2 -7
  551. package/xata-http/driver.cjs.map +1 -1
  552. package/xata-http/driver.d.cts +0 -2
  553. package/xata-http/driver.d.ts +0 -2
  554. package/xata-http/driver.js +2 -7
  555. package/xata-http/driver.js.map +1 -1
  556. package/xata-http/session.cjs +7 -21
  557. package/xata-http/session.cjs.map +1 -1
  558. package/xata-http/session.d.cts +3 -12
  559. package/xata-http/session.d.ts +3 -12
  560. package/xata-http/session.js +7 -21
  561. package/xata-http/session.js.map +1 -1
  562. package/cache/core/cache.cjs.map +0 -1
  563. package/cache/core/cache.d.cts +0 -35
  564. package/cache/core/cache.d.ts +0 -35
  565. package/cache/core/cache.js +0 -22
  566. package/cache/core/cache.js.map +0 -1
  567. package/cache/core/index.cjs.map +0 -1
  568. package/cache/core/index.d.cts +0 -1
  569. package/cache/core/index.d.ts +0 -1
  570. package/cache/core/index.js +0 -2
  571. package/cache/core/index.js.map +0 -1
  572. package/cache/core/types.cjs.map +0 -1
  573. package/cache/core/types.d.cts +0 -22
  574. package/cache/core/types.d.ts +0 -22
  575. package/cache/core/types.js +0 -1
  576. package/cache/upstash/cache.cjs +0 -98
  577. package/cache/upstash/cache.cjs.map +0 -1
  578. package/cache/upstash/cache.d.cts +0 -23
  579. package/cache/upstash/cache.d.ts +0 -23
  580. package/cache/upstash/cache.js +0 -73
  581. package/cache/upstash/cache.js.map +0 -1
  582. package/cache/upstash/index.cjs.map +0 -1
  583. package/cache/upstash/index.d.cts +0 -1
  584. package/cache/upstash/index.d.ts +0 -1
  585. package/cache/upstash/index.js +0 -2
  586. package/cache/upstash/index.js.map +0 -1
  587. /package/{cache/core/types.js.map → gel-core/query-builders/select.types.js.map} +0 -0
@@ -34,7 +34,6 @@ __export(session_exports, {
34
34
  });
35
35
  module.exports = __toCommonJS(session_exports);
36
36
  var import_pg = __toESM(require("pg"), 1);
37
- var import_core = require("../cache/core/index.cjs");
38
37
  var import_entity = require("../entity.cjs");
39
38
  var import_logger = require("../logger.cjs");
40
39
  var import_pg_core = require("../pg-core/index.cjs");
@@ -44,10 +43,9 @@ var import_tracing = require("../tracing.cjs");
44
43
  var import_utils = require("../utils.cjs");
45
44
  const { Pool, types } = import_pg.default;
46
45
  class NodePgPreparedQuery extends import_session.PgPreparedQuery {
47
- constructor(client, queryString, params, logger, cache, queryMetadata, cacheConfig, fields, name, _isResponseInArrayMode, customResultMapper) {
48
- super({ sql: queryString, params }, cache, queryMetadata, cacheConfig);
46
+ constructor(client, queryString, params, logger, fields, name, _isResponseInArrayMode, customResultMapper) {
47
+ super({ sql: queryString, params });
49
48
  this.client = client;
50
- this.queryString = queryString;
51
49
  this.params = params;
52
50
  this.logger = logger;
53
51
  this.fields = fields;
@@ -114,9 +112,7 @@ class NodePgPreparedQuery extends import_session.PgPreparedQuery {
114
112
  "drizzle.query.text": rawQuery.text,
115
113
  "drizzle.query.params": JSON.stringify(params)
116
114
  });
117
- return this.queryWithCache(rawQuery.text, params, async () => {
118
- return await client.query(rawQuery, params);
119
- });
115
+ return client.query(rawQuery, params);
120
116
  });
121
117
  }
122
118
  const result = await import_tracing.tracer.startActiveSpan("drizzle.driver.execute", (span) => {
@@ -125,9 +121,7 @@ class NodePgPreparedQuery extends import_session.PgPreparedQuery {
125
121
  "drizzle.query.text": query.text,
126
122
  "drizzle.query.params": JSON.stringify(params)
127
123
  });
128
- return this.queryWithCache(query.text, params, async () => {
129
- return await client.query(query, params);
130
- });
124
+ return client.query(query, params);
131
125
  });
132
126
  return import_tracing.tracer.startActiveSpan("drizzle.mapResponse", () => {
133
127
  return customResultMapper ? customResultMapper(result.rows) : result.rows.map((row) => (0, import_utils.mapResultRow)(fields, row, joinsNotNullableMap));
@@ -144,9 +138,7 @@ class NodePgPreparedQuery extends import_session.PgPreparedQuery {
144
138
  "drizzle.query.text": this.rawQueryConfig.text,
145
139
  "drizzle.query.params": JSON.stringify(params)
146
140
  });
147
- return this.queryWithCache(this.rawQueryConfig.text, params, async () => {
148
- return this.client.query(this.rawQueryConfig, params);
149
- }).then((result) => result.rows);
141
+ return this.client.query(this.rawQueryConfig, params).then((result) => result.rows);
150
142
  });
151
143
  });
152
144
  }
@@ -162,20 +154,15 @@ class NodePgSession extends import_session.PgSession {
162
154
  this.schema = schema;
163
155
  this.options = options;
164
156
  this.logger = options.logger ?? new import_logger.NoopLogger();
165
- this.cache = options.cache ?? new import_core.NoopCache();
166
157
  }
167
158
  static [import_entity.entityKind] = "NodePgSession";
168
159
  logger;
169
- cache;
170
- prepareQuery(query, fields, name, isResponseInArrayMode, customResultMapper, queryMetadata, cacheConfig) {
160
+ prepareQuery(query, fields, name, isResponseInArrayMode, customResultMapper) {
171
161
  return new NodePgPreparedQuery(
172
162
  this.client,
173
163
  query.sql,
174
164
  query.params,
175
165
  this.logger,
176
- this.cache,
177
- queryMetadata,
178
- cacheConfig,
179
166
  fields,
180
167
  name,
181
168
  isResponseInArrayMode,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/node-postgres/session.ts"],"sourcesContent":["import type { Client, PoolClient, QueryArrayConfig, QueryConfig, QueryResult, QueryResultRow } from 'pg';\nimport pg from 'pg';\nimport { type Cache, NoopCache } from '~/cache/core/index.ts';\nimport { entityKind } from '~/entity.ts';\nimport { type Logger, NoopLogger } from '~/logger.ts';\nimport type { PgDialect } from '~/pg-core/dialect.ts';\nimport { PgTransaction } from '~/pg-core/index.ts';\nimport type { SelectedFieldsOrdered, WithCacheConfig } from '~/pg-core/query-builders/select.types.ts';\nimport type { PgQueryResultHKT, PgTransactionConfig, PreparedQueryConfig } from '~/pg-core/session.ts';\nimport { PgPreparedQuery, PgSession } from '~/pg-core/session.ts';\nimport type { RelationalSchemaConfig, TablesRelationalConfig } from '~/relations.ts';\nimport { fillPlaceholders, type Query, type SQL, sql } from '~/sql/sql.ts';\nimport { tracer } from '~/tracing.ts';\nimport { type Assume, mapResultRow } from '~/utils.ts';\n\nconst { Pool, types } = pg;\n\nexport type NodePgClient = pg.Pool | PoolClient | Client;\n\nexport class NodePgPreparedQuery<T extends PreparedQueryConfig> extends PgPreparedQuery<T> {\n\tstatic override readonly [entityKind]: string = 'NodePgPreparedQuery';\n\n\tprivate rawQueryConfig: QueryConfig;\n\tprivate queryConfig: QueryArrayConfig;\n\n\tconstructor(\n\t\tprivate client: NodePgClient,\n\t\tprivate queryString: string,\n\t\tprivate params: unknown[],\n\t\tprivate logger: Logger,\n\t\tcache: Cache,\n\t\tqueryMetadata: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t} | undefined,\n\t\tcacheConfig: WithCacheConfig | undefined,\n\t\tprivate fields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tprivate _isResponseInArrayMode: boolean,\n\t\tprivate customResultMapper?: (rows: unknown[][]) => T['execute'],\n\t) {\n\t\tsuper({ sql: queryString, params }, cache, queryMetadata, cacheConfig);\n\t\tthis.rawQueryConfig = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t\tthis.queryConfig = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\trowMode: 'array',\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t}\n\n\tasync execute(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['execute']> {\n\t\treturn tracer.startActiveSpan('drizzle.execute', async () => {\n\t\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\n\t\t\tthis.logger.logQuery(this.rawQueryConfig.text, params);\n\n\t\t\tconst { fields, rawQueryConfig: rawQuery, client, queryConfig: query, joinsNotNullableMap, customResultMapper } =\n\t\t\t\tthis;\n\t\t\tif (!fields && !customResultMapper) {\n\t\t\t\treturn tracer.startActiveSpan('drizzle.driver.execute', async (span) => {\n\t\t\t\t\tspan?.setAttributes({\n\t\t\t\t\t\t'drizzle.query.name': rawQuery.name,\n\t\t\t\t\t\t'drizzle.query.text': rawQuery.text,\n\t\t\t\t\t\t'drizzle.query.params': JSON.stringify(params),\n\t\t\t\t\t});\n\t\t\t\t\treturn this.queryWithCache(rawQuery.text, params, async () => {\n\t\t\t\t\t\treturn await client.query(rawQuery, params);\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tconst result = await tracer.startActiveSpan('drizzle.driver.execute', (span) => {\n\t\t\t\tspan?.setAttributes({\n\t\t\t\t\t'drizzle.query.name': query.name,\n\t\t\t\t\t'drizzle.query.text': query.text,\n\t\t\t\t\t'drizzle.query.params': JSON.stringify(params),\n\t\t\t\t});\n\t\t\t\treturn this.queryWithCache(query.text, params, async () => {\n\t\t\t\t\treturn await client.query(query, params);\n\t\t\t\t});\n\t\t\t});\n\n\t\t\treturn tracer.startActiveSpan('drizzle.mapResponse', () => {\n\t\t\t\treturn customResultMapper\n\t\t\t\t\t? customResultMapper(result.rows)\n\t\t\t\t\t: result.rows.map((row) => mapResultRow<T['execute']>(fields!, row, joinsNotNullableMap));\n\t\t\t});\n\t\t});\n\t}\n\n\tall(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['all']> {\n\t\treturn tracer.startActiveSpan('drizzle.execute', () => {\n\t\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\t\t\tthis.logger.logQuery(this.rawQueryConfig.text, params);\n\t\t\treturn tracer.startActiveSpan('drizzle.driver.execute', (span) => {\n\t\t\t\tspan?.setAttributes({\n\t\t\t\t\t'drizzle.query.name': this.rawQueryConfig.name,\n\t\t\t\t\t'drizzle.query.text': this.rawQueryConfig.text,\n\t\t\t\t\t'drizzle.query.params': JSON.stringify(params),\n\t\t\t\t});\n\t\t\t\treturn this.queryWithCache(this.rawQueryConfig.text, params, async () => {\n\t\t\t\t\treturn this.client.query(this.rawQueryConfig, params);\n\t\t\t\t}).then((result) => result.rows);\n\t\t\t});\n\t\t});\n\t}\n\n\t/** @internal */\n\tisResponseInArrayMode(): boolean {\n\t\treturn this._isResponseInArrayMode;\n\t}\n}\n\nexport interface NodePgSessionOptions {\n\tlogger?: Logger;\n\tcache?: Cache;\n}\n\nexport class NodePgSession<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgSession<NodePgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'NodePgSession';\n\n\tprivate logger: Logger;\n\tprivate cache: Cache;\n\n\tconstructor(\n\t\tprivate client: NodePgClient,\n\t\tdialect: PgDialect,\n\t\tprivate schema: RelationalSchemaConfig<TSchema> | undefined,\n\t\tprivate options: NodePgSessionOptions = {},\n\t) {\n\t\tsuper(dialect);\n\t\tthis.logger = options.logger ?? new NoopLogger();\n\t\tthis.cache = options.cache ?? new NoopCache();\n\t}\n\n\tprepareQuery<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[][]) => 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): PgPreparedQuery<T> {\n\t\treturn new NodePgPreparedQuery(\n\t\t\tthis.client,\n\t\t\tquery.sql,\n\t\t\tquery.params,\n\t\t\tthis.logger,\n\t\t\tthis.cache,\n\t\t\tqueryMetadata,\n\t\t\tcacheConfig,\n\t\t\tfields,\n\t\t\tname,\n\t\t\tisResponseInArrayMode,\n\t\t\tcustomResultMapper,\n\t\t);\n\t}\n\n\toverride async transaction<T>(\n\t\ttransaction: (tx: NodePgTransaction<TFullSchema, TSchema>) => Promise<T>,\n\t\tconfig?: PgTransactionConfig | undefined,\n\t): Promise<T> {\n\t\tconst session = this.client instanceof Pool // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t? new NodePgSession(await this.client.connect(), this.dialect, this.schema, this.options)\n\t\t\t: this;\n\t\tconst tx = new NodePgTransaction<TFullSchema, TSchema>(this.dialect, session, this.schema);\n\t\tawait tx.execute(sql`begin${config ? sql` ${tx.getTransactionConfigSQL(config)}` : undefined}`);\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql`commit`);\n\t\t\treturn result;\n\t\t} catch (error) {\n\t\t\tawait tx.execute(sql`rollback`);\n\t\t\tthrow error;\n\t\t} finally {\n\t\t\tif (this.client instanceof Pool) { // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t\t(session.client as PoolClient).release();\n\t\t\t}\n\t\t}\n\t}\n\n\toverride async count(sql: SQL): Promise<number> {\n\t\tconst res = await this.execute<{ rows: [{ count: string }] }>(sql);\n\t\treturn Number(\n\t\t\tres['rows'][0]['count'],\n\t\t);\n\t}\n}\n\nexport class NodePgTransaction<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgTransaction<NodePgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'NodePgTransaction';\n\n\toverride async transaction<T>(transaction: (tx: NodePgTransaction<TFullSchema, TSchema>) => Promise<T>): Promise<T> {\n\t\tconst savepointName = `sp${this.nestedIndex + 1}`;\n\t\tconst tx = new NodePgTransaction<TFullSchema, TSchema>(\n\t\t\tthis.dialect,\n\t\t\tthis.session,\n\t\t\tthis.schema,\n\t\t\tthis.nestedIndex + 1,\n\t\t);\n\t\tawait tx.execute(sql.raw(`savepoint ${savepointName}`));\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql.raw(`release savepoint ${savepointName}`));\n\t\t\treturn result;\n\t\t} catch (err) {\n\t\t\tawait tx.execute(sql.raw(`rollback to savepoint ${savepointName}`));\n\t\t\tthrow err;\n\t\t}\n\t}\n}\n\nexport interface NodePgQueryResultHKT extends PgQueryResultHKT {\n\ttype: QueryResult<Assume<this['row'], QueryResultRow>>;\n}\n"],"mappings":"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","names":["pg","sql"]}
1
+ {"version":3,"sources":["../../src/node-postgres/session.ts"],"sourcesContent":["import type { Client, PoolClient, QueryArrayConfig, QueryConfig, QueryResult, QueryResultRow } from 'pg';\nimport pg from 'pg';\nimport { entityKind } from '~/entity.ts';\nimport { type Logger, NoopLogger } from '~/logger.ts';\nimport type { PgDialect } from '~/pg-core/dialect.ts';\nimport { PgTransaction } from '~/pg-core/index.ts';\nimport type { SelectedFieldsOrdered } from '~/pg-core/query-builders/select.types.ts';\nimport type { PgQueryResultHKT, PgTransactionConfig, PreparedQueryConfig } from '~/pg-core/session.ts';\nimport { PgPreparedQuery, PgSession } from '~/pg-core/session.ts';\nimport type { RelationalSchemaConfig, TablesRelationalConfig } from '~/relations.ts';\nimport { fillPlaceholders, type Query, type SQL, sql } from '~/sql/sql.ts';\nimport { tracer } from '~/tracing.ts';\nimport { type Assume, mapResultRow } from '~/utils.ts';\n\nconst { Pool, types } = pg;\n\nexport type NodePgClient = pg.Pool | PoolClient | Client;\n\nexport class NodePgPreparedQuery<T extends PreparedQueryConfig> extends PgPreparedQuery<T> {\n\tstatic override readonly [entityKind]: string = 'NodePgPreparedQuery';\n\n\tprivate rawQueryConfig: QueryConfig;\n\tprivate queryConfig: QueryArrayConfig;\n\n\tconstructor(\n\t\tprivate client: NodePgClient,\n\t\tqueryString: string,\n\t\tprivate params: unknown[],\n\t\tprivate logger: Logger,\n\t\tprivate fields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tprivate _isResponseInArrayMode: boolean,\n\t\tprivate customResultMapper?: (rows: unknown[][]) => T['execute'],\n\t) {\n\t\tsuper({ sql: queryString, params });\n\t\tthis.rawQueryConfig = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t\tthis.queryConfig = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\trowMode: 'array',\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t}\n\n\tasync execute(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['execute']> {\n\t\treturn tracer.startActiveSpan('drizzle.execute', async () => {\n\t\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\n\t\t\tthis.logger.logQuery(this.rawQueryConfig.text, params);\n\n\t\t\tconst { fields, rawQueryConfig: rawQuery, client, queryConfig: query, joinsNotNullableMap, customResultMapper } =\n\t\t\t\tthis;\n\t\t\tif (!fields && !customResultMapper) {\n\t\t\t\treturn tracer.startActiveSpan('drizzle.driver.execute', async (span) => {\n\t\t\t\t\tspan?.setAttributes({\n\t\t\t\t\t\t'drizzle.query.name': rawQuery.name,\n\t\t\t\t\t\t'drizzle.query.text': rawQuery.text,\n\t\t\t\t\t\t'drizzle.query.params': JSON.stringify(params),\n\t\t\t\t\t});\n\t\t\t\t\treturn client.query(rawQuery, params);\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tconst result = await tracer.startActiveSpan('drizzle.driver.execute', (span) => {\n\t\t\t\tspan?.setAttributes({\n\t\t\t\t\t'drizzle.query.name': query.name,\n\t\t\t\t\t'drizzle.query.text': query.text,\n\t\t\t\t\t'drizzle.query.params': JSON.stringify(params),\n\t\t\t\t});\n\t\t\t\treturn client.query(query, params);\n\t\t\t});\n\n\t\t\treturn tracer.startActiveSpan('drizzle.mapResponse', () => {\n\t\t\t\treturn customResultMapper\n\t\t\t\t\t? customResultMapper(result.rows)\n\t\t\t\t\t: result.rows.map((row) => mapResultRow<T['execute']>(fields!, row, joinsNotNullableMap));\n\t\t\t});\n\t\t});\n\t}\n\n\tall(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['all']> {\n\t\treturn tracer.startActiveSpan('drizzle.execute', () => {\n\t\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\t\t\tthis.logger.logQuery(this.rawQueryConfig.text, params);\n\t\t\treturn tracer.startActiveSpan('drizzle.driver.execute', (span) => {\n\t\t\t\tspan?.setAttributes({\n\t\t\t\t\t'drizzle.query.name': this.rawQueryConfig.name,\n\t\t\t\t\t'drizzle.query.text': this.rawQueryConfig.text,\n\t\t\t\t\t'drizzle.query.params': JSON.stringify(params),\n\t\t\t\t});\n\t\t\t\treturn this.client.query(this.rawQueryConfig, params).then((result) => result.rows);\n\t\t\t});\n\t\t});\n\t}\n\n\t/** @internal */\n\tisResponseInArrayMode(): boolean {\n\t\treturn this._isResponseInArrayMode;\n\t}\n}\n\nexport interface NodePgSessionOptions {\n\tlogger?: Logger;\n}\n\nexport class NodePgSession<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgSession<NodePgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'NodePgSession';\n\n\tprivate logger: Logger;\n\n\tconstructor(\n\t\tprivate client: NodePgClient,\n\t\tdialect: PgDialect,\n\t\tprivate schema: RelationalSchemaConfig<TSchema> | undefined,\n\t\tprivate options: NodePgSessionOptions = {},\n\t) {\n\t\tsuper(dialect);\n\t\tthis.logger = options.logger ?? new NoopLogger();\n\t}\n\n\tprepareQuery<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[][]) => T['execute'],\n\t): PgPreparedQuery<T> {\n\t\treturn new NodePgPreparedQuery(\n\t\t\tthis.client,\n\t\t\tquery.sql,\n\t\t\tquery.params,\n\t\t\tthis.logger,\n\t\t\tfields,\n\t\t\tname,\n\t\t\tisResponseInArrayMode,\n\t\t\tcustomResultMapper,\n\t\t);\n\t}\n\n\toverride async transaction<T>(\n\t\ttransaction: (tx: NodePgTransaction<TFullSchema, TSchema>) => Promise<T>,\n\t\tconfig?: PgTransactionConfig | undefined,\n\t): Promise<T> {\n\t\tconst session = this.client instanceof Pool // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t? new NodePgSession(await this.client.connect(), this.dialect, this.schema, this.options)\n\t\t\t: this;\n\t\tconst tx = new NodePgTransaction<TFullSchema, TSchema>(this.dialect, session, this.schema);\n\t\tawait tx.execute(sql`begin${config ? sql` ${tx.getTransactionConfigSQL(config)}` : undefined}`);\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql`commit`);\n\t\t\treturn result;\n\t\t} catch (error) {\n\t\t\tawait tx.execute(sql`rollback`);\n\t\t\tthrow error;\n\t\t} finally {\n\t\t\tif (this.client instanceof Pool) { // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t\t(session.client as PoolClient).release();\n\t\t\t}\n\t\t}\n\t}\n\n\toverride async count(sql: SQL): Promise<number> {\n\t\tconst res = await this.execute<{ rows: [{ count: string }] }>(sql);\n\t\treturn Number(\n\t\t\tres['rows'][0]['count'],\n\t\t);\n\t}\n}\n\nexport class NodePgTransaction<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgTransaction<NodePgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'NodePgTransaction';\n\n\toverride async transaction<T>(transaction: (tx: NodePgTransaction<TFullSchema, TSchema>) => Promise<T>): Promise<T> {\n\t\tconst savepointName = `sp${this.nestedIndex + 1}`;\n\t\tconst tx = new NodePgTransaction<TFullSchema, TSchema>(\n\t\t\tthis.dialect,\n\t\t\tthis.session,\n\t\t\tthis.schema,\n\t\t\tthis.nestedIndex + 1,\n\t\t);\n\t\tawait tx.execute(sql.raw(`savepoint ${savepointName}`));\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql.raw(`release savepoint ${savepointName}`));\n\t\t\treturn result;\n\t\t} catch (err) {\n\t\t\tawait tx.execute(sql.raw(`rollback to savepoint ${savepointName}`));\n\t\t\tthrow err;\n\t\t}\n\t}\n}\n\nexport interface NodePgQueryResultHKT extends PgQueryResultHKT {\n\ttype: QueryResult<Assume<this['row'], QueryResultRow>>;\n}\n"],"mappings":"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","names":["pg","sql"]}
@@ -1,11 +1,10 @@
1
1
  import type { Client, PoolClient, QueryResult, QueryResultRow } from 'pg';
2
2
  import pg from 'pg';
3
- import { type Cache } from "../cache/core/index.cjs";
4
3
  import { entityKind } from "../entity.cjs";
5
4
  import { type Logger } from "../logger.cjs";
6
5
  import type { PgDialect } from "../pg-core/dialect.cjs";
7
6
  import { PgTransaction } from "../pg-core/index.cjs";
8
- import type { SelectedFieldsOrdered, WithCacheConfig } from "../pg-core/query-builders/select.types.cjs";
7
+ import type { SelectedFieldsOrdered } from "../pg-core/query-builders/select.types.cjs";
9
8
  import type { PgQueryResultHKT, PgTransactionConfig, PreparedQueryConfig } from "../pg-core/session.cjs";
10
9
  import { PgPreparedQuery, PgSession } from "../pg-core/session.cjs";
11
10
  import type { RelationalSchemaConfig, TablesRelationalConfig } from "../relations.cjs";
@@ -14,7 +13,6 @@ import { type Assume } from "../utils.cjs";
14
13
  export type NodePgClient = pg.Pool | PoolClient | Client;
15
14
  export declare class NodePgPreparedQuery<T extends PreparedQueryConfig> extends PgPreparedQuery<T> {
16
15
  private client;
17
- private queryString;
18
16
  private params;
19
17
  private logger;
20
18
  private fields;
@@ -23,16 +21,12 @@ export declare class NodePgPreparedQuery<T extends PreparedQueryConfig> extends
23
21
  static readonly [entityKind]: string;
24
22
  private rawQueryConfig;
25
23
  private queryConfig;
26
- constructor(client: NodePgClient, queryString: string, params: unknown[], logger: Logger, cache: Cache, queryMetadata: {
27
- type: 'select' | 'update' | 'delete' | 'insert';
28
- tables: string[];
29
- } | undefined, cacheConfig: WithCacheConfig | undefined, fields: SelectedFieldsOrdered | undefined, name: string | undefined, _isResponseInArrayMode: boolean, customResultMapper?: ((rows: unknown[][]) => T["execute"]) | undefined);
24
+ constructor(client: NodePgClient, queryString: string, params: unknown[], logger: Logger, fields: SelectedFieldsOrdered | undefined, name: string | undefined, _isResponseInArrayMode: boolean, customResultMapper?: ((rows: unknown[][]) => T["execute"]) | undefined);
30
25
  execute(placeholderValues?: Record<string, unknown> | undefined): Promise<T['execute']>;
31
26
  all(placeholderValues?: Record<string, unknown> | undefined): Promise<T['all']>;
32
27
  }
33
28
  export interface NodePgSessionOptions {
34
29
  logger?: Logger;
35
- cache?: Cache;
36
30
  }
37
31
  export declare class NodePgSession<TFullSchema extends Record<string, unknown>, TSchema extends TablesRelationalConfig> extends PgSession<NodePgQueryResultHKT, TFullSchema, TSchema> {
38
32
  private client;
@@ -40,12 +34,8 @@ export declare class NodePgSession<TFullSchema extends Record<string, unknown>,
40
34
  private options;
41
35
  static readonly [entityKind]: string;
42
36
  private logger;
43
- private cache;
44
37
  constructor(client: NodePgClient, dialect: PgDialect, schema: RelationalSchemaConfig<TSchema> | undefined, options?: NodePgSessionOptions);
45
- prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, isResponseInArrayMode: boolean, customResultMapper?: (rows: unknown[][]) => T['execute'], queryMetadata?: {
46
- type: 'select' | 'update' | 'delete' | 'insert';
47
- tables: string[];
48
- }, cacheConfig?: WithCacheConfig): PgPreparedQuery<T>;
38
+ prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, isResponseInArrayMode: boolean, customResultMapper?: (rows: unknown[][]) => T['execute']): PgPreparedQuery<T>;
49
39
  transaction<T>(transaction: (tx: NodePgTransaction<TFullSchema, TSchema>) => Promise<T>, config?: PgTransactionConfig | undefined): Promise<T>;
50
40
  count(sql: SQL): Promise<number>;
51
41
  }
@@ -1,11 +1,10 @@
1
1
  import type { Client, PoolClient, QueryResult, QueryResultRow } from 'pg';
2
2
  import pg from 'pg';
3
- import { type Cache } from "../cache/core/index.js";
4
3
  import { entityKind } from "../entity.js";
5
4
  import { type Logger } from "../logger.js";
6
5
  import type { PgDialect } from "../pg-core/dialect.js";
7
6
  import { PgTransaction } from "../pg-core/index.js";
8
- import type { SelectedFieldsOrdered, WithCacheConfig } from "../pg-core/query-builders/select.types.js";
7
+ import type { SelectedFieldsOrdered } from "../pg-core/query-builders/select.types.js";
9
8
  import type { PgQueryResultHKT, PgTransactionConfig, PreparedQueryConfig } from "../pg-core/session.js";
10
9
  import { PgPreparedQuery, PgSession } from "../pg-core/session.js";
11
10
  import type { RelationalSchemaConfig, TablesRelationalConfig } from "../relations.js";
@@ -14,7 +13,6 @@ import { type Assume } from "../utils.js";
14
13
  export type NodePgClient = pg.Pool | PoolClient | Client;
15
14
  export declare class NodePgPreparedQuery<T extends PreparedQueryConfig> extends PgPreparedQuery<T> {
16
15
  private client;
17
- private queryString;
18
16
  private params;
19
17
  private logger;
20
18
  private fields;
@@ -23,16 +21,12 @@ export declare class NodePgPreparedQuery<T extends PreparedQueryConfig> extends
23
21
  static readonly [entityKind]: string;
24
22
  private rawQueryConfig;
25
23
  private queryConfig;
26
- constructor(client: NodePgClient, queryString: string, params: unknown[], logger: Logger, cache: Cache, queryMetadata: {
27
- type: 'select' | 'update' | 'delete' | 'insert';
28
- tables: string[];
29
- } | undefined, cacheConfig: WithCacheConfig | undefined, fields: SelectedFieldsOrdered | undefined, name: string | undefined, _isResponseInArrayMode: boolean, customResultMapper?: ((rows: unknown[][]) => T["execute"]) | undefined);
24
+ constructor(client: NodePgClient, queryString: string, params: unknown[], logger: Logger, fields: SelectedFieldsOrdered | undefined, name: string | undefined, _isResponseInArrayMode: boolean, customResultMapper?: ((rows: unknown[][]) => T["execute"]) | undefined);
30
25
  execute(placeholderValues?: Record<string, unknown> | undefined): Promise<T['execute']>;
31
26
  all(placeholderValues?: Record<string, unknown> | undefined): Promise<T['all']>;
32
27
  }
33
28
  export interface NodePgSessionOptions {
34
29
  logger?: Logger;
35
- cache?: Cache;
36
30
  }
37
31
  export declare class NodePgSession<TFullSchema extends Record<string, unknown>, TSchema extends TablesRelationalConfig> extends PgSession<NodePgQueryResultHKT, TFullSchema, TSchema> {
38
32
  private client;
@@ -40,12 +34,8 @@ export declare class NodePgSession<TFullSchema extends Record<string, unknown>,
40
34
  private options;
41
35
  static readonly [entityKind]: string;
42
36
  private logger;
43
- private cache;
44
37
  constructor(client: NodePgClient, dialect: PgDialect, schema: RelationalSchemaConfig<TSchema> | undefined, options?: NodePgSessionOptions);
45
- prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, isResponseInArrayMode: boolean, customResultMapper?: (rows: unknown[][]) => T['execute'], queryMetadata?: {
46
- type: 'select' | 'update' | 'delete' | 'insert';
47
- tables: string[];
48
- }, cacheConfig?: WithCacheConfig): PgPreparedQuery<T>;
38
+ prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, isResponseInArrayMode: boolean, customResultMapper?: (rows: unknown[][]) => T['execute']): PgPreparedQuery<T>;
49
39
  transaction<T>(transaction: (tx: NodePgTransaction<TFullSchema, TSchema>) => Promise<T>, config?: PgTransactionConfig | undefined): Promise<T>;
50
40
  count(sql: SQL): Promise<number>;
51
41
  }
@@ -1,5 +1,4 @@
1
1
  import pg from "pg";
2
- import { NoopCache } from "../cache/core/index.js";
3
2
  import { entityKind } from "../entity.js";
4
3
  import { NoopLogger } from "../logger.js";
5
4
  import { PgTransaction } from "../pg-core/index.js";
@@ -9,10 +8,9 @@ import { tracer } from "../tracing.js";
9
8
  import { mapResultRow } from "../utils.js";
10
9
  const { Pool, types } = pg;
11
10
  class NodePgPreparedQuery extends PgPreparedQuery {
12
- constructor(client, queryString, params, logger, cache, queryMetadata, cacheConfig, fields, name, _isResponseInArrayMode, customResultMapper) {
13
- super({ sql: queryString, params }, cache, queryMetadata, cacheConfig);
11
+ constructor(client, queryString, params, logger, fields, name, _isResponseInArrayMode, customResultMapper) {
12
+ super({ sql: queryString, params });
14
13
  this.client = client;
15
- this.queryString = queryString;
16
14
  this.params = params;
17
15
  this.logger = logger;
18
16
  this.fields = fields;
@@ -79,9 +77,7 @@ class NodePgPreparedQuery extends PgPreparedQuery {
79
77
  "drizzle.query.text": rawQuery.text,
80
78
  "drizzle.query.params": JSON.stringify(params)
81
79
  });
82
- return this.queryWithCache(rawQuery.text, params, async () => {
83
- return await client.query(rawQuery, params);
84
- });
80
+ return client.query(rawQuery, params);
85
81
  });
86
82
  }
87
83
  const result = await tracer.startActiveSpan("drizzle.driver.execute", (span) => {
@@ -90,9 +86,7 @@ class NodePgPreparedQuery extends PgPreparedQuery {
90
86
  "drizzle.query.text": query.text,
91
87
  "drizzle.query.params": JSON.stringify(params)
92
88
  });
93
- return this.queryWithCache(query.text, params, async () => {
94
- return await client.query(query, params);
95
- });
89
+ return client.query(query, params);
96
90
  });
97
91
  return tracer.startActiveSpan("drizzle.mapResponse", () => {
98
92
  return customResultMapper ? customResultMapper(result.rows) : result.rows.map((row) => mapResultRow(fields, row, joinsNotNullableMap));
@@ -109,9 +103,7 @@ class NodePgPreparedQuery extends PgPreparedQuery {
109
103
  "drizzle.query.text": this.rawQueryConfig.text,
110
104
  "drizzle.query.params": JSON.stringify(params)
111
105
  });
112
- return this.queryWithCache(this.rawQueryConfig.text, params, async () => {
113
- return this.client.query(this.rawQueryConfig, params);
114
- }).then((result) => result.rows);
106
+ return this.client.query(this.rawQueryConfig, params).then((result) => result.rows);
115
107
  });
116
108
  });
117
109
  }
@@ -127,20 +119,15 @@ class NodePgSession extends PgSession {
127
119
  this.schema = schema;
128
120
  this.options = options;
129
121
  this.logger = options.logger ?? new NoopLogger();
130
- this.cache = options.cache ?? new NoopCache();
131
122
  }
132
123
  static [entityKind] = "NodePgSession";
133
124
  logger;
134
- cache;
135
- prepareQuery(query, fields, name, isResponseInArrayMode, customResultMapper, queryMetadata, cacheConfig) {
125
+ prepareQuery(query, fields, name, isResponseInArrayMode, customResultMapper) {
136
126
  return new NodePgPreparedQuery(
137
127
  this.client,
138
128
  query.sql,
139
129
  query.params,
140
130
  this.logger,
141
- this.cache,
142
- queryMetadata,
143
- cacheConfig,
144
131
  fields,
145
132
  name,
146
133
  isResponseInArrayMode,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/node-postgres/session.ts"],"sourcesContent":["import type { Client, PoolClient, QueryArrayConfig, QueryConfig, QueryResult, QueryResultRow } from 'pg';\nimport pg from 'pg';\nimport { type Cache, NoopCache } from '~/cache/core/index.ts';\nimport { entityKind } from '~/entity.ts';\nimport { type Logger, NoopLogger } from '~/logger.ts';\nimport type { PgDialect } from '~/pg-core/dialect.ts';\nimport { PgTransaction } from '~/pg-core/index.ts';\nimport type { SelectedFieldsOrdered, WithCacheConfig } from '~/pg-core/query-builders/select.types.ts';\nimport type { PgQueryResultHKT, PgTransactionConfig, PreparedQueryConfig } from '~/pg-core/session.ts';\nimport { PgPreparedQuery, PgSession } from '~/pg-core/session.ts';\nimport type { RelationalSchemaConfig, TablesRelationalConfig } from '~/relations.ts';\nimport { fillPlaceholders, type Query, type SQL, sql } from '~/sql/sql.ts';\nimport { tracer } from '~/tracing.ts';\nimport { type Assume, mapResultRow } from '~/utils.ts';\n\nconst { Pool, types } = pg;\n\nexport type NodePgClient = pg.Pool | PoolClient | Client;\n\nexport class NodePgPreparedQuery<T extends PreparedQueryConfig> extends PgPreparedQuery<T> {\n\tstatic override readonly [entityKind]: string = 'NodePgPreparedQuery';\n\n\tprivate rawQueryConfig: QueryConfig;\n\tprivate queryConfig: QueryArrayConfig;\n\n\tconstructor(\n\t\tprivate client: NodePgClient,\n\t\tprivate queryString: string,\n\t\tprivate params: unknown[],\n\t\tprivate logger: Logger,\n\t\tcache: Cache,\n\t\tqueryMetadata: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t} | undefined,\n\t\tcacheConfig: WithCacheConfig | undefined,\n\t\tprivate fields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tprivate _isResponseInArrayMode: boolean,\n\t\tprivate customResultMapper?: (rows: unknown[][]) => T['execute'],\n\t) {\n\t\tsuper({ sql: queryString, params }, cache, queryMetadata, cacheConfig);\n\t\tthis.rawQueryConfig = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t\tthis.queryConfig = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\trowMode: 'array',\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t}\n\n\tasync execute(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['execute']> {\n\t\treturn tracer.startActiveSpan('drizzle.execute', async () => {\n\t\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\n\t\t\tthis.logger.logQuery(this.rawQueryConfig.text, params);\n\n\t\t\tconst { fields, rawQueryConfig: rawQuery, client, queryConfig: query, joinsNotNullableMap, customResultMapper } =\n\t\t\t\tthis;\n\t\t\tif (!fields && !customResultMapper) {\n\t\t\t\treturn tracer.startActiveSpan('drizzle.driver.execute', async (span) => {\n\t\t\t\t\tspan?.setAttributes({\n\t\t\t\t\t\t'drizzle.query.name': rawQuery.name,\n\t\t\t\t\t\t'drizzle.query.text': rawQuery.text,\n\t\t\t\t\t\t'drizzle.query.params': JSON.stringify(params),\n\t\t\t\t\t});\n\t\t\t\t\treturn this.queryWithCache(rawQuery.text, params, async () => {\n\t\t\t\t\t\treturn await client.query(rawQuery, params);\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tconst result = await tracer.startActiveSpan('drizzle.driver.execute', (span) => {\n\t\t\t\tspan?.setAttributes({\n\t\t\t\t\t'drizzle.query.name': query.name,\n\t\t\t\t\t'drizzle.query.text': query.text,\n\t\t\t\t\t'drizzle.query.params': JSON.stringify(params),\n\t\t\t\t});\n\t\t\t\treturn this.queryWithCache(query.text, params, async () => {\n\t\t\t\t\treturn await client.query(query, params);\n\t\t\t\t});\n\t\t\t});\n\n\t\t\treturn tracer.startActiveSpan('drizzle.mapResponse', () => {\n\t\t\t\treturn customResultMapper\n\t\t\t\t\t? customResultMapper(result.rows)\n\t\t\t\t\t: result.rows.map((row) => mapResultRow<T['execute']>(fields!, row, joinsNotNullableMap));\n\t\t\t});\n\t\t});\n\t}\n\n\tall(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['all']> {\n\t\treturn tracer.startActiveSpan('drizzle.execute', () => {\n\t\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\t\t\tthis.logger.logQuery(this.rawQueryConfig.text, params);\n\t\t\treturn tracer.startActiveSpan('drizzle.driver.execute', (span) => {\n\t\t\t\tspan?.setAttributes({\n\t\t\t\t\t'drizzle.query.name': this.rawQueryConfig.name,\n\t\t\t\t\t'drizzle.query.text': this.rawQueryConfig.text,\n\t\t\t\t\t'drizzle.query.params': JSON.stringify(params),\n\t\t\t\t});\n\t\t\t\treturn this.queryWithCache(this.rawQueryConfig.text, params, async () => {\n\t\t\t\t\treturn this.client.query(this.rawQueryConfig, params);\n\t\t\t\t}).then((result) => result.rows);\n\t\t\t});\n\t\t});\n\t}\n\n\t/** @internal */\n\tisResponseInArrayMode(): boolean {\n\t\treturn this._isResponseInArrayMode;\n\t}\n}\n\nexport interface NodePgSessionOptions {\n\tlogger?: Logger;\n\tcache?: Cache;\n}\n\nexport class NodePgSession<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgSession<NodePgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'NodePgSession';\n\n\tprivate logger: Logger;\n\tprivate cache: Cache;\n\n\tconstructor(\n\t\tprivate client: NodePgClient,\n\t\tdialect: PgDialect,\n\t\tprivate schema: RelationalSchemaConfig<TSchema> | undefined,\n\t\tprivate options: NodePgSessionOptions = {},\n\t) {\n\t\tsuper(dialect);\n\t\tthis.logger = options.logger ?? new NoopLogger();\n\t\tthis.cache = options.cache ?? new NoopCache();\n\t}\n\n\tprepareQuery<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[][]) => 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): PgPreparedQuery<T> {\n\t\treturn new NodePgPreparedQuery(\n\t\t\tthis.client,\n\t\t\tquery.sql,\n\t\t\tquery.params,\n\t\t\tthis.logger,\n\t\t\tthis.cache,\n\t\t\tqueryMetadata,\n\t\t\tcacheConfig,\n\t\t\tfields,\n\t\t\tname,\n\t\t\tisResponseInArrayMode,\n\t\t\tcustomResultMapper,\n\t\t);\n\t}\n\n\toverride async transaction<T>(\n\t\ttransaction: (tx: NodePgTransaction<TFullSchema, TSchema>) => Promise<T>,\n\t\tconfig?: PgTransactionConfig | undefined,\n\t): Promise<T> {\n\t\tconst session = this.client instanceof Pool // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t? new NodePgSession(await this.client.connect(), this.dialect, this.schema, this.options)\n\t\t\t: this;\n\t\tconst tx = new NodePgTransaction<TFullSchema, TSchema>(this.dialect, session, this.schema);\n\t\tawait tx.execute(sql`begin${config ? sql` ${tx.getTransactionConfigSQL(config)}` : undefined}`);\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql`commit`);\n\t\t\treturn result;\n\t\t} catch (error) {\n\t\t\tawait tx.execute(sql`rollback`);\n\t\t\tthrow error;\n\t\t} finally {\n\t\t\tif (this.client instanceof Pool) { // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t\t(session.client as PoolClient).release();\n\t\t\t}\n\t\t}\n\t}\n\n\toverride async count(sql: SQL): Promise<number> {\n\t\tconst res = await this.execute<{ rows: [{ count: string }] }>(sql);\n\t\treturn Number(\n\t\t\tres['rows'][0]['count'],\n\t\t);\n\t}\n}\n\nexport class NodePgTransaction<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgTransaction<NodePgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'NodePgTransaction';\n\n\toverride async transaction<T>(transaction: (tx: NodePgTransaction<TFullSchema, TSchema>) => Promise<T>): Promise<T> {\n\t\tconst savepointName = `sp${this.nestedIndex + 1}`;\n\t\tconst tx = new NodePgTransaction<TFullSchema, TSchema>(\n\t\t\tthis.dialect,\n\t\t\tthis.session,\n\t\t\tthis.schema,\n\t\t\tthis.nestedIndex + 1,\n\t\t);\n\t\tawait tx.execute(sql.raw(`savepoint ${savepointName}`));\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql.raw(`release savepoint ${savepointName}`));\n\t\t\treturn result;\n\t\t} catch (err) {\n\t\t\tawait tx.execute(sql.raw(`rollback to savepoint ${savepointName}`));\n\t\t\tthrow err;\n\t\t}\n\t}\n}\n\nexport interface NodePgQueryResultHKT extends PgQueryResultHKT {\n\ttype: QueryResult<Assume<this['row'], QueryResultRow>>;\n}\n"],"mappings":"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","names":["sql"]}
1
+ {"version":3,"sources":["../../src/node-postgres/session.ts"],"sourcesContent":["import type { Client, PoolClient, QueryArrayConfig, QueryConfig, QueryResult, QueryResultRow } from 'pg';\nimport pg from 'pg';\nimport { entityKind } from '~/entity.ts';\nimport { type Logger, NoopLogger } from '~/logger.ts';\nimport type { PgDialect } from '~/pg-core/dialect.ts';\nimport { PgTransaction } from '~/pg-core/index.ts';\nimport type { SelectedFieldsOrdered } from '~/pg-core/query-builders/select.types.ts';\nimport type { PgQueryResultHKT, PgTransactionConfig, PreparedQueryConfig } from '~/pg-core/session.ts';\nimport { PgPreparedQuery, PgSession } from '~/pg-core/session.ts';\nimport type { RelationalSchemaConfig, TablesRelationalConfig } from '~/relations.ts';\nimport { fillPlaceholders, type Query, type SQL, sql } from '~/sql/sql.ts';\nimport { tracer } from '~/tracing.ts';\nimport { type Assume, mapResultRow } from '~/utils.ts';\n\nconst { Pool, types } = pg;\n\nexport type NodePgClient = pg.Pool | PoolClient | Client;\n\nexport class NodePgPreparedQuery<T extends PreparedQueryConfig> extends PgPreparedQuery<T> {\n\tstatic override readonly [entityKind]: string = 'NodePgPreparedQuery';\n\n\tprivate rawQueryConfig: QueryConfig;\n\tprivate queryConfig: QueryArrayConfig;\n\n\tconstructor(\n\t\tprivate client: NodePgClient,\n\t\tqueryString: string,\n\t\tprivate params: unknown[],\n\t\tprivate logger: Logger,\n\t\tprivate fields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tprivate _isResponseInArrayMode: boolean,\n\t\tprivate customResultMapper?: (rows: unknown[][]) => T['execute'],\n\t) {\n\t\tsuper({ sql: queryString, params });\n\t\tthis.rawQueryConfig = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t\tthis.queryConfig = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\trowMode: 'array',\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t}\n\n\tasync execute(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['execute']> {\n\t\treturn tracer.startActiveSpan('drizzle.execute', async () => {\n\t\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\n\t\t\tthis.logger.logQuery(this.rawQueryConfig.text, params);\n\n\t\t\tconst { fields, rawQueryConfig: rawQuery, client, queryConfig: query, joinsNotNullableMap, customResultMapper } =\n\t\t\t\tthis;\n\t\t\tif (!fields && !customResultMapper) {\n\t\t\t\treturn tracer.startActiveSpan('drizzle.driver.execute', async (span) => {\n\t\t\t\t\tspan?.setAttributes({\n\t\t\t\t\t\t'drizzle.query.name': rawQuery.name,\n\t\t\t\t\t\t'drizzle.query.text': rawQuery.text,\n\t\t\t\t\t\t'drizzle.query.params': JSON.stringify(params),\n\t\t\t\t\t});\n\t\t\t\t\treturn client.query(rawQuery, params);\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tconst result = await tracer.startActiveSpan('drizzle.driver.execute', (span) => {\n\t\t\t\tspan?.setAttributes({\n\t\t\t\t\t'drizzle.query.name': query.name,\n\t\t\t\t\t'drizzle.query.text': query.text,\n\t\t\t\t\t'drizzle.query.params': JSON.stringify(params),\n\t\t\t\t});\n\t\t\t\treturn client.query(query, params);\n\t\t\t});\n\n\t\t\treturn tracer.startActiveSpan('drizzle.mapResponse', () => {\n\t\t\t\treturn customResultMapper\n\t\t\t\t\t? customResultMapper(result.rows)\n\t\t\t\t\t: result.rows.map((row) => mapResultRow<T['execute']>(fields!, row, joinsNotNullableMap));\n\t\t\t});\n\t\t});\n\t}\n\n\tall(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['all']> {\n\t\treturn tracer.startActiveSpan('drizzle.execute', () => {\n\t\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\t\t\tthis.logger.logQuery(this.rawQueryConfig.text, params);\n\t\t\treturn tracer.startActiveSpan('drizzle.driver.execute', (span) => {\n\t\t\t\tspan?.setAttributes({\n\t\t\t\t\t'drizzle.query.name': this.rawQueryConfig.name,\n\t\t\t\t\t'drizzle.query.text': this.rawQueryConfig.text,\n\t\t\t\t\t'drizzle.query.params': JSON.stringify(params),\n\t\t\t\t});\n\t\t\t\treturn this.client.query(this.rawQueryConfig, params).then((result) => result.rows);\n\t\t\t});\n\t\t});\n\t}\n\n\t/** @internal */\n\tisResponseInArrayMode(): boolean {\n\t\treturn this._isResponseInArrayMode;\n\t}\n}\n\nexport interface NodePgSessionOptions {\n\tlogger?: Logger;\n}\n\nexport class NodePgSession<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgSession<NodePgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'NodePgSession';\n\n\tprivate logger: Logger;\n\n\tconstructor(\n\t\tprivate client: NodePgClient,\n\t\tdialect: PgDialect,\n\t\tprivate schema: RelationalSchemaConfig<TSchema> | undefined,\n\t\tprivate options: NodePgSessionOptions = {},\n\t) {\n\t\tsuper(dialect);\n\t\tthis.logger = options.logger ?? new NoopLogger();\n\t}\n\n\tprepareQuery<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[][]) => T['execute'],\n\t): PgPreparedQuery<T> {\n\t\treturn new NodePgPreparedQuery(\n\t\t\tthis.client,\n\t\t\tquery.sql,\n\t\t\tquery.params,\n\t\t\tthis.logger,\n\t\t\tfields,\n\t\t\tname,\n\t\t\tisResponseInArrayMode,\n\t\t\tcustomResultMapper,\n\t\t);\n\t}\n\n\toverride async transaction<T>(\n\t\ttransaction: (tx: NodePgTransaction<TFullSchema, TSchema>) => Promise<T>,\n\t\tconfig?: PgTransactionConfig | undefined,\n\t): Promise<T> {\n\t\tconst session = this.client instanceof Pool // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t? new NodePgSession(await this.client.connect(), this.dialect, this.schema, this.options)\n\t\t\t: this;\n\t\tconst tx = new NodePgTransaction<TFullSchema, TSchema>(this.dialect, session, this.schema);\n\t\tawait tx.execute(sql`begin${config ? sql` ${tx.getTransactionConfigSQL(config)}` : undefined}`);\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql`commit`);\n\t\t\treturn result;\n\t\t} catch (error) {\n\t\t\tawait tx.execute(sql`rollback`);\n\t\t\tthrow error;\n\t\t} finally {\n\t\t\tif (this.client instanceof Pool) { // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t\t(session.client as PoolClient).release();\n\t\t\t}\n\t\t}\n\t}\n\n\toverride async count(sql: SQL): Promise<number> {\n\t\tconst res = await this.execute<{ rows: [{ count: string }] }>(sql);\n\t\treturn Number(\n\t\t\tres['rows'][0]['count'],\n\t\t);\n\t}\n}\n\nexport class NodePgTransaction<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgTransaction<NodePgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'NodePgTransaction';\n\n\toverride async transaction<T>(transaction: (tx: NodePgTransaction<TFullSchema, TSchema>) => Promise<T>): Promise<T> {\n\t\tconst savepointName = `sp${this.nestedIndex + 1}`;\n\t\tconst tx = new NodePgTransaction<TFullSchema, TSchema>(\n\t\t\tthis.dialect,\n\t\t\tthis.session,\n\t\t\tthis.schema,\n\t\t\tthis.nestedIndex + 1,\n\t\t);\n\t\tawait tx.execute(sql.raw(`savepoint ${savepointName}`));\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql.raw(`release savepoint ${savepointName}`));\n\t\t\treturn result;\n\t\t} catch (err) {\n\t\t\tawait tx.execute(sql.raw(`rollback to savepoint ${savepointName}`));\n\t\t\tthrow err;\n\t\t}\n\t}\n}\n\nexport interface NodePgQueryResultHKT extends PgQueryResultHKT {\n\ttype: QueryResult<Assume<this['row'], QueryResultRow>>;\n}\n"],"mappings":"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","names":["sql"]}