drizzle-orm 0.39.3 → 0.40.0-af1f2fe

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 (381) hide show
  1. package/column-builder.cjs.map +1 -1
  2. package/column-builder.d.cts +6 -5
  3. package/column-builder.d.ts +6 -5
  4. package/column-builder.js.map +1 -1
  5. package/gel/driver.cjs +97 -0
  6. package/gel/driver.cjs.map +1 -0
  7. package/gel/driver.d.cts +38 -0
  8. package/gel/driver.d.ts +38 -0
  9. package/gel/driver.js +74 -0
  10. package/gel/driver.js.map +1 -0
  11. package/gel/index.cjs +25 -0
  12. package/gel/index.cjs.map +1 -0
  13. package/gel/index.d.cts +2 -0
  14. package/gel/index.d.ts +2 -0
  15. package/gel/index.js +3 -0
  16. package/gel/index.js.map +1 -0
  17. package/gel/migrator.cjs +5 -0
  18. package/gel/migrator.cjs.map +1 -0
  19. package/gel/migrator.d.cts +1 -0
  20. package/gel/migrator.d.ts +1 -0
  21. package/gel/migrator.js +4 -0
  22. package/gel/migrator.js.map +1 -0
  23. package/gel/session.cjs +139 -0
  24. package/gel/session.cjs.map +1 -0
  25. package/gel/session.d.cts +47 -0
  26. package/gel/session.d.ts +47 -0
  27. package/gel/session.js +113 -0
  28. package/gel/session.js.map +1 -0
  29. package/gel-core/alias.cjs +32 -0
  30. package/gel-core/alias.cjs.map +1 -0
  31. package/gel-core/alias.d.cts +4 -0
  32. package/gel-core/alias.d.ts +4 -0
  33. package/gel-core/alias.js +8 -0
  34. package/gel-core/alias.js.map +1 -0
  35. package/gel-core/checks.cjs +58 -0
  36. package/gel-core/checks.cjs.map +1 -0
  37. package/gel-core/checks.d.cts +18 -0
  38. package/gel-core/checks.d.ts +18 -0
  39. package/gel-core/checks.js +32 -0
  40. package/gel-core/checks.js.map +1 -0
  41. package/gel-core/columns/all.cjs +72 -0
  42. package/gel-core/columns/all.cjs.map +1 -0
  43. package/gel-core/columns/all.d.cts +43 -0
  44. package/gel-core/columns/all.d.ts +43 -0
  45. package/gel-core/columns/all.js +48 -0
  46. package/gel-core/columns/all.js.map +1 -0
  47. package/gel-core/columns/bigint.cjs +54 -0
  48. package/gel-core/columns/bigint.cjs.map +1 -0
  49. package/gel-core/columns/bigint.d.cts +23 -0
  50. package/gel-core/columns/bigint.d.ts +23 -0
  51. package/gel-core/columns/bigint.js +28 -0
  52. package/gel-core/columns/bigint.js.map +1 -0
  53. package/gel-core/columns/bigintT.cjs +60 -0
  54. package/gel-core/columns/bigintT.cjs.map +1 -0
  55. package/gel-core/columns/bigintT.d.cts +24 -0
  56. package/gel-core/columns/bigintT.d.ts +24 -0
  57. package/gel-core/columns/bigintT.js +34 -0
  58. package/gel-core/columns/bigintT.js.map +1 -0
  59. package/gel-core/columns/boolean.cjs +53 -0
  60. package/gel-core/columns/boolean.cjs.map +1 -0
  61. package/gel-core/columns/boolean.d.cts +22 -0
  62. package/gel-core/columns/boolean.d.ts +22 -0
  63. package/gel-core/columns/boolean.js +27 -0
  64. package/gel-core/columns/boolean.js.map +1 -0
  65. package/gel-core/columns/bytes.cjs +56 -0
  66. package/gel-core/columns/bytes.cjs.map +1 -0
  67. package/gel-core/columns/bytes.d.cts +22 -0
  68. package/gel-core/columns/bytes.d.ts +22 -0
  69. package/gel-core/columns/bytes.js +30 -0
  70. package/gel-core/columns/bytes.js.map +1 -0
  71. package/gel-core/columns/common.cjs +213 -0
  72. package/gel-core/columns/common.cjs.map +1 -0
  73. package/gel-core/columns/common.d.cts +147 -0
  74. package/gel-core/columns/common.d.ts +147 -0
  75. package/gel-core/columns/common.js +184 -0
  76. package/gel-core/columns/common.js.map +1 -0
  77. package/gel-core/columns/custom.cjs +77 -0
  78. package/gel-core/columns/custom.cjs.map +1 -0
  79. package/gel-core/columns/custom.d.cts +155 -0
  80. package/gel-core/columns/custom.d.ts +155 -0
  81. package/gel-core/columns/custom.js +51 -0
  82. package/gel-core/columns/custom.js.map +1 -0
  83. package/gel-core/columns/date-duration.cjs +56 -0
  84. package/gel-core/columns/date-duration.cjs.map +1 -0
  85. package/gel-core/columns/date-duration.d.cts +23 -0
  86. package/gel-core/columns/date-duration.d.ts +23 -0
  87. package/gel-core/columns/date-duration.js +30 -0
  88. package/gel-core/columns/date-duration.js.map +1 -0
  89. package/gel-core/columns/date.common.cjs +37 -0
  90. package/gel-core/columns/date.common.cjs.map +1 -0
  91. package/gel-core/columns/date.common.d.cts +7 -0
  92. package/gel-core/columns/date.common.d.ts +7 -0
  93. package/gel-core/columns/date.common.js +13 -0
  94. package/gel-core/columns/date.common.js.map +1 -0
  95. package/gel-core/columns/decimal.cjs +56 -0
  96. package/gel-core/columns/decimal.cjs.map +1 -0
  97. package/gel-core/columns/decimal.d.cts +26 -0
  98. package/gel-core/columns/decimal.d.ts +26 -0
  99. package/gel-core/columns/decimal.js +30 -0
  100. package/gel-core/columns/decimal.js.map +1 -0
  101. package/gel-core/columns/double-precision.cjs +62 -0
  102. package/gel-core/columns/double-precision.cjs.map +1 -0
  103. package/gel-core/columns/double-precision.d.cts +23 -0
  104. package/gel-core/columns/double-precision.d.ts +23 -0
  105. package/gel-core/columns/double-precision.js +36 -0
  106. package/gel-core/columns/double-precision.js.map +1 -0
  107. package/gel-core/columns/duration.cjs +53 -0
  108. package/gel-core/columns/duration.cjs.map +1 -0
  109. package/gel-core/columns/duration.d.cts +23 -0
  110. package/gel-core/columns/duration.d.ts +23 -0
  111. package/gel-core/columns/duration.js +27 -0
  112. package/gel-core/columns/duration.js.map +1 -0
  113. package/gel-core/columns/index.cjs +65 -0
  114. package/gel-core/columns/index.cjs.map +1 -0
  115. package/gel-core/columns/index.d.cts +22 -0
  116. package/gel-core/columns/index.d.ts +22 -0
  117. package/gel-core/columns/index.js +23 -0
  118. package/gel-core/columns/index.js.map +1 -0
  119. package/gel-core/columns/int.common.cjs +67 -0
  120. package/gel-core/columns/int.common.cjs.map +1 -0
  121. package/gel-core/columns/int.common.d.cts +15 -0
  122. package/gel-core/columns/int.common.d.ts +15 -0
  123. package/gel-core/columns/int.common.js +43 -0
  124. package/gel-core/columns/int.common.js.map +1 -0
  125. package/gel-core/columns/integer.cjs +54 -0
  126. package/gel-core/columns/integer.cjs.map +1 -0
  127. package/gel-core/columns/integer.d.cts +23 -0
  128. package/gel-core/columns/integer.d.ts +23 -0
  129. package/gel-core/columns/integer.js +28 -0
  130. package/gel-core/columns/integer.js.map +1 -0
  131. package/gel-core/columns/json.cjs +56 -0
  132. package/gel-core/columns/json.cjs.map +1 -0
  133. package/gel-core/columns/json.d.cts +26 -0
  134. package/gel-core/columns/json.d.ts +26 -0
  135. package/gel-core/columns/json.js +30 -0
  136. package/gel-core/columns/json.js.map +1 -0
  137. package/gel-core/columns/localdate.cjs +57 -0
  138. package/gel-core/columns/localdate.cjs.map +1 -0
  139. package/gel-core/columns/localdate.d.cts +24 -0
  140. package/gel-core/columns/localdate.d.ts +24 -0
  141. package/gel-core/columns/localdate.js +31 -0
  142. package/gel-core/columns/localdate.js.map +1 -0
  143. package/gel-core/columns/localtime.cjs +57 -0
  144. package/gel-core/columns/localtime.cjs.map +1 -0
  145. package/gel-core/columns/localtime.d.cts +24 -0
  146. package/gel-core/columns/localtime.d.ts +24 -0
  147. package/gel-core/columns/localtime.js +31 -0
  148. package/gel-core/columns/localtime.js.map +1 -0
  149. package/gel-core/columns/real.cjs +57 -0
  150. package/gel-core/columns/real.cjs.map +1 -0
  151. package/gel-core/columns/real.d.cts +28 -0
  152. package/gel-core/columns/real.d.ts +28 -0
  153. package/gel-core/columns/real.js +31 -0
  154. package/gel-core/columns/real.js.map +1 -0
  155. package/gel-core/columns/relative-duration.cjs +56 -0
  156. package/gel-core/columns/relative-duration.cjs.map +1 -0
  157. package/gel-core/columns/relative-duration.d.cts +23 -0
  158. package/gel-core/columns/relative-duration.d.ts +23 -0
  159. package/gel-core/columns/relative-duration.js +30 -0
  160. package/gel-core/columns/relative-duration.js.map +1 -0
  161. package/gel-core/columns/smallint.cjs +54 -0
  162. package/gel-core/columns/smallint.cjs.map +1 -0
  163. package/gel-core/columns/smallint.d.cts +23 -0
  164. package/gel-core/columns/smallint.d.ts +23 -0
  165. package/gel-core/columns/smallint.js +28 -0
  166. package/gel-core/columns/smallint.js.map +1 -0
  167. package/gel-core/columns/text.cjs +54 -0
  168. package/gel-core/columns/text.cjs.map +1 -0
  169. package/gel-core/columns/text.d.cts +26 -0
  170. package/gel-core/columns/text.d.ts +26 -0
  171. package/gel-core/columns/text.js +28 -0
  172. package/gel-core/columns/text.js.map +1 -0
  173. package/gel-core/columns/timestamp.cjs +60 -0
  174. package/gel-core/columns/timestamp.cjs.map +1 -0
  175. package/gel-core/columns/timestamp.d.cts +28 -0
  176. package/gel-core/columns/timestamp.d.ts +28 -0
  177. package/gel-core/columns/timestamp.js +34 -0
  178. package/gel-core/columns/timestamp.js.map +1 -0
  179. package/gel-core/columns/timestamptz.cjs +60 -0
  180. package/gel-core/columns/timestamptz.cjs.map +1 -0
  181. package/gel-core/columns/timestamptz.d.cts +27 -0
  182. package/gel-core/columns/timestamptz.d.ts +27 -0
  183. package/gel-core/columns/timestamptz.js +34 -0
  184. package/gel-core/columns/timestamptz.js.map +1 -0
  185. package/gel-core/columns/uuid.cjs +53 -0
  186. package/gel-core/columns/uuid.cjs.map +1 -0
  187. package/gel-core/columns/uuid.d.cts +22 -0
  188. package/gel-core/columns/uuid.d.ts +22 -0
  189. package/gel-core/columns/uuid.js +27 -0
  190. package/gel-core/columns/uuid.js.map +1 -0
  191. package/gel-core/db.cjs +338 -0
  192. package/gel-core/db.cjs.map +1 -0
  193. package/gel-core/db.d.cts +281 -0
  194. package/gel-core/db.d.ts +281 -0
  195. package/gel-core/db.js +319 -0
  196. package/gel-core/db.js.map +1 -0
  197. package/gel-core/dialect.cjs +1142 -0
  198. package/gel-core/dialect.cjs.map +1 -0
  199. package/gel-core/dialect.d.cts +62 -0
  200. package/gel-core/dialect.d.ts +62 -0
  201. package/gel-core/dialect.js +1128 -0
  202. package/gel-core/dialect.js.map +1 -0
  203. package/gel-core/expressions.cjs +49 -0
  204. package/gel-core/expressions.cjs.map +1 -0
  205. package/gel-core/expressions.d.cts +8 -0
  206. package/gel-core/expressions.d.ts +8 -0
  207. package/gel-core/expressions.js +22 -0
  208. package/gel-core/expressions.js.map +1 -0
  209. package/gel-core/foreign-keys.cjs +100 -0
  210. package/gel-core/foreign-keys.cjs.map +1 -0
  211. package/gel-core/foreign-keys.d.cts +48 -0
  212. package/gel-core/foreign-keys.d.ts +48 -0
  213. package/gel-core/foreign-keys.js +74 -0
  214. package/gel-core/foreign-keys.js.map +1 -0
  215. package/gel-core/index.cjs +61 -0
  216. package/gel-core/index.cjs.map +1 -0
  217. package/gel-core/index.d.cts +20 -0
  218. package/gel-core/index.d.ts +20 -0
  219. package/gel-core/index.js +21 -0
  220. package/gel-core/index.js.map +1 -0
  221. package/gel-core/indexes.cjs +149 -0
  222. package/gel-core/indexes.cjs.map +1 -0
  223. package/gel-core/indexes.d.cts +79 -0
  224. package/gel-core/indexes.d.ts +79 -0
  225. package/gel-core/indexes.js +121 -0
  226. package/gel-core/indexes.js.map +1 -0
  227. package/gel-core/policies.cjs +58 -0
  228. package/gel-core/policies.cjs.map +1 -0
  229. package/gel-core/policies.d.cts +24 -0
  230. package/gel-core/policies.d.ts +24 -0
  231. package/gel-core/policies.js +33 -0
  232. package/gel-core/policies.js.map +1 -0
  233. package/gel-core/primary-keys.cjs +68 -0
  234. package/gel-core/primary-keys.cjs.map +1 -0
  235. package/gel-core/primary-keys.d.cts +30 -0
  236. package/gel-core/primary-keys.d.ts +30 -0
  237. package/gel-core/primary-keys.js +42 -0
  238. package/gel-core/primary-keys.js.map +1 -0
  239. package/gel-core/query-builders/count.cjs +73 -0
  240. package/gel-core/query-builders/count.cjs.map +1 -0
  241. package/gel-core/query-builders/count.d.cts +25 -0
  242. package/gel-core/query-builders/count.d.ts +25 -0
  243. package/gel-core/query-builders/count.js +49 -0
  244. package/gel-core/query-builders/count.js.map +1 -0
  245. package/gel-core/query-builders/delete.cjs +105 -0
  246. package/gel-core/query-builders/delete.cjs.map +1 -0
  247. package/gel-core/query-builders/delete.d.cts +99 -0
  248. package/gel-core/query-builders/delete.d.ts +99 -0
  249. package/gel-core/query-builders/delete.js +81 -0
  250. package/gel-core/query-builders/delete.js.map +1 -0
  251. package/gel-core/query-builders/index.cjs +35 -0
  252. package/gel-core/query-builders/index.cjs.map +1 -0
  253. package/gel-core/query-builders/index.d.cts +7 -0
  254. package/gel-core/query-builders/index.d.ts +7 -0
  255. package/gel-core/query-builders/index.js +8 -0
  256. package/gel-core/query-builders/index.js.map +1 -0
  257. package/gel-core/query-builders/insert.cjs +218 -0
  258. package/gel-core/query-builders/insert.cjs.map +1 -0
  259. package/gel-core/query-builders/insert.d.cts +116 -0
  260. package/gel-core/query-builders/insert.d.ts +116 -0
  261. package/gel-core/query-builders/insert.js +193 -0
  262. package/gel-core/query-builders/insert.js.map +1 -0
  263. package/gel-core/query-builders/query-builder.cjs +114 -0
  264. package/gel-core/query-builders/query-builder.cjs.map +1 -0
  265. package/gel-core/query-builders/query-builder.d.cts +40 -0
  266. package/gel-core/query-builders/query-builder.d.ts +40 -0
  267. package/gel-core/query-builders/query-builder.js +90 -0
  268. package/gel-core/query-builders/query-builder.js.map +1 -0
  269. package/gel-core/query-builders/query.cjs +139 -0
  270. package/gel-core/query-builders/query.cjs.map +1 -0
  271. package/gel-core/query-builders/query.d.cts +46 -0
  272. package/gel-core/query-builders/query.d.ts +46 -0
  273. package/gel-core/query-builders/query.js +116 -0
  274. package/gel-core/query-builders/query.js.map +1 -0
  275. package/gel-core/query-builders/raw.cjs +57 -0
  276. package/gel-core/query-builders/raw.cjs.map +1 -0
  277. package/gel-core/query-builders/raw.d.cts +22 -0
  278. package/gel-core/query-builders/raw.d.ts +22 -0
  279. package/gel-core/query-builders/raw.js +33 -0
  280. package/gel-core/query-builders/raw.js.map +1 -0
  281. package/gel-core/query-builders/refresh-materialized-view.cjs +77 -0
  282. package/gel-core/query-builders/refresh-materialized-view.cjs.map +1 -0
  283. package/gel-core/query-builders/refresh-materialized-view.d.cts +27 -0
  284. package/gel-core/query-builders/refresh-materialized-view.d.ts +27 -0
  285. package/gel-core/query-builders/refresh-materialized-view.js +53 -0
  286. package/gel-core/query-builders/refresh-materialized-view.js.map +1 -0
  287. package/gel-core/query-builders/select.cjs +775 -0
  288. package/gel-core/query-builders/select.cjs.map +1 -0
  289. package/gel-core/query-builders/select.d.cts +721 -0
  290. package/gel-core/query-builders/select.d.ts +721 -0
  291. package/gel-core/query-builders/select.js +748 -0
  292. package/gel-core/query-builders/select.js.map +1 -0
  293. package/gel-core/query-builders/select.types.cjs +17 -0
  294. package/gel-core/query-builders/select.types.cjs.map +1 -0
  295. package/gel-core/query-builders/select.types.d.cts +138 -0
  296. package/gel-core/query-builders/select.types.d.ts +138 -0
  297. package/gel-core/query-builders/select.types.js +1 -0
  298. package/gel-core/query-builders/select.types.js.map +1 -0
  299. package/gel-core/query-builders/update.cjs +226 -0
  300. package/gel-core/query-builders/update.cjs.map +1 -0
  301. package/gel-core/query-builders/update.d.cts +166 -0
  302. package/gel-core/query-builders/update.d.ts +166 -0
  303. package/gel-core/query-builders/update.js +205 -0
  304. package/gel-core/query-builders/update.js.map +1 -0
  305. package/gel-core/roles.cjs +57 -0
  306. package/gel-core/roles.cjs.map +1 -0
  307. package/gel-core/roles.d.cts +13 -0
  308. package/gel-core/roles.d.ts +13 -0
  309. package/gel-core/roles.js +32 -0
  310. package/gel-core/roles.js.map +1 -0
  311. package/gel-core/schema.cjs +74 -0
  312. package/gel-core/schema.cjs.map +1 -0
  313. package/gel-core/schema.d.cts +15 -0
  314. package/gel-core/schema.d.ts +15 -0
  315. package/gel-core/schema.js +48 -0
  316. package/gel-core/schema.js.map +1 -0
  317. package/gel-core/sequence.cjs +52 -0
  318. package/gel-core/sequence.cjs.map +1 -0
  319. package/gel-core/sequence.d.cts +18 -0
  320. package/gel-core/sequence.d.ts +18 -0
  321. package/gel-core/sequence.js +25 -0
  322. package/gel-core/sequence.js.map +1 -0
  323. package/gel-core/session.cjs +94 -0
  324. package/gel-core/session.cjs.map +1 -0
  325. package/gel-core/session.d.cts +56 -0
  326. package/gel-core/session.d.ts +56 -0
  327. package/gel-core/session.js +68 -0
  328. package/gel-core/session.js.map +1 -0
  329. package/gel-core/subquery.cjs +17 -0
  330. package/gel-core/subquery.cjs.map +1 -0
  331. package/gel-core/subquery.d.cts +5 -0
  332. package/gel-core/subquery.d.ts +5 -0
  333. package/gel-core/subquery.js +1 -0
  334. package/gel-core/subquery.js.map +1 -0
  335. package/gel-core/table.cjs +100 -0
  336. package/gel-core/table.cjs.map +1 -0
  337. package/gel-core/table.d.cts +95 -0
  338. package/gel-core/table.d.ts +95 -0
  339. package/gel-core/table.js +71 -0
  340. package/gel-core/table.js.map +1 -0
  341. package/gel-core/unique-constraint.cjs +89 -0
  342. package/gel-core/unique-constraint.cjs.map +1 -0
  343. package/gel-core/unique-constraint.d.cts +25 -0
  344. package/gel-core/unique-constraint.d.ts +25 -0
  345. package/gel-core/unique-constraint.js +61 -0
  346. package/gel-core/unique-constraint.js.map +1 -0
  347. package/gel-core/utils.cjs +100 -0
  348. package/gel-core/utils.cjs.map +1 -0
  349. package/gel-core/utils.d.cts +51 -0
  350. package/gel-core/utils.d.ts +51 -0
  351. package/gel-core/utils.js +74 -0
  352. package/gel-core/utils.js.map +1 -0
  353. package/gel-core/view-base.cjs +33 -0
  354. package/gel-core/view-base.cjs.map +1 -0
  355. package/gel-core/view-base.d.cts +8 -0
  356. package/gel-core/view-base.d.ts +8 -0
  357. package/gel-core/view-base.js +9 -0
  358. package/gel-core/view-base.js.map +1 -0
  359. package/gel-core/view-common.cjs +29 -0
  360. package/gel-core/view-common.cjs.map +1 -0
  361. package/gel-core/view-common.d.cts +1 -0
  362. package/gel-core/view-common.d.ts +1 -0
  363. package/gel-core/view-common.js +5 -0
  364. package/gel-core/view-common.js.map +1 -0
  365. package/gel-core/view.cjs +302 -0
  366. package/gel-core/view.cjs.map +1 -0
  367. package/gel-core/view.d.cts +150 -0
  368. package/gel-core/view.d.ts +150 -0
  369. package/gel-core/view.js +268 -0
  370. package/gel-core/view.js.map +1 -0
  371. package/package.json +795 -50
  372. package/pg-core/table.cjs +2 -0
  373. package/pg-core/table.cjs.map +1 -1
  374. package/pg-core/table.js +2 -0
  375. package/pg-core/table.js.map +1 -1
  376. package/table.cjs.map +1 -1
  377. package/table.js.map +1 -1
  378. package/version.cjs +1 -1
  379. package/version.d.cts +1 -1
  380. package/version.d.ts +1 -1
  381. package/version.js +1 -1
@@ -0,0 +1,721 @@
1
+ import { entityKind } from "../../entity.cjs";
2
+ import type { GelColumn } from "../columns/index.cjs";
3
+ import type { GelDialect } from "../dialect.cjs";
4
+ import type { GelSession } from "../session.cjs";
5
+ import type { SubqueryWithSelection } from "../subquery.cjs";
6
+ import type { GelTable } from "../table.cjs";
7
+ import { GelViewBase } from "../view-base.cjs";
8
+ import { TypedQueryBuilder } from "../../query-builders/query-builder.cjs";
9
+ import type { BuildSubquerySelection, GetSelectTableName, GetSelectTableSelection, JoinNullability, SelectMode, SelectResult } from "../../query-builders/select.types.cjs";
10
+ import { QueryPromise } from "../../query-promise.cjs";
11
+ import type { RunnableQuery } from "../../runnable-query.cjs";
12
+ import { SQL } from "../../sql/sql.cjs";
13
+ import type { ColumnsSelection, Placeholder, Query, SQLWrapper } from "../../sql/sql.cjs";
14
+ import { Subquery } from "../../subquery.cjs";
15
+ import { type ValueOrArray } from "../../utils.cjs";
16
+ import type { CreateGelSelectFromBuilderMode, GelCreateSetOperatorFn, GelSelectConfig, GelSelectDynamic, GelSelectHKT, GelSelectHKTBase, GelSelectJoinFn, GelSelectPrepare, GelSelectWithout, GelSetOperatorExcludedMethods, GelSetOperatorWithResult, GetGelSetOperators, LockConfig, LockStrength, SelectedFields, SetOperatorRightSelect } from "./select.types.cjs";
17
+ export declare class GelSelectBuilder<TSelection extends SelectedFields | undefined, TBuilderMode extends 'db' | 'qb' = 'db'> {
18
+ static readonly [entityKind]: string;
19
+ private fields;
20
+ private session;
21
+ private dialect;
22
+ private withList;
23
+ private distinct;
24
+ constructor(config: {
25
+ fields: TSelection;
26
+ session: GelSession | undefined;
27
+ dialect: GelDialect;
28
+ withList?: Subquery[];
29
+ distinct?: boolean | {
30
+ on: (GelColumn | SQLWrapper)[];
31
+ };
32
+ });
33
+ private authToken?;
34
+ /**
35
+ * Specify the table, subquery, or other target that you're
36
+ * building a select query against.
37
+ *
38
+ * {@link https://www.postgresql.org/docs/current/sql-select.html#SQL-FROM | Postgres from documentation}
39
+ */
40
+ from<TFrom extends GelTable | Subquery | GelViewBase | SQL>(source: TFrom): CreateGelSelectFromBuilderMode<TBuilderMode, GetSelectTableName<TFrom>, TSelection extends undefined ? GetSelectTableSelection<TFrom> : TSelection, TSelection extends undefined ? 'single' : 'partial'>;
41
+ }
42
+ export declare abstract class GelSelectQueryBuilderBase<THKT extends GelSelectHKTBase, TTableName extends string | undefined, TSelection extends ColumnsSelection, TSelectMode extends SelectMode, TNullabilityMap extends Record<string, JoinNullability> = TTableName extends string ? Record<TTableName, 'not-null'> : {}, TDynamic extends boolean = false, TExcludedMethods extends string = never, TResult extends any[] = SelectResult<TSelection, TSelectMode, TNullabilityMap>[], TSelectedFields extends ColumnsSelection = BuildSubquerySelection<TSelection, TNullabilityMap>> extends TypedQueryBuilder<TSelectedFields, TResult> {
43
+ static readonly [entityKind]: string;
44
+ readonly _: {
45
+ readonly dialect: 'gel';
46
+ readonly hkt: THKT;
47
+ readonly tableName: TTableName;
48
+ readonly selection: TSelection;
49
+ readonly selectMode: TSelectMode;
50
+ readonly nullabilityMap: TNullabilityMap;
51
+ readonly dynamic: TDynamic;
52
+ readonly excludedMethods: TExcludedMethods;
53
+ readonly result: TResult;
54
+ readonly selectedFields: TSelectedFields;
55
+ };
56
+ protected config: GelSelectConfig;
57
+ protected joinsNotNullableMap: Record<string, boolean>;
58
+ private tableName;
59
+ private isPartialSelect;
60
+ protected session: GelSession | undefined;
61
+ protected dialect: GelDialect;
62
+ constructor({ table, fields, isPartialSelect, session, dialect, withList, distinct }: {
63
+ table: GelSelectConfig['table'];
64
+ fields: GelSelectConfig['fields'];
65
+ isPartialSelect: boolean;
66
+ session: GelSession | undefined;
67
+ dialect: GelDialect;
68
+ withList: Subquery[];
69
+ distinct: boolean | {
70
+ on: (GelColumn | SQLWrapper)[];
71
+ } | undefined;
72
+ });
73
+ private createJoin;
74
+ /**
75
+ * Executes a `left join` operation by adding another table to the current query.
76
+ *
77
+ * Calling this method associates each row of the table with the corresponding row from the joined table, if a match is found. If no matching row exists, it sets all columns of the joined table to null.
78
+ *
79
+ * See docs: {@link https://orm.drizzle.team/docs/joins#left-join}
80
+ *
81
+ * @param table the table to join.
82
+ * @param on the `on` clause.
83
+ *
84
+ * @example
85
+ *
86
+ * ```ts
87
+ * // Select all users and their pets
88
+ * const usersWithPets: { user: User; pets: Pet | null }[] = await db.select()
89
+ * .from(users)
90
+ * .leftJoin(pets, eq(users.id, pets.ownerId))
91
+ *
92
+ * // Select userId and petId
93
+ * const usersIdsAndPetIds: { userId: number; petId: number | null }[] = await db.select({
94
+ * userId: users.id,
95
+ * petId: pets.id,
96
+ * })
97
+ * .from(users)
98
+ * .leftJoin(pets, eq(users.id, pets.ownerId))
99
+ * ```
100
+ */
101
+ leftJoin: GelSelectJoinFn<this, TDynamic, "left">;
102
+ /**
103
+ * Executes a `right join` operation by adding another table to the current query.
104
+ *
105
+ * Calling this method associates each row of the joined table with the corresponding row from the main table, if a match is found. If no matching row exists, it sets all columns of the main table to null.
106
+ *
107
+ * See docs: {@link https://orm.drizzle.team/docs/joins#right-join}
108
+ *
109
+ * @param table the table to join.
110
+ * @param on the `on` clause.
111
+ *
112
+ * @example
113
+ *
114
+ * ```ts
115
+ * // Select all users and their pets
116
+ * const usersWithPets: { user: User | null; pets: Pet }[] = await db.select()
117
+ * .from(users)
118
+ * .rightJoin(pets, eq(users.id, pets.ownerId))
119
+ *
120
+ * // Select userId and petId
121
+ * const usersIdsAndPetIds: { userId: number | null; petId: number }[] = await db.select({
122
+ * userId: users.id,
123
+ * petId: pets.id,
124
+ * })
125
+ * .from(users)
126
+ * .rightJoin(pets, eq(users.id, pets.ownerId))
127
+ * ```
128
+ */
129
+ rightJoin: GelSelectJoinFn<this, TDynamic, "right">;
130
+ /**
131
+ * Executes an `inner join` operation, creating a new table by combining rows from two tables that have matching values.
132
+ *
133
+ * Calling this method retrieves rows that have corresponding entries in both joined tables. Rows without matching entries in either table are excluded, resulting in a table that includes only matching pairs.
134
+ *
135
+ * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join}
136
+ *
137
+ * @param table the table to join.
138
+ * @param on the `on` clause.
139
+ *
140
+ * @example
141
+ *
142
+ * ```ts
143
+ * // Select all users and their pets
144
+ * const usersWithPets: { user: User; pets: Pet }[] = await db.select()
145
+ * .from(users)
146
+ * .innerJoin(pets, eq(users.id, pets.ownerId))
147
+ *
148
+ * // Select userId and petId
149
+ * const usersIdsAndPetIds: { userId: number; petId: number }[] = await db.select({
150
+ * userId: users.id,
151
+ * petId: pets.id,
152
+ * })
153
+ * .from(users)
154
+ * .innerJoin(pets, eq(users.id, pets.ownerId))
155
+ * ```
156
+ */
157
+ innerJoin: GelSelectJoinFn<this, TDynamic, "inner">;
158
+ /**
159
+ * Executes a `full join` operation by combining rows from two tables into a new table.
160
+ *
161
+ * Calling this method retrieves all rows from both main and joined tables, merging rows with matching values and filling in `null` for non-matching columns.
162
+ *
163
+ * See docs: {@link https://orm.drizzle.team/docs/joins#full-join}
164
+ *
165
+ * @param table the table to join.
166
+ * @param on the `on` clause.
167
+ *
168
+ * @example
169
+ *
170
+ * ```ts
171
+ * // Select all users and their pets
172
+ * const usersWithPets: { user: User | null; pets: Pet | null }[] = await db.select()
173
+ * .from(users)
174
+ * .fullJoin(pets, eq(users.id, pets.ownerId))
175
+ *
176
+ * // Select userId and petId
177
+ * const usersIdsAndPetIds: { userId: number | null; petId: number | null }[] = await db.select({
178
+ * userId: users.id,
179
+ * petId: pets.id,
180
+ * })
181
+ * .from(users)
182
+ * .fullJoin(pets, eq(users.id, pets.ownerId))
183
+ * ```
184
+ */
185
+ fullJoin: GelSelectJoinFn<this, TDynamic, "full">;
186
+ private createSetOperator;
187
+ /**
188
+ * Adds `union` set operator to the query.
189
+ *
190
+ * Calling this method will combine the result sets of the `select` statements and remove any duplicate rows that appear across them.
191
+ *
192
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#union}
193
+ *
194
+ * @example
195
+ *
196
+ * ```ts
197
+ * // Select all unique names from customers and users tables
198
+ * await db.select({ name: users.name })
199
+ * .from(users)
200
+ * .union(
201
+ * db.select({ name: customers.name }).from(customers)
202
+ * );
203
+ * // or
204
+ * import { union } from 'drizzle-orm/gel-core'
205
+ *
206
+ * await union(
207
+ * db.select({ name: users.name }).from(users),
208
+ * db.select({ name: customers.name }).from(customers)
209
+ * );
210
+ * ```
211
+ */
212
+ union: <TValue extends GelSetOperatorWithResult<TResult>>(rightSelection: ((setOperators: GetGelSetOperators) => SetOperatorRightSelect<TValue, TResult>) | SetOperatorRightSelect<TValue, TResult>) => GelSelectWithout<this, TDynamic, GelSetOperatorExcludedMethods, true>;
213
+ /**
214
+ * Adds `union all` set operator to the query.
215
+ *
216
+ * Calling this method will combine the result-set of the `select` statements and keep all duplicate rows that appear across them.
217
+ *
218
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#union-all}
219
+ *
220
+ * @example
221
+ *
222
+ * ```ts
223
+ * // Select all transaction ids from both online and in-store sales
224
+ * await db.select({ transaction: onlineSales.transactionId })
225
+ * .from(onlineSales)
226
+ * .unionAll(
227
+ * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)
228
+ * );
229
+ * // or
230
+ * import { unionAll } from 'drizzle-orm/gel-core'
231
+ *
232
+ * await unionAll(
233
+ * db.select({ transaction: onlineSales.transactionId }).from(onlineSales),
234
+ * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)
235
+ * );
236
+ * ```
237
+ */
238
+ unionAll: <TValue extends GelSetOperatorWithResult<TResult>>(rightSelection: ((setOperators: GetGelSetOperators) => SetOperatorRightSelect<TValue, TResult>) | SetOperatorRightSelect<TValue, TResult>) => GelSelectWithout<this, TDynamic, GelSetOperatorExcludedMethods, true>;
239
+ /**
240
+ * Adds `intersect` set operator to the query.
241
+ *
242
+ * Calling this method will retain only the rows that are present in both result sets and eliminate duplicates.
243
+ *
244
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect}
245
+ *
246
+ * @example
247
+ *
248
+ * ```ts
249
+ * // Select course names that are offered in both departments A and B
250
+ * await db.select({ courseName: depA.courseName })
251
+ * .from(depA)
252
+ * .intersect(
253
+ * db.select({ courseName: depB.courseName }).from(depB)
254
+ * );
255
+ * // or
256
+ * import { intersect } from 'drizzle-orm/gel-core'
257
+ *
258
+ * await intersect(
259
+ * db.select({ courseName: depA.courseName }).from(depA),
260
+ * db.select({ courseName: depB.courseName }).from(depB)
261
+ * );
262
+ * ```
263
+ */
264
+ intersect: <TValue extends GelSetOperatorWithResult<TResult>>(rightSelection: ((setOperators: GetGelSetOperators) => SetOperatorRightSelect<TValue, TResult>) | SetOperatorRightSelect<TValue, TResult>) => GelSelectWithout<this, TDynamic, GelSetOperatorExcludedMethods, true>;
265
+ /**
266
+ * Adds `intersect all` set operator to the query.
267
+ *
268
+ * Calling this method will retain only the rows that are present in both result sets including all duplicates.
269
+ *
270
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect-all}
271
+ *
272
+ * @example
273
+ *
274
+ * ```ts
275
+ * // Select all products and quantities that are ordered by both regular and VIP customers
276
+ * await db.select({
277
+ * productId: regularCustomerOrders.productId,
278
+ * quantityOrdered: regularCustomerOrders.quantityOrdered
279
+ * })
280
+ * .from(regularCustomerOrders)
281
+ * .intersectAll(
282
+ * db.select({
283
+ * productId: vipCustomerOrders.productId,
284
+ * quantityOrdered: vipCustomerOrders.quantityOrdered
285
+ * })
286
+ * .from(vipCustomerOrders)
287
+ * );
288
+ * // or
289
+ * import { intersectAll } from 'drizzle-orm/gel-core'
290
+ *
291
+ * await intersectAll(
292
+ * db.select({
293
+ * productId: regularCustomerOrders.productId,
294
+ * quantityOrdered: regularCustomerOrders.quantityOrdered
295
+ * })
296
+ * .from(regularCustomerOrders),
297
+ * db.select({
298
+ * productId: vipCustomerOrders.productId,
299
+ * quantityOrdered: vipCustomerOrders.quantityOrdered
300
+ * })
301
+ * .from(vipCustomerOrders)
302
+ * );
303
+ * ```
304
+ */
305
+ intersectAll: <TValue extends GelSetOperatorWithResult<TResult>>(rightSelection: ((setOperators: GetGelSetOperators) => SetOperatorRightSelect<TValue, TResult>) | SetOperatorRightSelect<TValue, TResult>) => GelSelectWithout<this, TDynamic, GelSetOperatorExcludedMethods, true>;
306
+ /**
307
+ * Adds `except` set operator to the query.
308
+ *
309
+ * Calling this method will retrieve all unique rows from the left query, except for the rows that are present in the result set of the right query.
310
+ *
311
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#except}
312
+ *
313
+ * @example
314
+ *
315
+ * ```ts
316
+ * // Select all courses offered in department A but not in department B
317
+ * await db.select({ courseName: depA.courseName })
318
+ * .from(depA)
319
+ * .except(
320
+ * db.select({ courseName: depB.courseName }).from(depB)
321
+ * );
322
+ * // or
323
+ * import { except } from 'drizzle-orm/gel-core'
324
+ *
325
+ * await except(
326
+ * db.select({ courseName: depA.courseName }).from(depA),
327
+ * db.select({ courseName: depB.courseName }).from(depB)
328
+ * );
329
+ * ```
330
+ */
331
+ except: <TValue extends GelSetOperatorWithResult<TResult>>(rightSelection: ((setOperators: GetGelSetOperators) => SetOperatorRightSelect<TValue, TResult>) | SetOperatorRightSelect<TValue, TResult>) => GelSelectWithout<this, TDynamic, GelSetOperatorExcludedMethods, true>;
332
+ /**
333
+ * Adds `except all` set operator to the query.
334
+ *
335
+ * Calling this method will retrieve all rows from the left query, except for the rows that are present in the result set of the right query.
336
+ *
337
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#except-all}
338
+ *
339
+ * @example
340
+ *
341
+ * ```ts
342
+ * // Select all products that are ordered by regular customers but not by VIP customers
343
+ * await db.select({
344
+ * productId: regularCustomerOrders.productId,
345
+ * quantityOrdered: regularCustomerOrders.quantityOrdered,
346
+ * })
347
+ * .from(regularCustomerOrders)
348
+ * .exceptAll(
349
+ * db.select({
350
+ * productId: vipCustomerOrders.productId,
351
+ * quantityOrdered: vipCustomerOrders.quantityOrdered,
352
+ * })
353
+ * .from(vipCustomerOrders)
354
+ * );
355
+ * // or
356
+ * import { exceptAll } from 'drizzle-orm/gel-core'
357
+ *
358
+ * await exceptAll(
359
+ * db.select({
360
+ * productId: regularCustomerOrders.productId,
361
+ * quantityOrdered: regularCustomerOrders.quantityOrdered
362
+ * })
363
+ * .from(regularCustomerOrders),
364
+ * db.select({
365
+ * productId: vipCustomerOrders.productId,
366
+ * quantityOrdered: vipCustomerOrders.quantityOrdered
367
+ * })
368
+ * .from(vipCustomerOrders)
369
+ * );
370
+ * ```
371
+ */
372
+ exceptAll: <TValue extends GelSetOperatorWithResult<TResult>>(rightSelection: ((setOperators: GetGelSetOperators) => SetOperatorRightSelect<TValue, TResult>) | SetOperatorRightSelect<TValue, TResult>) => GelSelectWithout<this, TDynamic, GelSetOperatorExcludedMethods, true>;
373
+ /**
374
+ * Adds a `where` clause to the query.
375
+ *
376
+ * Calling this method will select only those rows that fulfill a specified condition.
377
+ *
378
+ * See docs: {@link https://orm.drizzle.team/docs/select#filtering}
379
+ *
380
+ * @param where the `where` clause.
381
+ *
382
+ * @example
383
+ * You can use conditional operators and `sql function` to filter the rows to be selected.
384
+ *
385
+ * ```ts
386
+ * // Select all cars with green color
387
+ * await db.select().from(cars).where(eq(cars.color, 'green'));
388
+ * // or
389
+ * await db.select().from(cars).where(sql`${cars.color} = 'green'`)
390
+ * ```
391
+ *
392
+ * You can logically combine conditional operators with `and()` and `or()` operators:
393
+ *
394
+ * ```ts
395
+ * // Select all BMW cars with a green color
396
+ * await db.select().from(cars).where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));
397
+ *
398
+ * // Select all cars with the green or blue color
399
+ * await db.select().from(cars).where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));
400
+ * ```
401
+ */
402
+ where(where: ((aliases: this['_']['selection']) => SQL | undefined) | SQL | undefined): GelSelectWithout<this, TDynamic, 'where'>;
403
+ /**
404
+ * Adds a `having` clause to the query.
405
+ *
406
+ * Calling this method will select only those rows that fulfill a specified condition. It is typically used with aggregate functions to filter the aggregated data based on a specified condition.
407
+ *
408
+ * See docs: {@link https://orm.drizzle.team/docs/select#aggregations}
409
+ *
410
+ * @param having the `having` clause.
411
+ *
412
+ * @example
413
+ *
414
+ * ```ts
415
+ * // Select all brands with more than one car
416
+ * await db.select({
417
+ * brand: cars.brand,
418
+ * count: sql<number>`cast(count(${cars.id}) as int)`,
419
+ * })
420
+ * .from(cars)
421
+ * .groupBy(cars.brand)
422
+ * .having(({ count }) => gt(count, 1));
423
+ * ```
424
+ */
425
+ having(having: ((aliases: this['_']['selection']) => SQL | undefined) | SQL | undefined): GelSelectWithout<this, TDynamic, 'having'>;
426
+ /**
427
+ * Adds a `group by` clause to the query.
428
+ *
429
+ * Calling this method will group rows that have the same values into summary rows, often used for aggregation purposes.
430
+ *
431
+ * See docs: {@link https://orm.drizzle.team/docs/select#aggregations}
432
+ *
433
+ * @example
434
+ *
435
+ * ```ts
436
+ * // Group and count people by their last names
437
+ * await db.select({
438
+ * lastName: people.lastName,
439
+ * count: sql<number>`cast(count(*) as int)`
440
+ * })
441
+ * .from(people)
442
+ * .groupBy(people.lastName);
443
+ * ```
444
+ */
445
+ groupBy(builder: (aliases: this['_']['selection']) => ValueOrArray<GelColumn | SQL | SQL.Aliased>): GelSelectWithout<this, TDynamic, 'groupBy'>;
446
+ groupBy(...columns: (GelColumn | SQL | SQL.Aliased)[]): GelSelectWithout<this, TDynamic, 'groupBy'>;
447
+ /**
448
+ * Adds an `order by` clause to the query.
449
+ *
450
+ * Calling this method will sort the result-set in ascending or descending order. By default, the sort order is ascending.
451
+ *
452
+ * See docs: {@link https://orm.drizzle.team/docs/select#order-by}
453
+ *
454
+ * @example
455
+ *
456
+ * ```
457
+ * // Select cars ordered by year
458
+ * await db.select().from(cars).orderBy(cars.year);
459
+ * ```
460
+ *
461
+ * You can specify whether results are in ascending or descending order with the `asc()` and `desc()` operators.
462
+ *
463
+ * ```ts
464
+ * // Select cars ordered by year in descending order
465
+ * await db.select().from(cars).orderBy(desc(cars.year));
466
+ *
467
+ * // Select cars ordered by year and price
468
+ * await db.select().from(cars).orderBy(asc(cars.year), desc(cars.price));
469
+ * ```
470
+ */
471
+ orderBy(builder: (aliases: this['_']['selection']) => ValueOrArray<GelColumn | SQL | SQL.Aliased>): GelSelectWithout<this, TDynamic, 'orderBy'>;
472
+ orderBy(...columns: (GelColumn | SQL | SQL.Aliased)[]): GelSelectWithout<this, TDynamic, 'orderBy'>;
473
+ /**
474
+ * Adds a `limit` clause to the query.
475
+ *
476
+ * Calling this method will set the maximum number of rows that will be returned by this query.
477
+ *
478
+ * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}
479
+ *
480
+ * @param limit the `limit` clause.
481
+ *
482
+ * @example
483
+ *
484
+ * ```ts
485
+ * // Get the first 10 people from this query.
486
+ * await db.select().from(people).limit(10);
487
+ * ```
488
+ */
489
+ limit(limit: number | Placeholder): GelSelectWithout<this, TDynamic, 'limit'>;
490
+ /**
491
+ * Adds an `offset` clause to the query.
492
+ *
493
+ * Calling this method will skip a number of rows when returning results from this query.
494
+ *
495
+ * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}
496
+ *
497
+ * @param offset the `offset` clause.
498
+ *
499
+ * @example
500
+ *
501
+ * ```ts
502
+ * // Get the 10th-20th people from this query.
503
+ * await db.select().from(people).offset(10).limit(10);
504
+ * ```
505
+ */
506
+ offset(offset: number | Placeholder): GelSelectWithout<this, TDynamic, 'offset'>;
507
+ /**
508
+ * Adds a `for` clause to the query.
509
+ *
510
+ * Calling this method will specify a lock strength for this query that controls how strictly it acquires exclusive access to the rows being queried.
511
+ *
512
+ * See docs: {@link https://www.postgresql.org/docs/current/sql-select.html#SQL-FOR-UPDATE-SHARE}
513
+ *
514
+ * @param strength the lock strength.
515
+ * @param config the lock configuration.
516
+ */
517
+ for(strength: LockStrength, config?: LockConfig): GelSelectWithout<this, TDynamic, 'for'>;
518
+ toSQL(): Query;
519
+ as<TAlias extends string>(alias: TAlias): SubqueryWithSelection<this['_']['selectedFields'], TAlias>;
520
+ $dynamic(): GelSelectDynamic<this>;
521
+ }
522
+ export interface GelSelectBase<TTableName extends string | undefined, TSelection extends ColumnsSelection, TSelectMode extends SelectMode, TNullabilityMap extends Record<string, JoinNullability> = TTableName extends string ? Record<TTableName, 'not-null'> : {}, TDynamic extends boolean = false, TExcludedMethods extends string = never, TResult extends any[] = SelectResult<TSelection, TSelectMode, TNullabilityMap>[], TSelectedFields extends ColumnsSelection = BuildSubquerySelection<TSelection, TNullabilityMap>> extends GelSelectQueryBuilderBase<GelSelectHKT, TTableName, TSelection, TSelectMode, TNullabilityMap, TDynamic, TExcludedMethods, TResult, TSelectedFields>, QueryPromise<TResult>, SQLWrapper {
523
+ }
524
+ export declare class GelSelectBase<TTableName extends string | undefined, TSelection extends ColumnsSelection, TSelectMode extends SelectMode, TNullabilityMap extends Record<string, JoinNullability> = TTableName extends string ? Record<TTableName, 'not-null'> : {}, TDynamic extends boolean = false, TExcludedMethods extends string = never, TResult = SelectResult<TSelection, TSelectMode, TNullabilityMap>[], TSelectedFields = BuildSubquerySelection<TSelection, TNullabilityMap>> extends GelSelectQueryBuilderBase<GelSelectHKT, TTableName, TSelection, TSelectMode, TNullabilityMap, TDynamic, TExcludedMethods, TResult, TSelectedFields> implements RunnableQuery<TResult, 'gel'>, SQLWrapper {
525
+ static readonly [entityKind]: string;
526
+ /**
527
+ * Create a prepared statement for this query. This allows
528
+ * the database to remember this query for the given session
529
+ * and call it by name, rather than specifying the full query.
530
+ *
531
+ * {@link https://www.postgresql.org/docs/current/sql-prepare.html | Postgres prepare documentation}
532
+ */
533
+ prepare(name: string): GelSelectPrepare<this>;
534
+ execute: ReturnType<this['prepare']>['execute'];
535
+ }
536
+ /**
537
+ * Adds `union` set operator to the query.
538
+ *
539
+ * Calling this method will combine the result sets of the `select` statements and remove any duplicate rows that appear across them.
540
+ *
541
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#union}
542
+ *
543
+ * @example
544
+ *
545
+ * ```ts
546
+ * // Select all unique names from customers and users tables
547
+ * import { union } from 'drizzle-orm/Gel-core'
548
+ *
549
+ * await union(
550
+ * db.select({ name: users.name }).from(users),
551
+ * db.select({ name: customers.name }).from(customers)
552
+ * );
553
+ * // or
554
+ * await db.select({ name: users.name })
555
+ * .from(users)
556
+ * .union(
557
+ * db.select({ name: customers.name }).from(customers)
558
+ * );
559
+ * ```
560
+ */
561
+ export declare const union: GelCreateSetOperatorFn;
562
+ /**
563
+ * Adds `union all` set operator to the query.
564
+ *
565
+ * Calling this method will combine the result-set of the `select` statements and keep all duplicate rows that appear across them.
566
+ *
567
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#union-all}
568
+ *
569
+ * @example
570
+ *
571
+ * ```ts
572
+ * // Select all transaction ids from both online and in-store sales
573
+ * import { unionAll } from 'drizzle-orm/Gel-core'
574
+ *
575
+ * await unionAll(
576
+ * db.select({ transaction: onlineSales.transactionId }).from(onlineSales),
577
+ * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)
578
+ * );
579
+ * // or
580
+ * await db.select({ transaction: onlineSales.transactionId })
581
+ * .from(onlineSales)
582
+ * .unionAll(
583
+ * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)
584
+ * );
585
+ * ```
586
+ */
587
+ export declare const unionAll: GelCreateSetOperatorFn;
588
+ /**
589
+ * Adds `intersect` set operator to the query.
590
+ *
591
+ * Calling this method will retain only the rows that are present in both result sets and eliminate duplicates.
592
+ *
593
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect}
594
+ *
595
+ * @example
596
+ *
597
+ * ```ts
598
+ * // Select course names that are offered in both departments A and B
599
+ * import { intersect } from 'drizzle-orm/Gel-core'
600
+ *
601
+ * await intersect(
602
+ * db.select({ courseName: depA.courseName }).from(depA),
603
+ * db.select({ courseName: depB.courseName }).from(depB)
604
+ * );
605
+ * // or
606
+ * await db.select({ courseName: depA.courseName })
607
+ * .from(depA)
608
+ * .intersect(
609
+ * db.select({ courseName: depB.courseName }).from(depB)
610
+ * );
611
+ * ```
612
+ */
613
+ export declare const intersect: GelCreateSetOperatorFn;
614
+ /**
615
+ * Adds `intersect all` set operator to the query.
616
+ *
617
+ * Calling this method will retain only the rows that are present in both result sets including all duplicates.
618
+ *
619
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect-all}
620
+ *
621
+ * @example
622
+ *
623
+ * ```ts
624
+ * // Select all products and quantities that are ordered by both regular and VIP customers
625
+ * import { intersectAll } from 'drizzle-orm/Gel-core'
626
+ *
627
+ * await intersectAll(
628
+ * db.select({
629
+ * productId: regularCustomerOrders.productId,
630
+ * quantityOrdered: regularCustomerOrders.quantityOrdered
631
+ * })
632
+ * .from(regularCustomerOrders),
633
+ * db.select({
634
+ * productId: vipCustomerOrders.productId,
635
+ * quantityOrdered: vipCustomerOrders.quantityOrdered
636
+ * })
637
+ * .from(vipCustomerOrders)
638
+ * );
639
+ * // or
640
+ * await db.select({
641
+ * productId: regularCustomerOrders.productId,
642
+ * quantityOrdered: regularCustomerOrders.quantityOrdered
643
+ * })
644
+ * .from(regularCustomerOrders)
645
+ * .intersectAll(
646
+ * db.select({
647
+ * productId: vipCustomerOrders.productId,
648
+ * quantityOrdered: vipCustomerOrders.quantityOrdered
649
+ * })
650
+ * .from(vipCustomerOrders)
651
+ * );
652
+ * ```
653
+ */
654
+ export declare const intersectAll: GelCreateSetOperatorFn;
655
+ /**
656
+ * Adds `except` set operator to the query.
657
+ *
658
+ * Calling this method will retrieve all unique rows from the left query, except for the rows that are present in the result set of the right query.
659
+ *
660
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#except}
661
+ *
662
+ * @example
663
+ *
664
+ * ```ts
665
+ * // Select all courses offered in department A but not in department B
666
+ * import { except } from 'drizzle-orm/Gel-core'
667
+ *
668
+ * await except(
669
+ * db.select({ courseName: depA.courseName }).from(depA),
670
+ * db.select({ courseName: depB.courseName }).from(depB)
671
+ * );
672
+ * // or
673
+ * await db.select({ courseName: depA.courseName })
674
+ * .from(depA)
675
+ * .except(
676
+ * db.select({ courseName: depB.courseName }).from(depB)
677
+ * );
678
+ * ```
679
+ */
680
+ export declare const except: GelCreateSetOperatorFn;
681
+ /**
682
+ * Adds `except all` set operator to the query.
683
+ *
684
+ * Calling this method will retrieve all rows from the left query, except for the rows that are present in the result set of the right query.
685
+ *
686
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#except-all}
687
+ *
688
+ * @example
689
+ *
690
+ * ```ts
691
+ * // Select all products that are ordered by regular customers but not by VIP customers
692
+ * import { exceptAll } from 'drizzle-orm/Gel-core'
693
+ *
694
+ * await exceptAll(
695
+ * db.select({
696
+ * productId: regularCustomerOrders.productId,
697
+ * quantityOrdered: regularCustomerOrders.quantityOrdered
698
+ * })
699
+ * .from(regularCustomerOrders),
700
+ * db.select({
701
+ * productId: vipCustomerOrders.productId,
702
+ * quantityOrdered: vipCustomerOrders.quantityOrdered
703
+ * })
704
+ * .from(vipCustomerOrders)
705
+ * );
706
+ * // or
707
+ * await db.select({
708
+ * productId: regularCustomerOrders.productId,
709
+ * quantityOrdered: regularCustomerOrders.quantityOrdered,
710
+ * })
711
+ * .from(regularCustomerOrders)
712
+ * .exceptAll(
713
+ * db.select({
714
+ * productId: vipCustomerOrders.productId,
715
+ * quantityOrdered: vipCustomerOrders.quantityOrdered,
716
+ * })
717
+ * .from(vipCustomerOrders)
718
+ * );
719
+ * ```
720
+ */
721
+ export declare const exceptAll: GelCreateSetOperatorFn;