pipework 0.7.13 → 0.7.17

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 (726) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/README.md +3 -2
  3. package/REFERENCE.md +327 -296
  4. package/dist/REFERENCE.md +396 -431
  5. package/dist/auth/tenant/scope.d.ts +1 -1
  6. package/dist/auth/tenant/scope.d.ts.map +1 -1
  7. package/dist/cli/commands/check.d.ts +2 -1
  8. package/dist/cli/commands/check.d.ts.map +1 -1
  9. package/dist/cli/commands/check.js +52 -17
  10. package/dist/cli/commands/check.js.map +1 -1
  11. package/dist/cli/commands/migrate.d.ts.map +1 -1
  12. package/dist/cli/commands/migrate.js +3 -6
  13. package/dist/cli/commands/migrate.js.map +1 -1
  14. package/dist/cli/commands/scope.d.ts +12 -0
  15. package/dist/cli/commands/scope.d.ts.map +1 -0
  16. package/dist/cli/commands/scope.js +25 -0
  17. package/dist/cli/commands/scope.js.map +1 -0
  18. package/dist/cli/commands/test.d.ts +3 -0
  19. package/dist/cli/commands/test.d.ts.map +1 -1
  20. package/dist/cli/commands/test.js +65 -1
  21. package/dist/cli/commands/test.js.map +1 -1
  22. package/dist/cli/index.d.ts.map +1 -1
  23. package/dist/cli/index.js +21 -2
  24. package/dist/cli/index.js.map +1 -1
  25. package/dist/config/discover.d.ts.map +1 -1
  26. package/dist/config/discover.js +0 -14
  27. package/dist/config/discover.js.map +1 -1
  28. package/dist/core/config/namespace.d.ts +122 -120
  29. package/dist/core/config/namespace.d.ts.map +1 -1
  30. package/dist/core/config/schema.d.ts +7 -0
  31. package/dist/core/config/schema.d.ts.map +1 -1
  32. package/dist/core/config/schema.js +1 -0
  33. package/dist/core/config/schema.js.map +1 -1
  34. package/dist/data/db/col/index.d.ts +1 -1
  35. package/dist/data/db/col/index.d.ts.map +1 -1
  36. package/dist/data/db/col/index.js +1 -1
  37. package/dist/data/db/col/index.js.map +1 -1
  38. package/dist/data/db/excluded.js +2 -2
  39. package/dist/data/db/excluded.js.map +1 -1
  40. package/dist/data/db/filter.d.ts +12 -12
  41. package/dist/data/db/generated/drizzle-orm/aggregate.d.ts +1 -1
  42. package/dist/data/db/generated/drizzle-orm/aggregate.d.ts.map +1 -1
  43. package/dist/data/db/generated/drizzle-orm/aggregate.js +1 -1
  44. package/dist/data/db/generated/drizzle-orm/aggregate.js.map +1 -1
  45. package/dist/data/db/generated/drizzle-orm/introspection.d.ts +1 -1
  46. package/dist/data/db/generated/drizzle-orm/introspection.d.ts.map +1 -1
  47. package/dist/data/db/generated/drizzle-orm/introspection.js +1 -1
  48. package/dist/data/db/generated/drizzle-orm/introspection.js.map +1 -1
  49. package/dist/data/db/generated/drizzle-orm/operator.d.ts +1 -1
  50. package/dist/data/db/generated/drizzle-orm/operator.d.ts.map +1 -1
  51. package/dist/data/db/generated/drizzle-orm/operator.js +1 -1
  52. package/dist/data/db/generated/drizzle-orm/operator.js.map +1 -1
  53. package/dist/data/db/generated/drizzle-orm/relation.d.ts +1 -1
  54. package/dist/data/db/generated/drizzle-orm/relation.d.ts.map +1 -1
  55. package/dist/data/db/generated/drizzle-orm/relation.js +1 -1
  56. package/dist/data/db/generated/drizzle-orm/relation.js.map +1 -1
  57. package/dist/data/db/generated/drizzle-orm/type.d.ts +2 -2
  58. package/dist/data/db/generated/drizzle-orm/type.d.ts.map +1 -1
  59. package/dist/data/db/generated/drizzle-orm/type.js +1 -1
  60. package/dist/data/db/generated/drizzle-orm/type.js.map +1 -1
  61. package/dist/data/db/generated/pg-core/introspection.d.ts +1 -1
  62. package/dist/data/db/generated/pg-core/introspection.d.ts.map +1 -1
  63. package/dist/data/db/generated/pg-core/introspection.js +1 -1
  64. package/dist/data/db/generated/pg-core/introspection.js.map +1 -1
  65. package/dist/data/db/generated/pg-core/set-operation.d.ts +1 -1
  66. package/dist/data/db/generated/pg-core/set-operation.d.ts.map +1 -1
  67. package/dist/data/db/generated/pg-core/set-operation.js +1 -1
  68. package/dist/data/db/generated/pg-core/set-operation.js.map +1 -1
  69. package/dist/data/db/generated/pg-core/type.d.ts +2 -2
  70. package/dist/data/db/generated/pg-core/type.d.ts.map +1 -1
  71. package/dist/data/db/generated/pg-core/type.js +1 -1
  72. package/dist/data/db/generated/pg-core/type.js.map +1 -1
  73. package/dist/data/db/idx/index.d.ts +1 -1
  74. package/dist/data/db/idx/index.d.ts.map +1 -1
  75. package/dist/data/db/idx/index.js +1 -1
  76. package/dist/data/db/idx/index.js.map +1 -1
  77. package/dist/data/db/namespace.d.ts +43 -43
  78. package/dist/data/db/pool.d.ts +1 -1
  79. package/dist/data/db/pool.d.ts.map +1 -1
  80. package/dist/data/db/pool.js +1 -1
  81. package/dist/data/db/pool.js.map +1 -1
  82. package/dist/data/db/schema-features.d.ts +1 -1
  83. package/dist/data/db/schema-features.d.ts.map +1 -1
  84. package/dist/data/db/schema-features.js +1 -1
  85. package/dist/data/db/schema-features.js.map +1 -1
  86. package/dist/data/db/sql.d.ts +1 -1
  87. package/dist/data/db/sql.d.ts.map +1 -1
  88. package/dist/data/db/sql.js +1 -1
  89. package/dist/data/db/sql.js.map +1 -1
  90. package/dist/data/db/types.d.ts +3 -3
  91. package/dist/data/db/types.d.ts.map +1 -1
  92. package/dist/data/domain/project-table.d.ts +2 -2
  93. package/dist/data/domain/project-table.js +2 -2
  94. package/dist/data/domain/project-table.js.map +1 -1
  95. package/dist/data/domain/types.d.ts +1 -1
  96. package/dist/data/domain/types.d.ts.map +1 -1
  97. package/dist/data/migrate/apply.d.ts +8 -0
  98. package/dist/data/migrate/apply.d.ts.map +1 -0
  99. package/dist/data/migrate/apply.js +91 -0
  100. package/dist/data/migrate/apply.js.map +1 -0
  101. package/dist/data/migrate/diff.d.ts +118 -0
  102. package/dist/data/migrate/diff.d.ts.map +1 -0
  103. package/dist/data/migrate/diff.js +215 -0
  104. package/dist/data/migrate/diff.js.map +1 -0
  105. package/dist/data/migrate/generate.d.ts.map +1 -1
  106. package/dist/data/migrate/generate.js +12 -22
  107. package/dist/data/migrate/generate.js.map +1 -1
  108. package/dist/data/migrate/run.d.ts.map +1 -1
  109. package/dist/data/migrate/run.js +5 -16
  110. package/dist/data/migrate/run.js.map +1 -1
  111. package/dist/data/migrate/snapshot.d.ts +87 -0
  112. package/dist/data/migrate/snapshot.d.ts.map +1 -0
  113. package/dist/data/migrate/snapshot.js +204 -0
  114. package/dist/data/migrate/snapshot.js.map +1 -0
  115. package/dist/data/migrate/sql-emit.d.ts +3 -0
  116. package/dist/data/migrate/sql-emit.d.ts.map +1 -0
  117. package/dist/data/migrate/sql-emit.js +220 -0
  118. package/dist/data/migrate/sql-emit.js.map +1 -0
  119. package/dist/data/query/alias.d.ts +32 -0
  120. package/dist/data/query/alias.d.ts.map +1 -0
  121. package/dist/data/query/alias.js +101 -0
  122. package/dist/data/query/alias.js.map +1 -0
  123. package/dist/data/query/batch.d.ts +7 -0
  124. package/dist/data/query/batch.d.ts.map +1 -0
  125. package/dist/data/query/batch.js +2 -0
  126. package/dist/data/query/batch.js.map +1 -0
  127. package/dist/data/query/cache/core/cache.d.ts +37 -0
  128. package/dist/data/query/cache/core/cache.d.ts.map +1 -0
  129. package/dist/data/query/cache/core/cache.js +29 -0
  130. package/dist/data/query/cache/core/cache.js.map +1 -0
  131. package/dist/data/query/cache/core/index.d.ts +2 -0
  132. package/dist/data/query/cache/core/index.d.ts.map +1 -0
  133. package/dist/data/query/cache/core/index.js +2 -0
  134. package/dist/data/query/cache/core/index.js.map +1 -0
  135. package/dist/data/query/cache/core/types.d.ts +34 -0
  136. package/dist/data/query/cache/core/types.d.ts.map +1 -0
  137. package/dist/data/query/cache/core/types.js +2 -0
  138. package/dist/data/query/cache/core/types.js.map +1 -0
  139. package/dist/data/query/casing.d.ts +17 -0
  140. package/dist/data/query/casing.d.ts.map +1 -0
  141. package/dist/data/query/casing.js +62 -0
  142. package/dist/data/query/casing.js.map +1 -0
  143. package/dist/data/query/column-builder.d.ts +241 -0
  144. package/dist/data/query/column-builder.d.ts.map +1 -0
  145. package/dist/data/query/column-builder.js +105 -0
  146. package/dist/data/query/column-builder.js.map +1 -0
  147. package/dist/data/query/column.d.ts +70 -0
  148. package/dist/data/query/column.d.ts.map +1 -0
  149. package/dist/data/query/column.js +57 -0
  150. package/dist/data/query/column.js.map +1 -0
  151. package/dist/data/query/entity.d.ts +8 -0
  152. package/dist/data/query/entity.d.ts.map +1 -0
  153. package/dist/data/query/entity.js +25 -0
  154. package/dist/data/query/entity.js.map +1 -0
  155. package/dist/data/query/errors.d.ts +19 -0
  156. package/dist/data/query/errors.d.ts.map +1 -0
  157. package/dist/data/query/errors.js +31 -0
  158. package/dist/data/query/errors.js.map +1 -0
  159. package/dist/data/query/index.d.ts +15 -0
  160. package/dist/data/query/index.d.ts.map +1 -0
  161. package/dist/data/query/index.js +15 -0
  162. package/dist/data/query/index.js.map +1 -0
  163. package/dist/data/query/logger.d.ts +24 -0
  164. package/dist/data/query/logger.d.ts.map +1 -0
  165. package/dist/data/query/logger.js +33 -0
  166. package/dist/data/query/logger.js.map +1 -0
  167. package/dist/data/query/operations.d.ts +25 -0
  168. package/dist/data/query/operations.d.ts.map +1 -0
  169. package/dist/data/query/operations.js +2 -0
  170. package/dist/data/query/operations.js.map +1 -0
  171. package/dist/data/query/pg-core/alias.d.ts +5 -0
  172. package/dist/data/query/pg-core/alias.d.ts.map +1 -0
  173. package/dist/data/query/pg-core/alias.js +5 -0
  174. package/dist/data/query/pg-core/alias.js.map +1 -0
  175. package/dist/data/query/pg-core/checks.d.ts +21 -0
  176. package/dist/data/query/pg-core/checks.d.ts.map +1 -0
  177. package/dist/data/query/pg-core/checks.js +30 -0
  178. package/dist/data/query/pg-core/checks.js.map +1 -0
  179. package/dist/data/query/pg-core/columns/all.d.ts +68 -0
  180. package/dist/data/query/pg-core/columns/all.d.ts.map +1 -0
  181. package/dist/data/query/pg-core/columns/all.js +69 -0
  182. package/dist/data/query/pg-core/columns/all.js.map +1 -0
  183. package/dist/data/query/pg-core/columns/bigint.d.ts +54 -0
  184. package/dist/data/query/pg-core/columns/bigint.d.ts.map +1 -0
  185. package/dist/data/query/pg-core/columns/bigint.js +54 -0
  186. package/dist/data/query/pg-core/columns/bigint.js.map +1 -0
  187. package/dist/data/query/pg-core/columns/bigserial.d.ts +53 -0
  188. package/dist/data/query/pg-core/columns/bigserial.d.ts.map +1 -0
  189. package/dist/data/query/pg-core/columns/bigserial.js +56 -0
  190. package/dist/data/query/pg-core/columns/bigserial.js.map +1 -0
  191. package/dist/data/query/pg-core/columns/boolean.d.ts +28 -0
  192. package/dist/data/query/pg-core/columns/boolean.d.ts.map +1 -0
  193. package/dist/data/query/pg-core/columns/boolean.js +22 -0
  194. package/dist/data/query/pg-core/columns/boolean.js.map +1 -0
  195. package/dist/data/query/pg-core/columns/char.d.ts +53 -0
  196. package/dist/data/query/pg-core/columns/char.d.ts.map +1 -0
  197. package/dist/data/query/pg-core/columns/char.js +28 -0
  198. package/dist/data/query/pg-core/columns/char.js.map +1 -0
  199. package/dist/data/query/pg-core/columns/cidr.d.ts +28 -0
  200. package/dist/data/query/pg-core/columns/cidr.d.ts.map +1 -0
  201. package/dist/data/query/pg-core/columns/cidr.js +22 -0
  202. package/dist/data/query/pg-core/columns/cidr.js.map +1 -0
  203. package/dist/data/query/pg-core/columns/common.d.ts +167 -0
  204. package/dist/data/query/pg-core/columns/common.d.ts.map +1 -0
  205. package/dist/data/query/pg-core/columns/common.js +190 -0
  206. package/dist/data/query/pg-core/columns/common.js.map +1 -0
  207. package/dist/data/query/pg-core/columns/custom.d.ts +160 -0
  208. package/dist/data/query/pg-core/columns/custom.d.ts.map +1 -0
  209. package/dist/data/query/pg-core/columns/custom.js +46 -0
  210. package/dist/data/query/pg-core/columns/custom.js.map +1 -0
  211. package/dist/data/query/pg-core/columns/date.common.d.ts +8 -0
  212. package/dist/data/query/pg-core/columns/date.common.d.ts.map +1 -0
  213. package/dist/data/query/pg-core/columns/date.common.js +10 -0
  214. package/dist/data/query/pg-core/columns/date.common.js.map +1 -0
  215. package/dist/data/query/pg-core/columns/date.d.ts +57 -0
  216. package/dist/data/query/pg-core/columns/date.d.ts.map +1 -0
  217. package/dist/data/query/pg-core/columns/date.js +57 -0
  218. package/dist/data/query/pg-core/columns/date.js.map +1 -0
  219. package/dist/data/query/pg-core/columns/double-precision.d.ts +29 -0
  220. package/dist/data/query/pg-core/columns/double-precision.d.ts.map +1 -0
  221. package/dist/data/query/pg-core/columns/double-precision.js +28 -0
  222. package/dist/data/query/pg-core/columns/double-precision.js.map +1 -0
  223. package/dist/data/query/pg-core/columns/enum.d.ts +102 -0
  224. package/dist/data/query/pg-core/columns/enum.d.ts.map +1 -0
  225. package/dist/data/query/pg-core/columns/enum.js +78 -0
  226. package/dist/data/query/pg-core/columns/enum.js.map +1 -0
  227. package/dist/data/query/pg-core/columns/index.d.ts +36 -0
  228. package/dist/data/query/pg-core/columns/index.d.ts.map +1 -0
  229. package/dist/data/query/pg-core/columns/index.js +36 -0
  230. package/dist/data/query/pg-core/columns/index.js.map +1 -0
  231. package/dist/data/query/pg-core/columns/inet.d.ts +28 -0
  232. package/dist/data/query/pg-core/columns/inet.d.ts.map +1 -0
  233. package/dist/data/query/pg-core/columns/inet.js +22 -0
  234. package/dist/data/query/pg-core/columns/inet.js.map +1 -0
  235. package/dist/data/query/pg-core/columns/int.common.d.ts +16 -0
  236. package/dist/data/query/pg-core/columns/int.common.d.ts.map +1 -0
  237. package/dist/data/query/pg-core/columns/int.common.js +42 -0
  238. package/dist/data/query/pg-core/columns/int.common.js.map +1 -0
  239. package/dist/data/query/pg-core/columns/integer.d.ts +30 -0
  240. package/dist/data/query/pg-core/columns/integer.d.ts.map +1 -0
  241. package/dist/data/query/pg-core/columns/integer.js +29 -0
  242. package/dist/data/query/pg-core/columns/integer.js.map +1 -0
  243. package/dist/data/query/pg-core/columns/interval.d.ts +40 -0
  244. package/dist/data/query/pg-core/columns/interval.d.ts.map +1 -0
  245. package/dist/data/query/pg-core/columns/interval.js +29 -0
  246. package/dist/data/query/pg-core/columns/interval.js.map +1 -0
  247. package/dist/data/query/pg-core/columns/json.d.ts +33 -0
  248. package/dist/data/query/pg-core/columns/json.d.ts.map +1 -0
  249. package/dist/data/query/pg-core/columns/json.js +39 -0
  250. package/dist/data/query/pg-core/columns/json.js.map +1 -0
  251. package/dist/data/query/pg-core/columns/jsonb.d.ts +33 -0
  252. package/dist/data/query/pg-core/columns/jsonb.d.ts.map +1 -0
  253. package/dist/data/query/pg-core/columns/jsonb.js +39 -0
  254. package/dist/data/query/pg-core/columns/jsonb.js.map +1 -0
  255. package/dist/data/query/pg-core/columns/line.d.ts +69 -0
  256. package/dist/data/query/pg-core/columns/line.d.ts.map +1 -0
  257. package/dist/data/query/pg-core/columns/line.js +57 -0
  258. package/dist/data/query/pg-core/columns/line.js.map +1 -0
  259. package/dist/data/query/pg-core/columns/macaddr.d.ts +28 -0
  260. package/dist/data/query/pg-core/columns/macaddr.d.ts.map +1 -0
  261. package/dist/data/query/pg-core/columns/macaddr.js +22 -0
  262. package/dist/data/query/pg-core/columns/macaddr.js.map +1 -0
  263. package/dist/data/query/pg-core/columns/macaddr8.d.ts +28 -0
  264. package/dist/data/query/pg-core/columns/macaddr8.d.ts.map +1 -0
  265. package/dist/data/query/pg-core/columns/macaddr8.js +22 -0
  266. package/dist/data/query/pg-core/columns/macaddr8.js.map +1 -0
  267. package/dist/data/query/pg-core/columns/numeric.d.ts +112 -0
  268. package/dist/data/query/pg-core/columns/numeric.d.ts.map +1 -0
  269. package/dist/data/query/pg-core/columns/numeric.js +126 -0
  270. package/dist/data/query/pg-core/columns/numeric.js.map +1 -0
  271. package/dist/data/query/pg-core/columns/point.d.ts +72 -0
  272. package/dist/data/query/pg-core/columns/point.d.ts.map +1 -0
  273. package/dist/data/query/pg-core/columns/point.js +63 -0
  274. package/dist/data/query/pg-core/columns/point.js.map +1 -0
  275. package/dist/data/query/pg-core/columns/postgis_extension/geometry.d.ts +68 -0
  276. package/dist/data/query/pg-core/columns/postgis_extension/geometry.d.ts.map +1 -0
  277. package/dist/data/query/pg-core/columns/postgis_extension/geometry.js +57 -0
  278. package/dist/data/query/pg-core/columns/postgis_extension/geometry.js.map +1 -0
  279. package/dist/data/query/pg-core/columns/postgis_extension/utils.d.ts +2 -0
  280. package/dist/data/query/pg-core/columns/postgis_extension/utils.d.ts.map +1 -0
  281. package/dist/data/query/pg-core/columns/postgis_extension/utils.js +39 -0
  282. package/dist/data/query/pg-core/columns/postgis_extension/utils.js.map +1 -0
  283. package/dist/data/query/pg-core/columns/real.d.ts +34 -0
  284. package/dist/data/query/pg-core/columns/real.d.ts.map +1 -0
  285. package/dist/data/query/pg-core/columns/real.js +32 -0
  286. package/dist/data/query/pg-core/columns/real.js.map +1 -0
  287. package/dist/data/query/pg-core/columns/serial.d.ts +28 -0
  288. package/dist/data/query/pg-core/columns/serial.d.ts.map +1 -0
  289. package/dist/data/query/pg-core/columns/serial.js +24 -0
  290. package/dist/data/query/pg-core/columns/serial.js.map +1 -0
  291. package/dist/data/query/pg-core/columns/smallint.d.ts +30 -0
  292. package/dist/data/query/pg-core/columns/smallint.d.ts.map +1 -0
  293. package/dist/data/query/pg-core/columns/smallint.js +29 -0
  294. package/dist/data/query/pg-core/columns/smallint.js.map +1 -0
  295. package/dist/data/query/pg-core/columns/smallserial.d.ts +28 -0
  296. package/dist/data/query/pg-core/columns/smallserial.d.ts.map +1 -0
  297. package/dist/data/query/pg-core/columns/smallserial.js +24 -0
  298. package/dist/data/query/pg-core/columns/smallserial.js.map +1 -0
  299. package/dist/data/query/pg-core/columns/text.d.ts +38 -0
  300. package/dist/data/query/pg-core/columns/text.d.ts.map +1 -0
  301. package/dist/data/query/pg-core/columns/text.js +26 -0
  302. package/dist/data/query/pg-core/columns/text.js.map +1 -0
  303. package/dist/data/query/pg-core/columns/time.d.ts +45 -0
  304. package/dist/data/query/pg-core/columns/time.d.ts.map +1 -0
  305. package/dist/data/query/pg-core/columns/time.js +39 -0
  306. package/dist/data/query/pg-core/columns/time.js.map +1 -0
  307. package/dist/data/query/pg-core/columns/timestamp.d.ts +76 -0
  308. package/dist/data/query/pg-core/columns/timestamp.d.ts.map +1 -0
  309. package/dist/data/query/pg-core/columns/timestamp.js +83 -0
  310. package/dist/data/query/pg-core/columns/timestamp.js.map +1 -0
  311. package/dist/data/query/pg-core/columns/uuid.d.ts +32 -0
  312. package/dist/data/query/pg-core/columns/uuid.d.ts.map +1 -0
  313. package/dist/data/query/pg-core/columns/uuid.js +29 -0
  314. package/dist/data/query/pg-core/columns/uuid.js.map +1 -0
  315. package/dist/data/query/pg-core/columns/varchar.d.ts +53 -0
  316. package/dist/data/query/pg-core/columns/varchar.d.ts.map +1 -0
  317. package/dist/data/query/pg-core/columns/varchar.js +28 -0
  318. package/dist/data/query/pg-core/columns/varchar.js.map +1 -0
  319. package/dist/data/query/pg-core/columns/vector_extension/bit.d.ts +45 -0
  320. package/dist/data/query/pg-core/columns/vector_extension/bit.d.ts.map +1 -0
  321. package/dist/data/query/pg-core/columns/vector_extension/bit.js +26 -0
  322. package/dist/data/query/pg-core/columns/vector_extension/bit.js.map +1 -0
  323. package/dist/data/query/pg-core/columns/vector_extension/halfvec.d.ts +49 -0
  324. package/dist/data/query/pg-core/columns/vector_extension/halfvec.d.ts.map +1 -0
  325. package/dist/data/query/pg-core/columns/vector_extension/halfvec.js +35 -0
  326. package/dist/data/query/pg-core/columns/vector_extension/halfvec.js.map +1 -0
  327. package/dist/data/query/pg-core/columns/vector_extension/sparsevec.d.ts +36 -0
  328. package/dist/data/query/pg-core/columns/vector_extension/sparsevec.d.ts.map +1 -0
  329. package/dist/data/query/pg-core/columns/vector_extension/sparsevec.js +26 -0
  330. package/dist/data/query/pg-core/columns/vector_extension/sparsevec.js.map +1 -0
  331. package/dist/data/query/pg-core/columns/vector_extension/vector.d.ts +49 -0
  332. package/dist/data/query/pg-core/columns/vector_extension/vector.d.ts.map +1 -0
  333. package/dist/data/query/pg-core/columns/vector_extension/vector.js +35 -0
  334. package/dist/data/query/pg-core/columns/vector_extension/vector.js.map +1 -0
  335. package/dist/data/query/pg-core/db.d.ts +292 -0
  336. package/dist/data/query/pg-core/db.d.ts.map +1 -0
  337. package/dist/data/query/pg-core/db.js +377 -0
  338. package/dist/data/query/pg-core/db.js.map +1 -0
  339. package/dist/data/query/pg-core/dialect.d.ts +66 -0
  340. package/dist/data/query/pg-core/dialect.d.ts.map +1 -0
  341. package/dist/data/query/pg-core/dialect.js +1099 -0
  342. package/dist/data/query/pg-core/dialect.js.map +1 -0
  343. package/dist/data/query/pg-core/expressions.d.ts +9 -0
  344. package/dist/data/query/pg-core/expressions.d.ts.map +1 -0
  345. package/dist/data/query/pg-core/expressions.js +18 -0
  346. package/dist/data/query/pg-core/expressions.js.map +1 -0
  347. package/dist/data/query/pg-core/foreign-keys.d.ts +57 -0
  348. package/dist/data/query/pg-core/foreign-keys.d.ts.map +1 -0
  349. package/dist/data/query/pg-core/foreign-keys.js +70 -0
  350. package/dist/data/query/pg-core/foreign-keys.js.map +1 -0
  351. package/dist/data/query/pg-core/index.d.ts +22 -0
  352. package/dist/data/query/pg-core/index.d.ts.map +1 -0
  353. package/dist/data/query/pg-core/index.js +22 -0
  354. package/dist/data/query/pg-core/index.js.map +1 -0
  355. package/dist/data/query/pg-core/indexes.d.ts +84 -0
  356. package/dist/data/query/pg-core/indexes.d.ts.map +1 -0
  357. package/dist/data/query/pg-core/indexes.js +100 -0
  358. package/dist/data/query/pg-core/indexes.js.map +1 -0
  359. package/dist/data/query/pg-core/policies.d.ts +27 -0
  360. package/dist/data/query/pg-core/policies.d.ts.map +1 -0
  361. package/dist/data/query/pg-core/policies.js +30 -0
  362. package/dist/data/query/pg-core/policies.js.map +1 -0
  363. package/dist/data/query/pg-core/primary-keys.d.ts +37 -0
  364. package/dist/data/query/pg-core/primary-keys.d.ts.map +1 -0
  365. package/dist/data/query/pg-core/primary-keys.js +38 -0
  366. package/dist/data/query/pg-core/primary-keys.js.map +1 -0
  367. package/dist/data/query/pg-core/query-builders/count.d.ts +30 -0
  368. package/dist/data/query/pg-core/query-builders/count.d.ts.map +1 -0
  369. package/dist/data/query/pg-core/query-builders/count.js +45 -0
  370. package/dist/data/query/pg-core/query-builders/count.js.map +1 -0
  371. package/dist/data/query/pg-core/query-builders/delete.d.ts +115 -0
  372. package/dist/data/query/pg-core/query-builders/delete.d.ts.map +1 -0
  373. package/dist/data/query/pg-core/query-builders/delete.js +103 -0
  374. package/dist/data/query/pg-core/query-builders/delete.js.map +1 -0
  375. package/dist/data/query/pg-core/query-builders/index.d.ts +8 -0
  376. package/dist/data/query/pg-core/query-builders/index.d.ts.map +1 -0
  377. package/dist/data/query/pg-core/query-builders/index.js +8 -0
  378. package/dist/data/query/pg-core/query-builders/index.js.map +1 -0
  379. package/dist/data/query/pg-core/query-builders/insert.d.ts +189 -0
  380. package/dist/data/query/pg-core/query-builders/insert.d.ts.map +1 -0
  381. package/dist/data/query/pg-core/query-builders/insert.js +201 -0
  382. package/dist/data/query/pg-core/query-builders/insert.js.map +1 -0
  383. package/dist/data/query/pg-core/query-builders/query-builder.d.ts +38 -0
  384. package/dist/data/query/pg-core/query-builders/query-builder.d.ts.map +1 -0
  385. package/dist/data/query/pg-core/query-builders/query-builder.js +83 -0
  386. package/dist/data/query/pg-core/query-builders/query-builder.js.map +1 -0
  387. package/dist/data/query/pg-core/query-builders/query.d.ts +56 -0
  388. package/dist/data/query/pg-core/query-builders/query.d.ts.map +1 -0
  389. package/dist/data/query/pg-core/query-builders/query.js +104 -0
  390. package/dist/data/query/pg-core/query-builders/query.js.map +1 -0
  391. package/dist/data/query/pg-core/query-builders/raw.d.ts +27 -0
  392. package/dist/data/query/pg-core/query-builders/raw.d.ts.map +1 -0
  393. package/dist/data/query/pg-core/query-builders/raw.js +34 -0
  394. package/dist/data/query/pg-core/query-builders/raw.js.map +1 -0
  395. package/dist/data/query/pg-core/query-builders/refresh-materialized-view.d.ts +38 -0
  396. package/dist/data/query/pg-core/query-builders/refresh-materialized-view.d.ts.map +1 -0
  397. package/dist/data/query/pg-core/query-builders/refresh-materialized-view.js +58 -0
  398. package/dist/data/query/pg-core/query-builders/refresh-materialized-view.js.map +1 -0
  399. package/dist/data/query/pg-core/query-builders/select.d.ts +811 -0
  400. package/dist/data/query/pg-core/query-builders/select.d.ts.map +1 -0
  401. package/dist/data/query/pg-core/query-builders/select.js +993 -0
  402. package/dist/data/query/pg-core/query-builders/select.js.map +1 -0
  403. package/dist/data/query/pg-core/query-builders/select.types.d.ts +141 -0
  404. package/dist/data/query/pg-core/query-builders/select.types.d.ts.map +1 -0
  405. package/dist/data/query/pg-core/query-builders/select.types.js +2 -0
  406. package/dist/data/query/pg-core/query-builders/select.types.js.map +1 -0
  407. package/dist/data/query/pg-core/query-builders/update.d.ts +183 -0
  408. package/dist/data/query/pg-core/query-builders/update.d.ts.map +1 -0
  409. package/dist/data/query/pg-core/query-builders/update.js +210 -0
  410. package/dist/data/query/pg-core/query-builders/update.js.map +1 -0
  411. package/dist/data/query/pg-core/roles.d.ts +22 -0
  412. package/dist/data/query/pg-core/roles.d.ts.map +1 -0
  413. package/dist/data/query/pg-core/roles.js +29 -0
  414. package/dist/data/query/pg-core/roles.js.map +1 -0
  415. package/dist/data/query/pg-core/schema.d.ts +23 -0
  416. package/dist/data/query/pg-core/schema.d.ts.map +1 -0
  417. package/dist/data/query/pg-core/schema.js +46 -0
  418. package/dist/data/query/pg-core/schema.js.map +1 -0
  419. package/dist/data/query/pg-core/sequence.d.ts +21 -0
  420. package/dist/data/query/pg-core/sequence.d.ts.map +1 -0
  421. package/dist/data/query/pg-core/sequence.js +23 -0
  422. package/dist/data/query/pg-core/sequence.js.map +1 -0
  423. package/dist/data/query/pg-core/session.d.ts +94 -0
  424. package/dist/data/query/pg-core/session.d.ts.map +1 -0
  425. package/dist/data/query/pg-core/session.js +169 -0
  426. package/dist/data/query/pg-core/session.js.map +1 -0
  427. package/dist/data/query/pg-core/subquery.d.ts +19 -0
  428. package/dist/data/query/pg-core/subquery.d.ts.map +1 -0
  429. package/dist/data/query/pg-core/subquery.js +2 -0
  430. package/dist/data/query/pg-core/subquery.js.map +1 -0
  431. package/dist/data/query/pg-core/table.d.ts +129 -0
  432. package/dist/data/query/pg-core/table.d.ts.map +1 -0
  433. package/dist/data/query/pg-core/table.js +62 -0
  434. package/dist/data/query/pg-core/table.js.map +1 -0
  435. package/dist/data/query/pg-core/unique-constraint.d.ts +34 -0
  436. package/dist/data/query/pg-core/unique-constraint.d.ts.map +1 -0
  437. package/dist/data/query/pg-core/unique-constraint.js +56 -0
  438. package/dist/data/query/pg-core/unique-constraint.js.map +1 -0
  439. package/dist/data/query/pg-core/utils/array.d.ts +4 -0
  440. package/dist/data/query/pg-core/utils/array.d.ts.map +1 -0
  441. package/dist/data/query/pg-core/utils/array.js +75 -0
  442. package/dist/data/query/pg-core/utils/array.js.map +1 -0
  443. package/dist/data/query/pg-core/utils/index.d.ts +2 -0
  444. package/dist/data/query/pg-core/utils/index.d.ts.map +1 -0
  445. package/dist/data/query/pg-core/utils/index.js +2 -0
  446. package/dist/data/query/pg-core/utils/index.js.map +1 -0
  447. package/dist/data/query/pg-core/utils.d.ts +56 -0
  448. package/dist/data/query/pg-core/utils.d.ts.map +1 -0
  449. package/dist/data/query/pg-core/utils.js +88 -0
  450. package/dist/data/query/pg-core/utils.js.map +1 -0
  451. package/dist/data/query/pg-core/view-base.d.ts +9 -0
  452. package/dist/data/query/pg-core/view-base.d.ts.map +1 -0
  453. package/dist/data/query/pg-core/view-base.js +6 -0
  454. package/dist/data/query/pg-core/view-base.js.map +1 -0
  455. package/dist/data/query/pg-core/view-common.d.ts +2 -0
  456. package/dist/data/query/pg-core/view-common.d.ts.map +1 -0
  457. package/dist/data/query/pg-core/view-common.js +2 -0
  458. package/dist/data/query/pg-core/view-common.js.map +1 -0
  459. package/dist/data/query/pg-core/view.d.ts +161 -0
  460. package/dist/data/query/pg-core/view.d.ts.map +1 -0
  461. package/dist/data/query/pg-core/view.js +243 -0
  462. package/dist/data/query/pg-core/view.js.map +1 -0
  463. package/dist/data/query/postgres-js/driver.d.ts +30 -0
  464. package/dist/data/query/postgres-js/driver.d.ts.map +1 -0
  465. package/dist/data/query/postgres-js/driver.js +77 -0
  466. package/dist/data/query/postgres-js/driver.js.map +1 -0
  467. package/dist/data/query/postgres-js/index.d.ts +3 -0
  468. package/dist/data/query/postgres-js/index.d.ts.map +1 -0
  469. package/dist/data/query/postgres-js/index.js +3 -0
  470. package/dist/data/query/postgres-js/index.js.map +1 -0
  471. package/dist/data/query/postgres-js/session.d.ts +67 -0
  472. package/dist/data/query/postgres-js/session.d.ts.map +1 -0
  473. package/dist/data/query/postgres-js/session.js +139 -0
  474. package/dist/data/query/postgres-js/session.js.map +1 -0
  475. package/dist/data/query/primary-key.d.ts +11 -0
  476. package/dist/data/query/primary-key.d.ts.map +1 -0
  477. package/dist/data/query/primary-key.js +11 -0
  478. package/dist/data/query/primary-key.js.map +1 -0
  479. package/dist/data/query/query-builders/query-builder.d.ts +14 -0
  480. package/dist/data/query/query-builders/query-builder.d.ts.map +1 -0
  481. package/dist/data/query/query-builders/query-builder.js +9 -0
  482. package/dist/data/query/query-builders/query-builder.js.map +1 -0
  483. package/dist/data/query/query-builders/select.types.d.ts +59 -0
  484. package/dist/data/query/query-builders/select.types.d.ts.map +1 -0
  485. package/dist/data/query/query-builders/select.types.js +2 -0
  486. package/dist/data/query/query-builders/select.types.js.map +1 -0
  487. package/dist/data/query/query-promise.d.ts +10 -0
  488. package/dist/data/query/query-promise.d.ts.map +1 -0
  489. package/dist/data/query/query-promise.js +21 -0
  490. package/dist/data/query/query-promise.js.map +1 -0
  491. package/dist/data/query/relations.d.ts +216 -0
  492. package/dist/data/query/relations.d.ts.map +1 -0
  493. package/dist/data/query/relations.js +257 -0
  494. package/dist/data/query/relations.js.map +1 -0
  495. package/dist/data/query/runnable-query.d.ts +11 -0
  496. package/dist/data/query/runnable-query.d.ts.map +1 -0
  497. package/dist/data/query/runnable-query.js +2 -0
  498. package/dist/data/query/runnable-query.js.map +1 -0
  499. package/dist/data/query/selection-proxy.d.ts +10 -0
  500. package/dist/data/query/selection-proxy.d.ts.map +1 -0
  501. package/dist/data/query/selection-proxy.js +62 -0
  502. package/dist/data/query/selection-proxy.js.map +1 -0
  503. package/dist/data/query/session.d.ts +8 -0
  504. package/dist/data/query/session.d.ts.map +1 -0
  505. package/dist/data/query/session.js +2 -0
  506. package/dist/data/query/session.js.map +1 -0
  507. package/dist/data/query/sql/expressions/conditions.d.ts +454 -0
  508. package/dist/data/query/sql/expressions/conditions.d.ts.map +1 -0
  509. package/dist/data/query/sql/expressions/conditions.js +393 -0
  510. package/dist/data/query/sql/expressions/conditions.js.map +1 -0
  511. package/dist/data/query/sql/expressions/index.d.ts +3 -0
  512. package/dist/data/query/sql/expressions/index.d.ts.map +1 -0
  513. package/dist/data/query/sql/expressions/index.js +3 -0
  514. package/dist/data/query/sql/expressions/index.js.map +1 -0
  515. package/dist/data/query/sql/expressions/select.d.ts +39 -0
  516. package/dist/data/query/sql/expressions/select.d.ts.map +1 -0
  517. package/dist/data/query/sql/expressions/select.js +42 -0
  518. package/dist/data/query/sql/expressions/select.js.map +1 -0
  519. package/dist/data/query/sql/functions/aggregate.d.ts +105 -0
  520. package/dist/data/query/sql/functions/aggregate.d.ts.map +1 -0
  521. package/dist/data/query/sql/functions/aggregate.js +122 -0
  522. package/dist/data/query/sql/functions/aggregate.js.map +1 -0
  523. package/dist/data/query/sql/functions/index.d.ts +3 -0
  524. package/dist/data/query/sql/functions/index.d.ts.map +1 -0
  525. package/dist/data/query/sql/functions/index.js +3 -0
  526. package/dist/data/query/sql/functions/index.js.map +1 -0
  527. package/dist/data/query/sql/functions/vector.d.ts +121 -0
  528. package/dist/data/query/sql/functions/vector.d.ts.map +1 -0
  529. package/dist/data/query/sql/functions/vector.js +152 -0
  530. package/dist/data/query/sql/functions/vector.js.map +1 -0
  531. package/dist/data/query/sql/index.d.ts +4 -0
  532. package/dist/data/query/sql/index.d.ts.map +1 -0
  533. package/dist/data/query/sql/index.js +4 -0
  534. package/dist/data/query/sql/index.js.map +1 -0
  535. package/dist/data/query/sql/sql.d.ts +254 -0
  536. package/dist/data/query/sql/sql.d.ts.map +1 -0
  537. package/dist/data/query/sql/sql.js +478 -0
  538. package/dist/data/query/sql/sql.js.map +1 -0
  539. package/dist/data/query/subquery.d.ts +21 -0
  540. package/dist/data/query/subquery.d.ts.map +1 -0
  541. package/dist/data/query/subquery.js +18 -0
  542. package/dist/data/query/subquery.js.map +1 -0
  543. package/dist/data/query/table.d.ts +142 -0
  544. package/dist/data/query/table.d.ts.map +1 -0
  545. package/dist/data/query/table.js +73 -0
  546. package/dist/data/query/table.js.map +1 -0
  547. package/dist/data/query/table.utils.d.ts +3 -0
  548. package/dist/data/query/table.utils.d.ts.map +1 -0
  549. package/dist/data/query/table.utils.js +3 -0
  550. package/dist/data/query/table.utils.js.map +1 -0
  551. package/dist/data/query/tracing-utils.d.ts +2 -0
  552. package/dist/data/query/tracing-utils.d.ts.map +1 -0
  553. package/dist/data/query/tracing-utils.js +4 -0
  554. package/dist/data/query/tracing-utils.js.map +1 -0
  555. package/dist/data/query/tracing.d.ts +10 -0
  556. package/dist/data/query/tracing.d.ts.map +1 -0
  557. package/dist/data/query/tracing.js +7 -0
  558. package/dist/data/query/tracing.js.map +1 -0
  559. package/dist/data/query/utils.d.ts +81 -0
  560. package/dist/data/query/utils.d.ts.map +1 -0
  561. package/dist/data/query/utils.js +193 -0
  562. package/dist/data/query/utils.js.map +1 -0
  563. package/dist/data/query/version.d.ts +3 -0
  564. package/dist/data/query/version.d.ts.map +1 -0
  565. package/dist/data/query/version.js +5 -0
  566. package/dist/data/query/version.js.map +1 -0
  567. package/dist/data/query/view-common.d.ts +2 -0
  568. package/dist/data/query/view-common.d.ts.map +1 -0
  569. package/dist/data/query/view-common.js +2 -0
  570. package/dist/data/query/view-common.js.map +1 -0
  571. package/dist/data/schema/namespace.d.ts +2 -2
  572. package/dist/data/temporal/columns.d.ts +4 -4
  573. package/dist/data/vector/types.d.ts +2 -2
  574. package/dist/db/index.d.ts +0 -1
  575. package/dist/db/index.d.ts.map +1 -1
  576. package/dist/db/index.js +0 -1
  577. package/dist/db/index.js.map +1 -1
  578. package/dist/db/namespace.d.ts +0 -5
  579. package/dist/db/namespace.d.ts.map +1 -1
  580. package/dist/db/namespace.js +0 -5
  581. package/dist/db/namespace.js.map +1 -1
  582. package/dist/domain/define.d.ts.map +1 -1
  583. package/dist/domain/define.js.map +1 -1
  584. package/dist/domain/field.d.ts +2 -4
  585. package/dist/domain/field.d.ts.map +1 -1
  586. package/dist/domain/field.js.map +1 -1
  587. package/dist/domain/index.d.ts +1 -1
  588. package/dist/domain/index.d.ts.map +1 -1
  589. package/dist/domain/types.d.ts +9 -37
  590. package/dist/domain/types.d.ts.map +1 -1
  591. package/dist/drizzle/index.d.ts +3 -0
  592. package/dist/drizzle/index.d.ts.map +1 -0
  593. package/dist/drizzle/index.js +3 -0
  594. package/dist/drizzle/index.js.map +1 -0
  595. package/dist/log/namespace.d.ts +1 -1
  596. package/dist/logging/index.d.ts +1 -1
  597. package/dist/logging/index.d.ts.map +1 -1
  598. package/dist/logging/proxy.d.ts +2 -2
  599. package/dist/logging/proxy.d.ts.map +1 -1
  600. package/dist/logging/proxy.js +2 -9
  601. package/dist/logging/proxy.js.map +1 -1
  602. package/dist/logging/types.d.ts +0 -7
  603. package/dist/logging/types.d.ts.map +1 -1
  604. package/dist/resource/batch.d.ts +17 -0
  605. package/dist/resource/batch.d.ts.map +1 -0
  606. package/dist/resource/batch.js +47 -0
  607. package/dist/resource/batch.js.map +1 -0
  608. package/dist/resource/builder.d.ts +11 -0
  609. package/dist/resource/builder.d.ts.map +1 -0
  610. package/dist/resource/builder.js +12 -0
  611. package/dist/resource/builder.js.map +1 -0
  612. package/dist/resource/errors.d.ts +7 -0
  613. package/dist/resource/errors.d.ts.map +1 -0
  614. package/dist/resource/errors.js +9 -0
  615. package/dist/resource/errors.js.map +1 -0
  616. package/dist/resource/index.d.ts +9 -0
  617. package/dist/resource/index.d.ts.map +1 -0
  618. package/dist/resource/index.js +6 -0
  619. package/dist/resource/index.js.map +1 -0
  620. package/dist/resource/paginate.d.ts +13 -0
  621. package/dist/resource/paginate.d.ts.map +1 -0
  622. package/dist/resource/paginate.js +29 -0
  623. package/dist/resource/paginate.js.map +1 -0
  624. package/dist/resource/register.d.ts +16 -0
  625. package/dist/resource/register.d.ts.map +1 -0
  626. package/dist/resource/register.js +181 -0
  627. package/dist/resource/register.js.map +1 -0
  628. package/dist/resource/types.d.ts +69 -0
  629. package/dist/resource/types.d.ts.map +1 -0
  630. package/dist/resource/types.js +2 -0
  631. package/dist/resource/types.js.map +1 -0
  632. package/dist/surface/http.d.ts +2 -2
  633. package/dist/surface/http.d.ts.map +1 -1
  634. package/dist/surface/http.js +8 -25
  635. package/dist/surface/http.js.map +1 -1
  636. package/dist/surface/index.d.ts +1 -1
  637. package/dist/surface/index.d.ts.map +1 -1
  638. package/dist/surface/namespace.d.ts +1 -1
  639. package/dist/surface/namespace.d.ts.map +1 -1
  640. package/dist/surface/namespace.js +1 -1
  641. package/dist/surface/namespace.js.map +1 -1
  642. package/dist/surface/types.d.ts +0 -7
  643. package/dist/surface/types.d.ts.map +1 -1
  644. package/dist/temporal/definition-queries.d.ts +5 -5
  645. package/dist/temporal/definition-queries.d.ts.map +1 -1
  646. package/dist/temporal/definition-queries.js.map +1 -1
  647. package/dist/test/plugin.d.ts +2 -1
  648. package/dist/test/plugin.d.ts.map +1 -1
  649. package/dist/test/plugin.js +10 -2
  650. package/dist/test/plugin.js.map +1 -1
  651. package/dist/test/setup.d.ts.map +1 -1
  652. package/dist/test/setup.js +6 -4
  653. package/dist/test/setup.js.map +1 -1
  654. package/dist/test/vitest.d.ts +2 -2
  655. package/dist/test/vitest.d.ts.map +1 -1
  656. package/dist/test/vitest.js +6 -3
  657. package/dist/test/vitest.js.map +1 -1
  658. package/dist/trunk.d.ts +35 -0
  659. package/dist/trunk.d.ts.map +1 -0
  660. package/dist/trunk.js +102 -0
  661. package/dist/trunk.js.map +1 -0
  662. package/dist/validation/surface.d.ts +4 -0
  663. package/dist/validation/surface.d.ts.map +1 -0
  664. package/dist/validation/surface.js +55 -0
  665. package/dist/validation/surface.js.map +1 -0
  666. package/dist/vector/index.d.ts +1 -2
  667. package/dist/vector/index.d.ts.map +1 -1
  668. package/dist/vector/index.js +1 -1
  669. package/dist/vector/index.js.map +1 -1
  670. package/dist/vector/namespace.d.ts +4 -10
  671. package/dist/vector/namespace.d.ts.map +1 -1
  672. package/dist/vector/namespace.js +4 -10
  673. package/dist/vector/namespace.js.map +1 -1
  674. package/dist/vector/query.d.ts +2 -15
  675. package/dist/vector/query.d.ts.map +1 -1
  676. package/dist/vector/query.js +1 -39
  677. package/dist/vector/query.js.map +1 -1
  678. package/dist/webhook/verify.d.ts +3 -5
  679. package/dist/webhook/verify.d.ts.map +1 -1
  680. package/dist/webhook/verify.js +2 -5
  681. package/dist/webhook/verify.js.map +1 -1
  682. package/dist/workspace/affected.d.ts +17 -0
  683. package/dist/workspace/affected.d.ts.map +1 -0
  684. package/dist/workspace/affected.js +29 -0
  685. package/dist/workspace/affected.js.map +1 -0
  686. package/dist/workspace/changed-files.d.ts +7 -0
  687. package/dist/workspace/changed-files.d.ts.map +1 -0
  688. package/dist/workspace/changed-files.js +38 -0
  689. package/dist/workspace/changed-files.js.map +1 -0
  690. package/dist/workspace/dependency-graph.d.ts +8 -0
  691. package/dist/workspace/dependency-graph.d.ts.map +1 -0
  692. package/dist/workspace/dependency-graph.js +54 -0
  693. package/dist/workspace/dependency-graph.js.map +1 -0
  694. package/dist/workspace/index.d.ts +3 -0
  695. package/dist/workspace/index.d.ts.map +1 -1
  696. package/dist/workspace/index.js +3 -0
  697. package/dist/workspace/index.js.map +1 -1
  698. package/package.json +33 -24
  699. package/dist/config/ts-register.d.ts +0 -2
  700. package/dist/config/ts-register.d.ts.map +0 -1
  701. package/dist/config/ts-register.js +0 -3
  702. package/dist/config/ts-register.js.map +0 -1
  703. package/dist/config/ts-resolve-hooks.d.ts +0 -10
  704. package/dist/config/ts-resolve-hooks.d.ts.map +0 -1
  705. package/dist/config/ts-resolve-hooks.js +0 -14
  706. package/dist/config/ts-resolve-hooks.js.map +0 -1
  707. package/dist/db/excluded.d.ts +0 -7
  708. package/dist/db/excluded.d.ts.map +0 -1
  709. package/dist/db/excluded.js +0 -11
  710. package/dist/db/excluded.js.map +0 -1
  711. package/dist/jsonb/index.d.ts +0 -2
  712. package/dist/jsonb/index.d.ts.map +0 -1
  713. package/dist/jsonb/index.js +0 -2
  714. package/dist/jsonb/index.js.map +0 -1
  715. package/dist/jsonb/namespace.d.ts +0 -11
  716. package/dist/jsonb/namespace.d.ts.map +0 -1
  717. package/dist/jsonb/namespace.js +0 -11
  718. package/dist/jsonb/namespace.js.map +0 -1
  719. package/dist/jsonb/query.d.ts +0 -5
  720. package/dist/jsonb/query.d.ts.map +0 -1
  721. package/dist/jsonb/query.js +0 -11
  722. package/dist/jsonb/query.js.map +0 -1
  723. package/dist/validation/doctrine.d.ts +0 -13
  724. package/dist/validation/doctrine.d.ts.map +0 -1
  725. package/dist/validation/doctrine.js +0 -115
  726. package/dist/validation/doctrine.js.map +0 -1
@@ -0,0 +1,993 @@
1
+ import { entityKind, is } from '../../entity.js';
2
+ import { PgViewBase } from '../view-base.js';
3
+ import { TypedQueryBuilder } from '../../query-builders/query-builder.js';
4
+ import { QueryPromise } from '../../query-promise.js';
5
+ import { SelectionProxyHandler } from '../../selection-proxy.js';
6
+ import { SQL, View } from '../../sql/sql.js';
7
+ import { Subquery } from '../../subquery.js';
8
+ import { Table } from '../../table.js';
9
+ import { tracer } from '../../tracing.js';
10
+ import { applyMixins, getTableColumns, getTableLikeName, haveSameKeys, } from '../../utils.js';
11
+ import { orderSelectedFields } from '../../utils.js';
12
+ import { ViewBaseConfig } from '../../view-common.js';
13
+ import { extractUsedTable } from '../utils.js';
14
+ export class PgSelectBuilder {
15
+ static [entityKind] = 'PgSelectBuilder';
16
+ fields;
17
+ session;
18
+ dialect;
19
+ withList = [];
20
+ distinct;
21
+ constructor(config) {
22
+ this.fields = config.fields;
23
+ this.session = config.session;
24
+ this.dialect = config.dialect;
25
+ if (config.withList) {
26
+ this.withList = config.withList;
27
+ }
28
+ this.distinct = config.distinct;
29
+ }
30
+ authToken;
31
+ /** @internal */
32
+ setToken(token) {
33
+ this.authToken = token;
34
+ return this;
35
+ }
36
+ /**
37
+ * Specify the table, subquery, or other target that you're
38
+ * building a select query against.
39
+ *
40
+ * {@link https://www.postgresql.org/docs/current/sql-select.html#SQL-FROM | Postgres from documentation}
41
+ */
42
+ from(source) {
43
+ const isPartialSelect = !!this.fields;
44
+ const src = source;
45
+ let fields;
46
+ if (this.fields) {
47
+ fields = this.fields;
48
+ }
49
+ else if (is(src, Subquery)) {
50
+ // This is required to use the proxy handler to get the correct field values from the subquery
51
+ fields = Object.fromEntries(Object.keys(src._.selectedFields).map((key) => [key, src[key]]));
52
+ }
53
+ else if (is(src, PgViewBase)) {
54
+ fields = src[ViewBaseConfig].selectedFields;
55
+ }
56
+ else if (is(src, SQL)) {
57
+ fields = {};
58
+ }
59
+ else {
60
+ fields = getTableColumns(src);
61
+ }
62
+ return (new PgSelectBase({
63
+ table: src,
64
+ fields,
65
+ isPartialSelect,
66
+ session: this.session,
67
+ dialect: this.dialect,
68
+ withList: this.withList,
69
+ distinct: this.distinct,
70
+ }).setToken(this.authToken));
71
+ }
72
+ }
73
+ export class PgSelectQueryBuilderBase extends TypedQueryBuilder {
74
+ static [entityKind] = 'PgSelectQueryBuilder';
75
+ _;
76
+ config;
77
+ joinsNotNullableMap;
78
+ tableName;
79
+ isPartialSelect;
80
+ session;
81
+ dialect;
82
+ cacheConfig = undefined;
83
+ usedTables = new Set();
84
+ constructor({ table, fields, isPartialSelect, session, dialect, withList, distinct }) {
85
+ super();
86
+ this.config = {
87
+ withList,
88
+ table,
89
+ fields: { ...fields },
90
+ distinct,
91
+ setOperators: [],
92
+ };
93
+ this.isPartialSelect = isPartialSelect;
94
+ this.session = session;
95
+ this.dialect = dialect;
96
+ this._ = {
97
+ selectedFields: fields,
98
+ config: this.config,
99
+ };
100
+ this.tableName = getTableLikeName(table);
101
+ this.joinsNotNullableMap = typeof this.tableName === 'string' ? { [this.tableName]: true } : {};
102
+ for (const item of extractUsedTable(table))
103
+ this.usedTables.add(item);
104
+ }
105
+ /** @internal */
106
+ getUsedTables() {
107
+ return [...this.usedTables];
108
+ }
109
+ createJoin(joinType, lateral) {
110
+ return ((table, on) => {
111
+ const baseTableName = this.tableName;
112
+ const tableName = getTableLikeName(table);
113
+ // store all tables used in a query
114
+ for (const item of extractUsedTable(table))
115
+ this.usedTables.add(item);
116
+ if (typeof tableName === 'string' && this.config.joins?.some((join) => join.alias === tableName)) {
117
+ throw new Error(`Alias "${tableName}" is already used in this query`);
118
+ }
119
+ if (!this.isPartialSelect) {
120
+ // If this is the first join and this is not a partial select and we're not selecting from raw SQL, "move" the fields from the main table to the nested object
121
+ if (Object.keys(this.joinsNotNullableMap).length === 1 && typeof baseTableName === 'string') {
122
+ this.config.fields = {
123
+ [baseTableName]: this.config.fields,
124
+ };
125
+ }
126
+ if (typeof tableName === 'string' && !is(table, SQL)) {
127
+ const selection = is(table, Subquery)
128
+ ? table._.selectedFields
129
+ : is(table, View)
130
+ ? table[ViewBaseConfig].selectedFields
131
+ : table[Table.Symbol.Columns];
132
+ this.config.fields[tableName] = selection;
133
+ }
134
+ }
135
+ if (typeof on === 'function') {
136
+ on = on(new Proxy(this.config.fields, new SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' })));
137
+ }
138
+ if (!this.config.joins) {
139
+ this.config.joins = [];
140
+ }
141
+ this.config.joins.push({ on, table, joinType, alias: tableName, lateral });
142
+ if (typeof tableName === 'string') {
143
+ switch (joinType) {
144
+ case 'left': {
145
+ this.joinsNotNullableMap[tableName] = false;
146
+ break;
147
+ }
148
+ case 'right': {
149
+ this.joinsNotNullableMap = Object.fromEntries(Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false]));
150
+ this.joinsNotNullableMap[tableName] = true;
151
+ break;
152
+ }
153
+ case 'cross':
154
+ case 'inner': {
155
+ this.joinsNotNullableMap[tableName] = true;
156
+ break;
157
+ }
158
+ case 'full': {
159
+ this.joinsNotNullableMap = Object.fromEntries(Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false]));
160
+ this.joinsNotNullableMap[tableName] = false;
161
+ break;
162
+ }
163
+ }
164
+ }
165
+ return this;
166
+ });
167
+ }
168
+ /**
169
+ * Executes a `left join` operation by adding another table to the current query.
170
+ *
171
+ * 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.
172
+ *
173
+ * See docs: {@link https://orm.drizzle.team/docs/joins#left-join}
174
+ *
175
+ * @param table the table to join.
176
+ * @param on the `on` clause.
177
+ *
178
+ * @example
179
+ *
180
+ * ```ts
181
+ * // Select all users and their pets
182
+ * const usersWithPets: { user: User; pets: Pet | null; }[] = await db.select()
183
+ * .from(users)
184
+ * .leftJoin(pets, eq(users.id, pets.ownerId))
185
+ *
186
+ * // Select userId and petId
187
+ * const usersIdsAndPetIds: { userId: number; petId: number | null; }[] = await db.select({
188
+ * userId: users.id,
189
+ * petId: pets.id,
190
+ * })
191
+ * .from(users)
192
+ * .leftJoin(pets, eq(users.id, pets.ownerId))
193
+ * ```
194
+ */
195
+ leftJoin = this.createJoin('left', false);
196
+ /**
197
+ * Executes a `left join lateral` operation by adding subquery to the current query.
198
+ *
199
+ * A `lateral` join allows the right-hand expression to refer to columns from the left-hand side.
200
+ *
201
+ * 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.
202
+ *
203
+ * See docs: {@link https://orm.drizzle.team/docs/joins#left-join-lateral}
204
+ *
205
+ * @param table the subquery to join.
206
+ * @param on the `on` clause.
207
+ */
208
+ leftJoinLateral = this.createJoin('left', true);
209
+ /**
210
+ * Executes a `right join` operation by adding another table to the current query.
211
+ *
212
+ * 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.
213
+ *
214
+ * See docs: {@link https://orm.drizzle.team/docs/joins#right-join}
215
+ *
216
+ * @param table the table to join.
217
+ * @param on the `on` clause.
218
+ *
219
+ * @example
220
+ *
221
+ * ```ts
222
+ * // Select all users and their pets
223
+ * const usersWithPets: { user: User | null; pets: Pet; }[] = await db.select()
224
+ * .from(users)
225
+ * .rightJoin(pets, eq(users.id, pets.ownerId))
226
+ *
227
+ * // Select userId and petId
228
+ * const usersIdsAndPetIds: { userId: number | null; petId: number; }[] = await db.select({
229
+ * userId: users.id,
230
+ * petId: pets.id,
231
+ * })
232
+ * .from(users)
233
+ * .rightJoin(pets, eq(users.id, pets.ownerId))
234
+ * ```
235
+ */
236
+ rightJoin = this.createJoin('right', false);
237
+ /**
238
+ * Executes an `inner join` operation, creating a new table by combining rows from two tables that have matching values.
239
+ *
240
+ * 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.
241
+ *
242
+ * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join}
243
+ *
244
+ * @param table the table to join.
245
+ * @param on the `on` clause.
246
+ *
247
+ * @example
248
+ *
249
+ * ```ts
250
+ * // Select all users and their pets
251
+ * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()
252
+ * .from(users)
253
+ * .innerJoin(pets, eq(users.id, pets.ownerId))
254
+ *
255
+ * // Select userId and petId
256
+ * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({
257
+ * userId: users.id,
258
+ * petId: pets.id,
259
+ * })
260
+ * .from(users)
261
+ * .innerJoin(pets, eq(users.id, pets.ownerId))
262
+ * ```
263
+ */
264
+ innerJoin = this.createJoin('inner', false);
265
+ /**
266
+ * Executes an `inner join lateral` operation, creating a new table by combining rows from two queries that have matching values.
267
+ *
268
+ * A `lateral` join allows the right-hand expression to refer to columns from the left-hand side.
269
+ *
270
+ * 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.
271
+ *
272
+ * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join-lateral}
273
+ *
274
+ * @param table the subquery to join.
275
+ * @param on the `on` clause.
276
+ */
277
+ innerJoinLateral = this.createJoin('inner', true);
278
+ /**
279
+ * Executes a `full join` operation by combining rows from two tables into a new table.
280
+ *
281
+ * 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.
282
+ *
283
+ * See docs: {@link https://orm.drizzle.team/docs/joins#full-join}
284
+ *
285
+ * @param table the table to join.
286
+ * @param on the `on` clause.
287
+ *
288
+ * @example
289
+ *
290
+ * ```ts
291
+ * // Select all users and their pets
292
+ * const usersWithPets: { user: User | null; pets: Pet | null; }[] = await db.select()
293
+ * .from(users)
294
+ * .fullJoin(pets, eq(users.id, pets.ownerId))
295
+ *
296
+ * // Select userId and petId
297
+ * const usersIdsAndPetIds: { userId: number | null; petId: number | null; }[] = await db.select({
298
+ * userId: users.id,
299
+ * petId: pets.id,
300
+ * })
301
+ * .from(users)
302
+ * .fullJoin(pets, eq(users.id, pets.ownerId))
303
+ * ```
304
+ */
305
+ fullJoin = this.createJoin('full', false);
306
+ /**
307
+ * Executes a `cross join` operation by combining rows from two tables into a new table.
308
+ *
309
+ * Calling this method retrieves all rows from both main and joined tables, merging all rows from each table.
310
+ *
311
+ * See docs: {@link https://orm.drizzle.team/docs/joins#cross-join}
312
+ *
313
+ * @param table the table to join.
314
+ *
315
+ * @example
316
+ *
317
+ * ```ts
318
+ * // Select all users, each user with every pet
319
+ * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()
320
+ * .from(users)
321
+ * .crossJoin(pets)
322
+ *
323
+ * // Select userId and petId
324
+ * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({
325
+ * userId: users.id,
326
+ * petId: pets.id,
327
+ * })
328
+ * .from(users)
329
+ * .crossJoin(pets)
330
+ * ```
331
+ */
332
+ crossJoin = this.createJoin('cross', false);
333
+ /**
334
+ * Executes a `cross join lateral` operation by combining rows from two queries into a new table.
335
+ *
336
+ * A `lateral` join allows the right-hand expression to refer to columns from the left-hand side.
337
+ *
338
+ * Calling this method retrieves all rows from both main and joined queries, merging all rows from each query.
339
+ *
340
+ * See docs: {@link https://orm.drizzle.team/docs/joins#cross-join-lateral}
341
+ *
342
+ * @param table the query to join.
343
+ */
344
+ crossJoinLateral = this.createJoin('cross', true);
345
+ createSetOperator(type, isAll) {
346
+ return (rightSelection) => {
347
+ const rightSelect = (typeof rightSelection === 'function'
348
+ ? rightSelection(getPgSetOperators())
349
+ : rightSelection);
350
+ if (!haveSameKeys(this.getSelectedFields(), rightSelect.getSelectedFields())) {
351
+ throw new Error('Set operator error (union / intersect / except): selected fields are not the same or are in a different order');
352
+ }
353
+ this.config.setOperators.push({ type, isAll, rightSelect });
354
+ return this;
355
+ };
356
+ }
357
+ /**
358
+ * Adds `union` set operator to the query.
359
+ *
360
+ * Calling this method will combine the result sets of the `select` statements and remove any duplicate rows that appear across them.
361
+ *
362
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#union}
363
+ *
364
+ * @example
365
+ *
366
+ * ```ts
367
+ * // Select all unique names from customers and users tables
368
+ * await db.select({ name: users.name })
369
+ * .from(users)
370
+ * .union(
371
+ * db.select({ name: customers.name }).from(customers)
372
+ * );
373
+ * // or
374
+ * import { union } from 'drizzle-orm/pg-core'
375
+ *
376
+ * await union(
377
+ * db.select({ name: users.name }).from(users),
378
+ * db.select({ name: customers.name }).from(customers)
379
+ * );
380
+ * ```
381
+ */
382
+ union = this.createSetOperator('union', false);
383
+ /**
384
+ * Adds `union all` set operator to the query.
385
+ *
386
+ * Calling this method will combine the result-set of the `select` statements and keep all duplicate rows that appear across them.
387
+ *
388
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#union-all}
389
+ *
390
+ * @example
391
+ *
392
+ * ```ts
393
+ * // Select all transaction ids from both online and in-store sales
394
+ * await db.select({ transaction: onlineSales.transactionId })
395
+ * .from(onlineSales)
396
+ * .unionAll(
397
+ * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)
398
+ * );
399
+ * // or
400
+ * import { unionAll } from 'drizzle-orm/pg-core'
401
+ *
402
+ * await unionAll(
403
+ * db.select({ transaction: onlineSales.transactionId }).from(onlineSales),
404
+ * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)
405
+ * );
406
+ * ```
407
+ */
408
+ unionAll = this.createSetOperator('union', true);
409
+ /**
410
+ * Adds `intersect` set operator to the query.
411
+ *
412
+ * Calling this method will retain only the rows that are present in both result sets and eliminate duplicates.
413
+ *
414
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect}
415
+ *
416
+ * @example
417
+ *
418
+ * ```ts
419
+ * // Select course names that are offered in both departments A and B
420
+ * await db.select({ courseName: depA.courseName })
421
+ * .from(depA)
422
+ * .intersect(
423
+ * db.select({ courseName: depB.courseName }).from(depB)
424
+ * );
425
+ * // or
426
+ * import { intersect } from 'drizzle-orm/pg-core'
427
+ *
428
+ * await intersect(
429
+ * db.select({ courseName: depA.courseName }).from(depA),
430
+ * db.select({ courseName: depB.courseName }).from(depB)
431
+ * );
432
+ * ```
433
+ */
434
+ intersect = this.createSetOperator('intersect', false);
435
+ /**
436
+ * Adds `intersect all` set operator to the query.
437
+ *
438
+ * Calling this method will retain only the rows that are present in both result sets including all duplicates.
439
+ *
440
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect-all}
441
+ *
442
+ * @example
443
+ *
444
+ * ```ts
445
+ * // Select all products and quantities that are ordered by both regular and VIP customers
446
+ * await db.select({
447
+ * productId: regularCustomerOrders.productId,
448
+ * quantityOrdered: regularCustomerOrders.quantityOrdered
449
+ * })
450
+ * .from(regularCustomerOrders)
451
+ * .intersectAll(
452
+ * db.select({
453
+ * productId: vipCustomerOrders.productId,
454
+ * quantityOrdered: vipCustomerOrders.quantityOrdered
455
+ * })
456
+ * .from(vipCustomerOrders)
457
+ * );
458
+ * // or
459
+ * import { intersectAll } from 'drizzle-orm/pg-core'
460
+ *
461
+ * await intersectAll(
462
+ * db.select({
463
+ * productId: regularCustomerOrders.productId,
464
+ * quantityOrdered: regularCustomerOrders.quantityOrdered
465
+ * })
466
+ * .from(regularCustomerOrders),
467
+ * db.select({
468
+ * productId: vipCustomerOrders.productId,
469
+ * quantityOrdered: vipCustomerOrders.quantityOrdered
470
+ * })
471
+ * .from(vipCustomerOrders)
472
+ * );
473
+ * ```
474
+ */
475
+ intersectAll = this.createSetOperator('intersect', true);
476
+ /**
477
+ * Adds `except` set operator to the query.
478
+ *
479
+ * 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.
480
+ *
481
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#except}
482
+ *
483
+ * @example
484
+ *
485
+ * ```ts
486
+ * // Select all courses offered in department A but not in department B
487
+ * await db.select({ courseName: depA.courseName })
488
+ * .from(depA)
489
+ * .except(
490
+ * db.select({ courseName: depB.courseName }).from(depB)
491
+ * );
492
+ * // or
493
+ * import { except } from 'drizzle-orm/pg-core'
494
+ *
495
+ * await except(
496
+ * db.select({ courseName: depA.courseName }).from(depA),
497
+ * db.select({ courseName: depB.courseName }).from(depB)
498
+ * );
499
+ * ```
500
+ */
501
+ except = this.createSetOperator('except', false);
502
+ /**
503
+ * Adds `except all` set operator to the query.
504
+ *
505
+ * 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.
506
+ *
507
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#except-all}
508
+ *
509
+ * @example
510
+ *
511
+ * ```ts
512
+ * // Select all products that are ordered by regular customers but not by VIP customers
513
+ * await db.select({
514
+ * productId: regularCustomerOrders.productId,
515
+ * quantityOrdered: regularCustomerOrders.quantityOrdered,
516
+ * })
517
+ * .from(regularCustomerOrders)
518
+ * .exceptAll(
519
+ * db.select({
520
+ * productId: vipCustomerOrders.productId,
521
+ * quantityOrdered: vipCustomerOrders.quantityOrdered,
522
+ * })
523
+ * .from(vipCustomerOrders)
524
+ * );
525
+ * // or
526
+ * import { exceptAll } from 'drizzle-orm/pg-core'
527
+ *
528
+ * await exceptAll(
529
+ * db.select({
530
+ * productId: regularCustomerOrders.productId,
531
+ * quantityOrdered: regularCustomerOrders.quantityOrdered
532
+ * })
533
+ * .from(regularCustomerOrders),
534
+ * db.select({
535
+ * productId: vipCustomerOrders.productId,
536
+ * quantityOrdered: vipCustomerOrders.quantityOrdered
537
+ * })
538
+ * .from(vipCustomerOrders)
539
+ * );
540
+ * ```
541
+ */
542
+ exceptAll = this.createSetOperator('except', true);
543
+ /** @internal */
544
+ addSetOperators(setOperators) {
545
+ this.config.setOperators.push(...setOperators);
546
+ return this;
547
+ }
548
+ /**
549
+ * Adds a `where` clause to the query.
550
+ *
551
+ * Calling this method will select only those rows that fulfill a specified condition.
552
+ *
553
+ * See docs: {@link https://orm.drizzle.team/docs/select#filtering}
554
+ *
555
+ * @param where the `where` clause.
556
+ *
557
+ * @example
558
+ * You can use conditional operators and `sql function` to filter the rows to be selected.
559
+ *
560
+ * ```ts
561
+ * // Select all cars with green color
562
+ * await db.select().from(cars).where(eq(cars.color, 'green'));
563
+ * // or
564
+ * await db.select().from(cars).where(sql`${cars.color} = 'green'`)
565
+ * ```
566
+ *
567
+ * You can logically combine conditional operators with `and()` and `or()` operators:
568
+ *
569
+ * ```ts
570
+ * // Select all BMW cars with a green color
571
+ * await db.select().from(cars).where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));
572
+ *
573
+ * // Select all cars with the green or blue color
574
+ * await db.select().from(cars).where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));
575
+ * ```
576
+ */
577
+ where(where) {
578
+ if (typeof where === 'function') {
579
+ where = where(new Proxy(this.config.fields, new SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' })));
580
+ }
581
+ this.config.where = where;
582
+ return this;
583
+ }
584
+ /**
585
+ * Adds a `having` clause to the query.
586
+ *
587
+ * 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.
588
+ *
589
+ * See docs: {@link https://orm.drizzle.team/docs/select#aggregations}
590
+ *
591
+ * @param having the `having` clause.
592
+ *
593
+ * @example
594
+ *
595
+ * ```ts
596
+ * // Select all brands with more than one car
597
+ * await db.select({
598
+ * brand: cars.brand,
599
+ * count: sql<number>`cast(count(${cars.id}) as int)`,
600
+ * })
601
+ * .from(cars)
602
+ * .groupBy(cars.brand)
603
+ * .having(({ count }) => gt(count, 1));
604
+ * ```
605
+ */
606
+ having(having) {
607
+ if (typeof having === 'function') {
608
+ having = having(new Proxy(this.config.fields, new SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' })));
609
+ }
610
+ this.config.having = having;
611
+ return this;
612
+ }
613
+ groupBy(...columns) {
614
+ if (typeof columns[0] === 'function') {
615
+ const groupBy = columns[0](new Proxy(this.config.fields, new SelectionProxyHandler({ sqlAliasedBehavior: 'alias', sqlBehavior: 'sql' })));
616
+ this.config.groupBy = Array.isArray(groupBy) ? groupBy : [groupBy];
617
+ }
618
+ else {
619
+ this.config.groupBy = columns;
620
+ }
621
+ return this;
622
+ }
623
+ orderBy(...columns) {
624
+ if (typeof columns[0] === 'function') {
625
+ const orderBy = columns[0](new Proxy(this.config.fields, new SelectionProxyHandler({ sqlAliasedBehavior: 'alias', sqlBehavior: 'sql' })));
626
+ const orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];
627
+ if (this.config.setOperators.length > 0) {
628
+ this.config.setOperators.at(-1).orderBy = orderByArray;
629
+ }
630
+ else {
631
+ this.config.orderBy = orderByArray;
632
+ }
633
+ }
634
+ else {
635
+ const orderByArray = columns;
636
+ if (this.config.setOperators.length > 0) {
637
+ this.config.setOperators.at(-1).orderBy = orderByArray;
638
+ }
639
+ else {
640
+ this.config.orderBy = orderByArray;
641
+ }
642
+ }
643
+ return this;
644
+ }
645
+ /**
646
+ * Adds a `limit` clause to the query.
647
+ *
648
+ * Calling this method will set the maximum number of rows that will be returned by this query.
649
+ *
650
+ * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}
651
+ *
652
+ * @param limit the `limit` clause.
653
+ *
654
+ * @example
655
+ *
656
+ * ```ts
657
+ * // Get the first 10 people from this query.
658
+ * await db.select().from(people).limit(10);
659
+ * ```
660
+ */
661
+ limit(limit) {
662
+ if (this.config.setOperators.length > 0) {
663
+ this.config.setOperators.at(-1).limit = limit;
664
+ }
665
+ else {
666
+ this.config.limit = limit;
667
+ }
668
+ return this;
669
+ }
670
+ /**
671
+ * Adds an `offset` clause to the query.
672
+ *
673
+ * Calling this method will skip a number of rows when returning results from this query.
674
+ *
675
+ * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}
676
+ *
677
+ * @param offset the `offset` clause.
678
+ *
679
+ * @example
680
+ *
681
+ * ```ts
682
+ * // Get the 10th-20th people from this query.
683
+ * await db.select().from(people).offset(10).limit(10);
684
+ * ```
685
+ */
686
+ offset(offset) {
687
+ if (this.config.setOperators.length > 0) {
688
+ this.config.setOperators.at(-1).offset = offset;
689
+ }
690
+ else {
691
+ this.config.offset = offset;
692
+ }
693
+ return this;
694
+ }
695
+ /**
696
+ * Adds a `for` clause to the query.
697
+ *
698
+ * Calling this method will specify a lock strength for this query that controls how strictly it acquires exclusive access to the rows being queried.
699
+ *
700
+ * See docs: {@link https://www.postgresql.org/docs/current/sql-select.html#SQL-FOR-UPDATE-SHARE}
701
+ *
702
+ * @param strength the lock strength.
703
+ * @param config the lock configuration.
704
+ */
705
+ for(strength, config = {}) {
706
+ this.config.lockingClause = { strength, config };
707
+ return this;
708
+ }
709
+ /** @internal */
710
+ getSQL() {
711
+ return this.dialect.buildSelectQuery(this.config);
712
+ }
713
+ toSQL() {
714
+ const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());
715
+ return rest;
716
+ }
717
+ as(alias) {
718
+ const usedTables = [];
719
+ usedTables.push(...extractUsedTable(this.config.table));
720
+ if (this.config.joins) {
721
+ for (const it of this.config.joins)
722
+ usedTables.push(...extractUsedTable(it.table));
723
+ }
724
+ return new Proxy(new Subquery(this.getSQL(), this.config.fields, alias, false, [...new Set(usedTables)]), new SelectionProxyHandler({ alias, sqlAliasedBehavior: 'alias', sqlBehavior: 'error' }));
725
+ }
726
+ /** @internal */
727
+ getSelectedFields() {
728
+ return new Proxy(this.config.fields, new SelectionProxyHandler({ alias: this.tableName, sqlAliasedBehavior: 'alias', sqlBehavior: 'error' }));
729
+ }
730
+ $dynamic() {
731
+ return this;
732
+ }
733
+ $withCache(config) {
734
+ this.cacheConfig = config === undefined
735
+ ? { config: {}, enable: true, autoInvalidate: true }
736
+ : config === false
737
+ ? { enable: false }
738
+ : { enable: true, autoInvalidate: true, ...config };
739
+ return this;
740
+ }
741
+ }
742
+ export class PgSelectBase extends PgSelectQueryBuilderBase {
743
+ static [entityKind] = 'PgSelect';
744
+ /** @internal */
745
+ _prepare(name) {
746
+ const { session, config, dialect, joinsNotNullableMap, authToken, cacheConfig, usedTables } = this;
747
+ if (!session) {
748
+ throw new Error('Cannot execute a query on a query builder. Please use a database instance instead.');
749
+ }
750
+ const { fields } = config;
751
+ return tracer.startActiveSpan('drizzle.prepareQuery', () => {
752
+ const fieldsList = orderSelectedFields(fields);
753
+ const query = session.prepareQuery(dialect.sqlToQuery(this.getSQL()), fieldsList, name, true, undefined, {
754
+ type: 'select',
755
+ tables: [...usedTables],
756
+ }, cacheConfig);
757
+ query.joinsNotNullableMap = joinsNotNullableMap;
758
+ return query.setToken(authToken);
759
+ });
760
+ }
761
+ /**
762
+ * Create a prepared statement for this query. This allows
763
+ * the database to remember this query for the given session
764
+ * and call it by name, rather than specifying the full query.
765
+ *
766
+ * {@link https://www.postgresql.org/docs/current/sql-prepare.html | Postgres prepare documentation}
767
+ */
768
+ prepare(name) {
769
+ return this._prepare(name);
770
+ }
771
+ authToken;
772
+ /** @internal */
773
+ setToken(token) {
774
+ this.authToken = token;
775
+ return this;
776
+ }
777
+ execute = (placeholderValues) => {
778
+ return tracer.startActiveSpan('drizzle.operation', () => {
779
+ return this._prepare().execute(placeholderValues, this.authToken);
780
+ });
781
+ };
782
+ }
783
+ applyMixins(PgSelectBase, [QueryPromise]);
784
+ function createSetOperator(type, isAll) {
785
+ return (leftSelect, rightSelect, ...restSelects) => {
786
+ const setOperators = [rightSelect, ...restSelects].map((select) => ({
787
+ type,
788
+ isAll,
789
+ rightSelect: select,
790
+ }));
791
+ for (const setOperator of setOperators) {
792
+ if (!haveSameKeys(leftSelect.getSelectedFields(), setOperator.rightSelect.getSelectedFields())) {
793
+ throw new Error('Set operator error (union / intersect / except): selected fields are not the same or are in a different order');
794
+ }
795
+ }
796
+ return leftSelect.addSetOperators(setOperators);
797
+ };
798
+ }
799
+ const getPgSetOperators = () => ({
800
+ union,
801
+ unionAll,
802
+ intersect,
803
+ intersectAll,
804
+ except,
805
+ exceptAll,
806
+ });
807
+ /**
808
+ * Adds `union` set operator to the query.
809
+ *
810
+ * Calling this method will combine the result sets of the `select` statements and remove any duplicate rows that appear across them.
811
+ *
812
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#union}
813
+ *
814
+ * @example
815
+ *
816
+ * ```ts
817
+ * // Select all unique names from customers and users tables
818
+ * import { union } from 'drizzle-orm/pg-core'
819
+ *
820
+ * await union(
821
+ * db.select({ name: users.name }).from(users),
822
+ * db.select({ name: customers.name }).from(customers)
823
+ * );
824
+ * // or
825
+ * await db.select({ name: users.name })
826
+ * .from(users)
827
+ * .union(
828
+ * db.select({ name: customers.name }).from(customers)
829
+ * );
830
+ * ```
831
+ */
832
+ export const union = createSetOperator('union', false);
833
+ /**
834
+ * Adds `union all` set operator to the query.
835
+ *
836
+ * Calling this method will combine the result-set of the `select` statements and keep all duplicate rows that appear across them.
837
+ *
838
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#union-all}
839
+ *
840
+ * @example
841
+ *
842
+ * ```ts
843
+ * // Select all transaction ids from both online and in-store sales
844
+ * import { unionAll } from 'drizzle-orm/pg-core'
845
+ *
846
+ * await unionAll(
847
+ * db.select({ transaction: onlineSales.transactionId }).from(onlineSales),
848
+ * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)
849
+ * );
850
+ * // or
851
+ * await db.select({ transaction: onlineSales.transactionId })
852
+ * .from(onlineSales)
853
+ * .unionAll(
854
+ * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)
855
+ * );
856
+ * ```
857
+ */
858
+ export const unionAll = createSetOperator('union', true);
859
+ /**
860
+ * Adds `intersect` set operator to the query.
861
+ *
862
+ * Calling this method will retain only the rows that are present in both result sets and eliminate duplicates.
863
+ *
864
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect}
865
+ *
866
+ * @example
867
+ *
868
+ * ```ts
869
+ * // Select course names that are offered in both departments A and B
870
+ * import { intersect } from 'drizzle-orm/pg-core'
871
+ *
872
+ * await intersect(
873
+ * db.select({ courseName: depA.courseName }).from(depA),
874
+ * db.select({ courseName: depB.courseName }).from(depB)
875
+ * );
876
+ * // or
877
+ * await db.select({ courseName: depA.courseName })
878
+ * .from(depA)
879
+ * .intersect(
880
+ * db.select({ courseName: depB.courseName }).from(depB)
881
+ * );
882
+ * ```
883
+ */
884
+ export const intersect = createSetOperator('intersect', false);
885
+ /**
886
+ * Adds `intersect all` set operator to the query.
887
+ *
888
+ * Calling this method will retain only the rows that are present in both result sets including all duplicates.
889
+ *
890
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect-all}
891
+ *
892
+ * @example
893
+ *
894
+ * ```ts
895
+ * // Select all products and quantities that are ordered by both regular and VIP customers
896
+ * import { intersectAll } from 'drizzle-orm/pg-core'
897
+ *
898
+ * await intersectAll(
899
+ * db.select({
900
+ * productId: regularCustomerOrders.productId,
901
+ * quantityOrdered: regularCustomerOrders.quantityOrdered
902
+ * })
903
+ * .from(regularCustomerOrders),
904
+ * db.select({
905
+ * productId: vipCustomerOrders.productId,
906
+ * quantityOrdered: vipCustomerOrders.quantityOrdered
907
+ * })
908
+ * .from(vipCustomerOrders)
909
+ * );
910
+ * // or
911
+ * await db.select({
912
+ * productId: regularCustomerOrders.productId,
913
+ * quantityOrdered: regularCustomerOrders.quantityOrdered
914
+ * })
915
+ * .from(regularCustomerOrders)
916
+ * .intersectAll(
917
+ * db.select({
918
+ * productId: vipCustomerOrders.productId,
919
+ * quantityOrdered: vipCustomerOrders.quantityOrdered
920
+ * })
921
+ * .from(vipCustomerOrders)
922
+ * );
923
+ * ```
924
+ */
925
+ export const intersectAll = createSetOperator('intersect', true);
926
+ /**
927
+ * Adds `except` set operator to the query.
928
+ *
929
+ * 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.
930
+ *
931
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#except}
932
+ *
933
+ * @example
934
+ *
935
+ * ```ts
936
+ * // Select all courses offered in department A but not in department B
937
+ * import { except } from 'drizzle-orm/pg-core'
938
+ *
939
+ * await except(
940
+ * db.select({ courseName: depA.courseName }).from(depA),
941
+ * db.select({ courseName: depB.courseName }).from(depB)
942
+ * );
943
+ * // or
944
+ * await db.select({ courseName: depA.courseName })
945
+ * .from(depA)
946
+ * .except(
947
+ * db.select({ courseName: depB.courseName }).from(depB)
948
+ * );
949
+ * ```
950
+ */
951
+ export const except = createSetOperator('except', false);
952
+ /**
953
+ * Adds `except all` set operator to the query.
954
+ *
955
+ * 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.
956
+ *
957
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#except-all}
958
+ *
959
+ * @example
960
+ *
961
+ * ```ts
962
+ * // Select all products that are ordered by regular customers but not by VIP customers
963
+ * import { exceptAll } from 'drizzle-orm/pg-core'
964
+ *
965
+ * await exceptAll(
966
+ * db.select({
967
+ * productId: regularCustomerOrders.productId,
968
+ * quantityOrdered: regularCustomerOrders.quantityOrdered
969
+ * })
970
+ * .from(regularCustomerOrders),
971
+ * db.select({
972
+ * productId: vipCustomerOrders.productId,
973
+ * quantityOrdered: vipCustomerOrders.quantityOrdered
974
+ * })
975
+ * .from(vipCustomerOrders)
976
+ * );
977
+ * // or
978
+ * await db.select({
979
+ * productId: regularCustomerOrders.productId,
980
+ * quantityOrdered: regularCustomerOrders.quantityOrdered,
981
+ * })
982
+ * .from(regularCustomerOrders)
983
+ * .exceptAll(
984
+ * db.select({
985
+ * productId: vipCustomerOrders.productId,
986
+ * quantityOrdered: vipCustomerOrders.quantityOrdered,
987
+ * })
988
+ * .from(vipCustomerOrders)
989
+ * );
990
+ * ```
991
+ */
992
+ export const exceptAll = createSetOperator('except', true);
993
+ //# sourceMappingURL=select.js.map