drizzle-orm 1.0.0-beta.1-7722e6a → 1.0.0-beta.2-e93475f

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 (1777) hide show
  1. package/_relations.cjs +50 -6
  2. package/_relations.cjs.map +1 -1
  3. package/_relations.d.cts +1 -0
  4. package/_relations.d.ts +1 -0
  5. package/_relations.js +49 -6
  6. package/_relations.js.map +1 -1
  7. package/alias.cjs +56 -8
  8. package/alias.cjs.map +1 -1
  9. package/alias.d.cts +13 -3
  10. package/alias.d.ts +13 -3
  11. package/alias.js +53 -8
  12. package/alias.js.map +1 -1
  13. package/aws-data-api/common/index.cjs +18 -9
  14. package/aws-data-api/common/index.cjs.map +1 -1
  15. package/aws-data-api/common/index.d.cts +4 -1
  16. package/aws-data-api/common/index.d.ts +4 -1
  17. package/aws-data-api/common/index.js +17 -9
  18. package/aws-data-api/common/index.js.map +1 -1
  19. package/aws-data-api/pg/driver.cjs +0 -3
  20. package/aws-data-api/pg/driver.cjs.map +1 -1
  21. package/aws-data-api/pg/driver.d.cts +0 -3
  22. package/aws-data-api/pg/driver.d.ts +0 -3
  23. package/aws-data-api/pg/driver.js +0 -3
  24. package/aws-data-api/pg/driver.js.map +1 -1
  25. package/better-sqlite3/driver.cjs +10 -14
  26. package/better-sqlite3/driver.cjs.map +1 -1
  27. package/better-sqlite3/driver.d.cts +3 -3
  28. package/better-sqlite3/driver.d.ts +3 -3
  29. package/better-sqlite3/driver.js +10 -14
  30. package/better-sqlite3/driver.js.map +1 -1
  31. package/bun-sql/driver.cjs.map +1 -1
  32. package/bun-sql/driver.d.cts +8 -8
  33. package/bun-sql/driver.d.ts +8 -8
  34. package/bun-sql/driver.js.map +1 -1
  35. package/bun-sql/mysql/driver.cjs +10 -14
  36. package/bun-sql/mysql/driver.cjs.map +1 -1
  37. package/bun-sql/mysql/driver.d.cts +3 -3
  38. package/bun-sql/mysql/driver.d.ts +3 -3
  39. package/bun-sql/mysql/driver.js +10 -14
  40. package/bun-sql/mysql/driver.js.map +1 -1
  41. package/bun-sql/postgres/driver.cjs +10 -14
  42. package/bun-sql/postgres/driver.cjs.map +1 -1
  43. package/bun-sql/postgres/driver.d.cts +3 -3
  44. package/bun-sql/postgres/driver.d.ts +3 -3
  45. package/bun-sql/postgres/driver.js +10 -14
  46. package/bun-sql/postgres/driver.js.map +1 -1
  47. package/bun-sql/sqlite/driver.cjs +10 -14
  48. package/bun-sql/sqlite/driver.cjs.map +1 -1
  49. package/bun-sql/sqlite/driver.d.cts +3 -3
  50. package/bun-sql/sqlite/driver.d.ts +3 -3
  51. package/bun-sql/sqlite/driver.js +10 -14
  52. package/bun-sql/sqlite/driver.js.map +1 -1
  53. package/bun-sql/sqlite/session.cjs +0 -2
  54. package/bun-sql/sqlite/session.cjs.map +1 -1
  55. package/bun-sql/sqlite/session.js +0 -2
  56. package/bun-sql/sqlite/session.js.map +1 -1
  57. package/bun-sqlite/driver.cjs +11 -15
  58. package/bun-sqlite/driver.cjs.map +1 -1
  59. package/bun-sqlite/driver.d.cts +3 -3
  60. package/bun-sqlite/driver.d.ts +3 -3
  61. package/bun-sqlite/driver.js +11 -15
  62. package/bun-sqlite/driver.js.map +1 -1
  63. package/cockroach/driver.cjs +109 -0
  64. package/cockroach/driver.cjs.map +1 -0
  65. package/cockroach/driver.d.cts +42 -0
  66. package/cockroach/driver.d.ts +42 -0
  67. package/cockroach/driver.js +73 -0
  68. package/cockroach/driver.js.map +1 -0
  69. package/cockroach/index.cjs +25 -0
  70. package/cockroach/index.cjs.map +1 -0
  71. package/cockroach/index.d.cts +2 -0
  72. package/cockroach/index.d.ts +2 -0
  73. package/cockroach/index.js +3 -0
  74. package/cockroach/index.js.map +1 -0
  75. package/cockroach/migrator.cjs +33 -0
  76. package/cockroach/migrator.cjs.map +1 -0
  77. package/cockroach/migrator.d.cts +3 -0
  78. package/cockroach/migrator.d.ts +3 -0
  79. package/cockroach/migrator.js +9 -0
  80. package/cockroach/migrator.js.map +1 -0
  81. package/cockroach/session.cjs +253 -0
  82. package/cockroach/session.cjs.map +1 -0
  83. package/cockroach/session.d.cts +48 -0
  84. package/cockroach/session.d.ts +48 -0
  85. package/cockroach/session.js +217 -0
  86. package/cockroach/session.js.map +1 -0
  87. package/cockroach-core/alias.cjs +32 -0
  88. package/cockroach-core/alias.cjs.map +1 -0
  89. package/cockroach-core/alias.d.cts +4 -0
  90. package/cockroach-core/alias.d.ts +4 -0
  91. package/cockroach-core/alias.js +8 -0
  92. package/cockroach-core/alias.js.map +1 -0
  93. package/cockroach-core/checks.cjs +58 -0
  94. package/cockroach-core/checks.cjs.map +1 -0
  95. package/cockroach-core/checks.d.cts +18 -0
  96. package/cockroach-core/checks.d.ts +18 -0
  97. package/cockroach-core/checks.js +32 -0
  98. package/cockroach-core/checks.js.map +1 -0
  99. package/cockroach-core/columns/all.cjs +81 -0
  100. package/cockroach-core/columns/all.cjs.map +1 -0
  101. package/cockroach-core/columns/all.d.cts +52 -0
  102. package/cockroach-core/columns/all.d.ts +52 -0
  103. package/cockroach-core/columns/all.js +57 -0
  104. package/cockroach-core/columns/all.js.map +1 -0
  105. package/cockroach-core/columns/bigint.cjs +104 -0
  106. package/cockroach-core/columns/bigint.cjs.map +1 -0
  107. package/cockroach-core/columns/bigint.d.cts +37 -0
  108. package/cockroach-core/columns/bigint.d.ts +37 -0
  109. package/cockroach-core/columns/bigint.js +75 -0
  110. package/cockroach-core/columns/bigint.js.map +1 -0
  111. package/cockroach-core/columns/bit.cjs +61 -0
  112. package/cockroach-core/columns/bit.cjs.map +1 -0
  113. package/cockroach-core/columns/bit.d.cts +29 -0
  114. package/cockroach-core/columns/bit.d.ts +29 -0
  115. package/cockroach-core/columns/bit.js +35 -0
  116. package/cockroach-core/columns/bit.js.map +1 -0
  117. package/cockroach-core/columns/bool.cjs +59 -0
  118. package/cockroach-core/columns/bool.cjs.map +1 -0
  119. package/cockroach-core/columns/bool.d.cts +17 -0
  120. package/cockroach-core/columns/bool.d.ts +17 -0
  121. package/cockroach-core/columns/bool.js +32 -0
  122. package/cockroach-core/columns/bool.js.map +1 -0
  123. package/cockroach-core/columns/char.cjs +62 -0
  124. package/cockroach-core/columns/char.cjs.map +1 -0
  125. package/cockroach-core/columns/char.d.cts +31 -0
  126. package/cockroach-core/columns/char.d.ts +31 -0
  127. package/cockroach-core/columns/char.js +36 -0
  128. package/cockroach-core/columns/char.js.map +1 -0
  129. package/cockroach-core/columns/common.cjs +198 -0
  130. package/cockroach-core/columns/common.cjs.map +1 -0
  131. package/cockroach-core/columns/common.d.cts +98 -0
  132. package/cockroach-core/columns/common.d.ts +98 -0
  133. package/cockroach-core/columns/common.js +168 -0
  134. package/cockroach-core/columns/common.js.map +1 -0
  135. package/cockroach-core/columns/custom.cjs +102 -0
  136. package/cockroach-core/columns/custom.cjs.map +1 -0
  137. package/cockroach-core/columns/custom.d.cts +261 -0
  138. package/cockroach-core/columns/custom.d.ts +261 -0
  139. package/cockroach-core/columns/custom.js +76 -0
  140. package/cockroach-core/columns/custom.js.map +1 -0
  141. package/cockroach-core/columns/date.cjs +91 -0
  142. package/cockroach-core/columns/date.cjs.map +1 -0
  143. package/cockroach-core/columns/date.common.cjs +37 -0
  144. package/cockroach-core/columns/date.common.cjs.map +1 -0
  145. package/cockroach-core/columns/date.common.d.cts +7 -0
  146. package/cockroach-core/columns/date.common.d.ts +7 -0
  147. package/cockroach-core/columns/date.common.js +13 -0
  148. package/cockroach-core/columns/date.common.js.map +1 -0
  149. package/cockroach-core/columns/date.d.cts +36 -0
  150. package/cockroach-core/columns/date.d.ts +36 -0
  151. package/cockroach-core/columns/date.js +63 -0
  152. package/cockroach-core/columns/date.js.map +1 -0
  153. package/cockroach-core/columns/decimal.cjs +164 -0
  154. package/cockroach-core/columns/decimal.cjs.map +1 -0
  155. package/cockroach-core/columns/decimal.d.cts +80 -0
  156. package/cockroach-core/columns/decimal.d.ts +80 -0
  157. package/cockroach-core/columns/decimal.js +133 -0
  158. package/cockroach-core/columns/decimal.js.map +1 -0
  159. package/cockroach-core/columns/enum.cjs +127 -0
  160. package/cockroach-core/columns/enum.cjs.map +1 -0
  161. package/cockroach-core/columns/enum.d.cts +64 -0
  162. package/cockroach-core/columns/enum.d.ts +64 -0
  163. package/cockroach-core/columns/enum.js +96 -0
  164. package/cockroach-core/columns/enum.js.map +1 -0
  165. package/cockroach-core/columns/float.cjs +65 -0
  166. package/cockroach-core/columns/float.cjs.map +1 -0
  167. package/cockroach-core/columns/float.d.cts +18 -0
  168. package/cockroach-core/columns/float.d.ts +18 -0
  169. package/cockroach-core/columns/float.js +38 -0
  170. package/cockroach-core/columns/float.js.map +1 -0
  171. package/cockroach-core/columns/geometry.cjs +105 -0
  172. package/cockroach-core/columns/geometry.cjs.map +1 -0
  173. package/cockroach-core/columns/geometry.d.cts +60 -0
  174. package/cockroach-core/columns/geometry.d.ts +60 -0
  175. package/cockroach-core/columns/geometry.js +77 -0
  176. package/cockroach-core/columns/geometry.js.map +1 -0
  177. package/cockroach-core/columns/index.cjs +71 -0
  178. package/cockroach-core/columns/index.cjs.map +1 -0
  179. package/cockroach-core/columns/index.d.cts +25 -0
  180. package/cockroach-core/columns/index.d.ts +25 -0
  181. package/cockroach-core/columns/index.js +26 -0
  182. package/cockroach-core/columns/index.js.map +1 -0
  183. package/cockroach-core/columns/inet.cjs +56 -0
  184. package/cockroach-core/columns/inet.cjs.map +1 -0
  185. package/cockroach-core/columns/inet.d.cts +16 -0
  186. package/cockroach-core/columns/inet.d.ts +16 -0
  187. package/cockroach-core/columns/inet.js +30 -0
  188. package/cockroach-core/columns/inet.js.map +1 -0
  189. package/cockroach-core/columns/int.common.cjs +55 -0
  190. package/cockroach-core/columns/int.common.cjs.map +1 -0
  191. package/cockroach-core/columns/int.common.d.cts +11 -0
  192. package/cockroach-core/columns/int.common.d.ts +11 -0
  193. package/cockroach-core/columns/int.common.js +31 -0
  194. package/cockroach-core/columns/int.common.js.map +1 -0
  195. package/cockroach-core/columns/integer.cjs +63 -0
  196. package/cockroach-core/columns/integer.cjs.map +1 -0
  197. package/cockroach-core/columns/integer.d.cts +18 -0
  198. package/cockroach-core/columns/integer.d.ts +18 -0
  199. package/cockroach-core/columns/integer.js +37 -0
  200. package/cockroach-core/columns/integer.js.map +1 -0
  201. package/cockroach-core/columns/interval.cjs +63 -0
  202. package/cockroach-core/columns/interval.cjs.map +1 -0
  203. package/cockroach-core/columns/interval.d.cts +28 -0
  204. package/cockroach-core/columns/interval.d.ts +28 -0
  205. package/cockroach-core/columns/interval.js +37 -0
  206. package/cockroach-core/columns/interval.js.map +1 -0
  207. package/cockroach-core/columns/jsonb.cjs +72 -0
  208. package/cockroach-core/columns/jsonb.cjs.map +1 -0
  209. package/cockroach-core/columns/jsonb.d.cts +20 -0
  210. package/cockroach-core/columns/jsonb.d.ts +20 -0
  211. package/cockroach-core/columns/jsonb.js +46 -0
  212. package/cockroach-core/columns/jsonb.js.map +1 -0
  213. package/cockroach-core/columns/real.cjs +66 -0
  214. package/cockroach-core/columns/real.cjs.map +1 -0
  215. package/cockroach-core/columns/real.d.cts +21 -0
  216. package/cockroach-core/columns/real.d.ts +21 -0
  217. package/cockroach-core/columns/real.js +40 -0
  218. package/cockroach-core/columns/real.js.map +1 -0
  219. package/cockroach-core/columns/smallint.cjs +68 -0
  220. package/cockroach-core/columns/smallint.cjs.map +1 -0
  221. package/cockroach-core/columns/smallint.d.cts +19 -0
  222. package/cockroach-core/columns/smallint.d.ts +19 -0
  223. package/cockroach-core/columns/smallint.js +41 -0
  224. package/cockroach-core/columns/smallint.js.map +1 -0
  225. package/cockroach-core/columns/string.cjs +67 -0
  226. package/cockroach-core/columns/string.cjs.map +1 -0
  227. package/cockroach-core/columns/string.d.cts +36 -0
  228. package/cockroach-core/columns/string.d.ts +36 -0
  229. package/cockroach-core/columns/string.js +40 -0
  230. package/cockroach-core/columns/string.js.map +1 -0
  231. package/cockroach-core/columns/time.cjs +70 -0
  232. package/cockroach-core/columns/time.cjs.map +1 -0
  233. package/cockroach-core/columns/time.d.cts +31 -0
  234. package/cockroach-core/columns/time.d.ts +31 -0
  235. package/cockroach-core/columns/time.js +44 -0
  236. package/cockroach-core/columns/time.js.map +1 -0
  237. package/cockroach-core/columns/timestamp.cjs +111 -0
  238. package/cockroach-core/columns/timestamp.cjs.map +1 -0
  239. package/cockroach-core/columns/timestamp.d.cts +52 -0
  240. package/cockroach-core/columns/timestamp.d.ts +52 -0
  241. package/cockroach-core/columns/timestamp.js +83 -0
  242. package/cockroach-core/columns/timestamp.js.map +1 -0
  243. package/cockroach-core/columns/utils.cjs +65 -0
  244. package/cockroach-core/columns/utils.cjs.map +1 -0
  245. package/cockroach-core/columns/utils.d.cts +4 -0
  246. package/cockroach-core/columns/utils.d.ts +4 -0
  247. package/cockroach-core/columns/utils.js +41 -0
  248. package/cockroach-core/columns/utils.js.map +1 -0
  249. package/cockroach-core/columns/uuid.cjs +63 -0
  250. package/cockroach-core/columns/uuid.cjs.map +1 -0
  251. package/cockroach-core/columns/uuid.d.cts +20 -0
  252. package/cockroach-core/columns/uuid.d.ts +20 -0
  253. package/cockroach-core/columns/uuid.js +37 -0
  254. package/cockroach-core/columns/uuid.js.map +1 -0
  255. package/cockroach-core/columns/varbit.cjs +59 -0
  256. package/cockroach-core/columns/varbit.cjs.map +1 -0
  257. package/cockroach-core/columns/varbit.d.cts +24 -0
  258. package/cockroach-core/columns/varbit.d.ts +24 -0
  259. package/cockroach-core/columns/varbit.js +33 -0
  260. package/cockroach-core/columns/varbit.js.map +1 -0
  261. package/cockroach-core/columns/varchar.cjs +61 -0
  262. package/cockroach-core/columns/varchar.cjs.map +1 -0
  263. package/cockroach-core/columns/varchar.d.cts +30 -0
  264. package/cockroach-core/columns/varchar.d.ts +30 -0
  265. package/cockroach-core/columns/varchar.js +35 -0
  266. package/cockroach-core/columns/varchar.js.map +1 -0
  267. package/cockroach-core/columns/vector.cjs +65 -0
  268. package/cockroach-core/columns/vector.cjs.map +1 -0
  269. package/cockroach-core/columns/vector.d.cts +26 -0
  270. package/cockroach-core/columns/vector.d.ts +26 -0
  271. package/cockroach-core/columns/vector.js +39 -0
  272. package/cockroach-core/columns/vector.js.map +1 -0
  273. package/cockroach-core/db.cjs +347 -0
  274. package/cockroach-core/db.cjs.map +1 -0
  275. package/cockroach-core/db.d.cts +282 -0
  276. package/cockroach-core/db.d.ts +282 -0
  277. package/cockroach-core/db.js +328 -0
  278. package/cockroach-core/db.js.map +1 -0
  279. package/cockroach-core/dialect.cjs +1155 -0
  280. package/cockroach-core/dialect.cjs.map +1 -0
  281. package/cockroach-core/dialect.d.cts +64 -0
  282. package/cockroach-core/dialect.d.ts +64 -0
  283. package/cockroach-core/dialect.js +1127 -0
  284. package/cockroach-core/dialect.js.map +1 -0
  285. package/cockroach-core/expressions.cjs +49 -0
  286. package/cockroach-core/expressions.cjs.map +1 -0
  287. package/cockroach-core/expressions.d.cts +8 -0
  288. package/cockroach-core/expressions.d.ts +8 -0
  289. package/cockroach-core/expressions.js +22 -0
  290. package/cockroach-core/expressions.js.map +1 -0
  291. package/cockroach-core/foreign-keys.cjs +95 -0
  292. package/cockroach-core/foreign-keys.cjs.map +1 -0
  293. package/cockroach-core/foreign-keys.d.cts +53 -0
  294. package/cockroach-core/foreign-keys.d.ts +53 -0
  295. package/cockroach-core/foreign-keys.js +69 -0
  296. package/cockroach-core/foreign-keys.js.map +1 -0
  297. package/cockroach-core/index.cjs +61 -0
  298. package/cockroach-core/index.cjs.map +1 -0
  299. package/cockroach-core/index.d.cts +20 -0
  300. package/cockroach-core/index.d.ts +20 -0
  301. package/cockroach-core/index.js +21 -0
  302. package/cockroach-core/index.js.map +1 -0
  303. package/cockroach-core/indexes.cjs +139 -0
  304. package/cockroach-core/indexes.cjs.map +1 -0
  305. package/cockroach-core/indexes.d.cts +65 -0
  306. package/cockroach-core/indexes.d.ts +65 -0
  307. package/cockroach-core/indexes.js +111 -0
  308. package/cockroach-core/indexes.js.map +1 -0
  309. package/cockroach-core/policies.cjs +58 -0
  310. package/cockroach-core/policies.cjs.map +1 -0
  311. package/cockroach-core/policies.d.cts +24 -0
  312. package/cockroach-core/policies.d.ts +24 -0
  313. package/cockroach-core/policies.js +33 -0
  314. package/cockroach-core/policies.js.map +1 -0
  315. package/cockroach-core/primary-keys.cjs +66 -0
  316. package/cockroach-core/primary-keys.cjs.map +1 -0
  317. package/cockroach-core/primary-keys.d.cts +24 -0
  318. package/cockroach-core/primary-keys.d.ts +24 -0
  319. package/cockroach-core/primary-keys.js +40 -0
  320. package/cockroach-core/primary-keys.js.map +1 -0
  321. package/cockroach-core/query-builders/count.cjs +79 -0
  322. package/cockroach-core/query-builders/count.cjs.map +1 -0
  323. package/cockroach-core/query-builders/count.d.cts +30 -0
  324. package/cockroach-core/query-builders/count.d.ts +30 -0
  325. package/cockroach-core/query-builders/count.js +55 -0
  326. package/cockroach-core/query-builders/count.js.map +1 -0
  327. package/cockroach-core/query-builders/delete.cjs +124 -0
  328. package/cockroach-core/query-builders/delete.cjs.map +1 -0
  329. package/cockroach-core/query-builders/delete.d.cts +103 -0
  330. package/cockroach-core/query-builders/delete.d.ts +103 -0
  331. package/cockroach-core/query-builders/delete.js +100 -0
  332. package/cockroach-core/query-builders/delete.js.map +1 -0
  333. package/cockroach-core/query-builders/index.cjs +35 -0
  334. package/cockroach-core/query-builders/index.cjs.map +1 -0
  335. package/cockroach-core/query-builders/index.d.cts +7 -0
  336. package/cockroach-core/query-builders/index.d.ts +7 -0
  337. package/cockroach-core/query-builders/index.js +8 -0
  338. package/cockroach-core/query-builders/index.js.map +1 -0
  339. package/cockroach-core/query-builders/insert.cjs +213 -0
  340. package/cockroach-core/query-builders/insert.cjs.map +1 -0
  341. package/cockroach-core/query-builders/insert.d.cts +168 -0
  342. package/cockroach-core/query-builders/insert.d.ts +168 -0
  343. package/cockroach-core/query-builders/insert.js +188 -0
  344. package/cockroach-core/query-builders/insert.js.map +1 -0
  345. package/cockroach-core/query-builders/query-builder.cjs +118 -0
  346. package/cockroach-core/query-builders/query-builder.cjs.map +1 -0
  347. package/cockroach-core/query-builders/query-builder.d.cts +37 -0
  348. package/cockroach-core/query-builders/query-builder.d.ts +37 -0
  349. package/cockroach-core/query-builders/query-builder.js +94 -0
  350. package/cockroach-core/query-builders/query-builder.js.map +1 -0
  351. package/cockroach-core/query-builders/query.cjs +145 -0
  352. package/cockroach-core/query-builders/query.cjs.map +1 -0
  353. package/cockroach-core/query-builders/query.d.cts +47 -0
  354. package/cockroach-core/query-builders/query.d.ts +47 -0
  355. package/cockroach-core/query-builders/query.js +122 -0
  356. package/cockroach-core/query-builders/query.js.map +1 -0
  357. package/cockroach-core/query-builders/raw.cjs +57 -0
  358. package/cockroach-core/query-builders/raw.cjs.map +1 -0
  359. package/cockroach-core/query-builders/raw.d.cts +22 -0
  360. package/cockroach-core/query-builders/raw.d.ts +22 -0
  361. package/cockroach-core/query-builders/raw.js +33 -0
  362. package/cockroach-core/query-builders/raw.js.map +1 -0
  363. package/cockroach-core/query-builders/refresh-materialized-view.cjs +83 -0
  364. package/cockroach-core/query-builders/refresh-materialized-view.cjs.map +1 -0
  365. package/cockroach-core/query-builders/refresh-materialized-view.d.cts +28 -0
  366. package/cockroach-core/query-builders/refresh-materialized-view.d.ts +28 -0
  367. package/cockroach-core/query-builders/refresh-materialized-view.js +59 -0
  368. package/cockroach-core/query-builders/refresh-materialized-view.js.map +1 -0
  369. package/cockroach-core/query-builders/select.cjs +847 -0
  370. package/cockroach-core/query-builders/select.cjs.map +1 -0
  371. package/cockroach-core/query-builders/select.d.cts +787 -0
  372. package/cockroach-core/query-builders/select.d.ts +787 -0
  373. package/cockroach-core/query-builders/select.js +821 -0
  374. package/cockroach-core/query-builders/select.js.map +1 -0
  375. package/cockroach-core/query-builders/select.types.cjs +17 -0
  376. package/cockroach-core/query-builders/select.types.cjs.map +1 -0
  377. package/cockroach-core/query-builders/select.types.d.cts +140 -0
  378. package/cockroach-core/query-builders/select.types.d.ts +140 -0
  379. package/cockroach-core/query-builders/select.types.js +1 -0
  380. package/cockroach-core/query-builders/select.types.js.map +1 -0
  381. package/cockroach-core/query-builders/update.cjs +240 -0
  382. package/cockroach-core/query-builders/update.cjs.map +1 -0
  383. package/cockroach-core/query-builders/update.d.cts +170 -0
  384. package/cockroach-core/query-builders/update.d.ts +170 -0
  385. package/cockroach-core/query-builders/update.js +219 -0
  386. package/cockroach-core/query-builders/update.js.map +1 -0
  387. package/cockroach-core/roles.cjs +54 -0
  388. package/cockroach-core/roles.cjs.map +1 -0
  389. package/cockroach-core/roles.d.cts +12 -0
  390. package/cockroach-core/roles.d.ts +12 -0
  391. package/cockroach-core/roles.js +29 -0
  392. package/cockroach-core/roles.js.map +1 -0
  393. package/cockroach-core/schema.cjs +92 -0
  394. package/cockroach-core/schema.cjs.map +1 -0
  395. package/cockroach-core/schema.d.cts +24 -0
  396. package/cockroach-core/schema.d.ts +24 -0
  397. package/cockroach-core/schema.js +72 -0
  398. package/cockroach-core/schema.js.map +1 -0
  399. package/cockroach-core/sequence.cjs +52 -0
  400. package/cockroach-core/sequence.cjs.map +1 -0
  401. package/cockroach-core/sequence.d.cts +17 -0
  402. package/cockroach-core/sequence.d.ts +17 -0
  403. package/cockroach-core/sequence.js +25 -0
  404. package/cockroach-core/sequence.js.map +1 -0
  405. package/cockroach-core/session.cjs +120 -0
  406. package/cockroach-core/session.cjs.map +1 -0
  407. package/cockroach-core/session.d.cts +62 -0
  408. package/cockroach-core/session.d.ts +62 -0
  409. package/cockroach-core/session.js +94 -0
  410. package/cockroach-core/session.js.map +1 -0
  411. package/cockroach-core/subquery.cjs +17 -0
  412. package/cockroach-core/subquery.cjs.map +1 -0
  413. package/cockroach-core/subquery.d.cts +18 -0
  414. package/cockroach-core/subquery.d.ts +18 -0
  415. package/cockroach-core/subquery.js +1 -0
  416. package/cockroach-core/subquery.js.map +1 -0
  417. package/cockroach-core/table.cjs +121 -0
  418. package/cockroach-core/table.cjs.map +1 -0
  419. package/cockroach-core/table.d.cts +41 -0
  420. package/cockroach-core/table.d.ts +41 -0
  421. package/cockroach-core/table.js +94 -0
  422. package/cockroach-core/table.js.map +1 -0
  423. package/cockroach-core/unique-constraint.cjs +77 -0
  424. package/cockroach-core/unique-constraint.cjs.map +1 -0
  425. package/cockroach-core/unique-constraint.d.cts +23 -0
  426. package/cockroach-core/unique-constraint.d.ts +23 -0
  427. package/cockroach-core/unique-constraint.js +50 -0
  428. package/cockroach-core/unique-constraint.js.map +1 -0
  429. package/cockroach-core/utils/array.cjs +106 -0
  430. package/cockroach-core/utils/array.cjs.map +1 -0
  431. package/cockroach-core/utils/array.d.cts +3 -0
  432. package/cockroach-core/utils/array.d.ts +3 -0
  433. package/cockroach-core/utils/array.js +80 -0
  434. package/cockroach-core/utils/array.js.map +1 -0
  435. package/cockroach-core/utils/index.cjs +23 -0
  436. package/cockroach-core/utils/index.cjs.map +1 -0
  437. package/cockroach-core/utils/index.d.cts +1 -0
  438. package/cockroach-core/utils/index.d.ts +1 -0
  439. package/cockroach-core/utils/index.js +2 -0
  440. package/cockroach-core/utils/index.js.map +1 -0
  441. package/cockroach-core/utils.cjs +98 -0
  442. package/cockroach-core/utils.cjs.map +1 -0
  443. package/cockroach-core/utils.d.cts +47 -0
  444. package/cockroach-core/utils.d.ts +47 -0
  445. package/cockroach-core/utils.js +72 -0
  446. package/cockroach-core/utils.js.map +1 -0
  447. package/cockroach-core/view-base.cjs +33 -0
  448. package/cockroach-core/view-base.cjs.map +1 -0
  449. package/cockroach-core/view-base.d.cts +8 -0
  450. package/cockroach-core/view-base.d.ts +8 -0
  451. package/cockroach-core/view-base.js +9 -0
  452. package/cockroach-core/view-base.js.map +1 -0
  453. package/cockroach-core/view.cjs +271 -0
  454. package/cockroach-core/view.cjs.map +1 -0
  455. package/cockroach-core/view.d.cts +106 -0
  456. package/cockroach-core/view.d.ts +106 -0
  457. package/cockroach-core/view.js +233 -0
  458. package/cockroach-core/view.js.map +1 -0
  459. package/column-builder.cjs.map +1 -1
  460. package/column-builder.d.cts +9 -8
  461. package/column-builder.d.ts +9 -8
  462. package/column-builder.js.map +1 -1
  463. package/column-common.cjs +29 -0
  464. package/column-common.cjs.map +1 -0
  465. package/column-common.d.cts +1 -0
  466. package/column-common.d.ts +1 -0
  467. package/column-common.js +5 -0
  468. package/column-common.js.map +1 -0
  469. package/column.cjs +7 -0
  470. package/column.cjs.map +1 -1
  471. package/column.d.cts +2 -0
  472. package/column.d.ts +2 -0
  473. package/column.js +7 -0
  474. package/column.js.map +1 -1
  475. package/durable-sqlite/migrator.cjs +10 -7
  476. package/durable-sqlite/migrator.cjs.map +1 -1
  477. package/durable-sqlite/migrator.d.cts +1 -9
  478. package/durable-sqlite/migrator.d.ts +1 -9
  479. package/durable-sqlite/migrator.js +10 -7
  480. package/durable-sqlite/migrator.js.map +1 -1
  481. package/durable-sqlite/session.cjs +6 -3
  482. package/durable-sqlite/session.cjs.map +1 -1
  483. package/durable-sqlite/session.d.cts +1 -2
  484. package/durable-sqlite/session.d.ts +1 -2
  485. package/durable-sqlite/session.js +6 -2
  486. package/durable-sqlite/session.js.map +1 -1
  487. package/entity.cjs.map +1 -1
  488. package/entity.js.map +1 -1
  489. package/expo-sqlite/migrator.cjs +10 -7
  490. package/expo-sqlite/migrator.cjs.map +1 -1
  491. package/expo-sqlite/migrator.d.cts +0 -8
  492. package/expo-sqlite/migrator.d.ts +0 -8
  493. package/expo-sqlite/migrator.js +10 -7
  494. package/expo-sqlite/migrator.js.map +1 -1
  495. package/gel/driver.cjs +6 -10
  496. package/gel/driver.cjs.map +1 -1
  497. package/gel/driver.d.cts +2 -2
  498. package/gel/driver.d.ts +2 -2
  499. package/gel/driver.js +6 -10
  500. package/gel/driver.js.map +1 -1
  501. package/gel-core/columns/bigint.cjs.map +1 -1
  502. package/gel-core/columns/bigint.d.cts +0 -1
  503. package/gel-core/columns/bigint.d.ts +0 -1
  504. package/gel-core/columns/bigint.js.map +1 -1
  505. package/gel-core/columns/bigintT.cjs.map +1 -1
  506. package/gel-core/columns/bigintT.d.cts +0 -1
  507. package/gel-core/columns/bigintT.d.ts +0 -1
  508. package/gel-core/columns/bigintT.js.map +1 -1
  509. package/gel-core/columns/boolean.cjs.map +1 -1
  510. package/gel-core/columns/boolean.d.cts +0 -1
  511. package/gel-core/columns/boolean.d.ts +0 -1
  512. package/gel-core/columns/boolean.js.map +1 -1
  513. package/gel-core/columns/bytes.cjs.map +1 -1
  514. package/gel-core/columns/bytes.d.cts +0 -1
  515. package/gel-core/columns/bytes.d.ts +0 -1
  516. package/gel-core/columns/bytes.js.map +1 -1
  517. package/gel-core/columns/common.cjs +0 -4
  518. package/gel-core/columns/common.cjs.map +1 -1
  519. package/gel-core/columns/common.d.cts +1 -1
  520. package/gel-core/columns/common.d.ts +1 -1
  521. package/gel-core/columns/common.js +0 -4
  522. package/gel-core/columns/common.js.map +1 -1
  523. package/gel-core/columns/custom.cjs.map +1 -1
  524. package/gel-core/columns/custom.d.cts +0 -1
  525. package/gel-core/columns/custom.d.ts +0 -1
  526. package/gel-core/columns/custom.js.map +1 -1
  527. package/gel-core/columns/date-duration.cjs.map +1 -1
  528. package/gel-core/columns/date-duration.d.cts +0 -1
  529. package/gel-core/columns/date-duration.d.ts +0 -1
  530. package/gel-core/columns/date-duration.js.map +1 -1
  531. package/gel-core/columns/decimal.cjs.map +1 -1
  532. package/gel-core/columns/decimal.d.cts +0 -1
  533. package/gel-core/columns/decimal.d.ts +0 -1
  534. package/gel-core/columns/decimal.js.map +1 -1
  535. package/gel-core/columns/double-precision.cjs.map +1 -1
  536. package/gel-core/columns/double-precision.d.cts +0 -1
  537. package/gel-core/columns/double-precision.d.ts +0 -1
  538. package/gel-core/columns/double-precision.js.map +1 -1
  539. package/gel-core/columns/duration.cjs.map +1 -1
  540. package/gel-core/columns/duration.d.cts +0 -1
  541. package/gel-core/columns/duration.d.ts +0 -1
  542. package/gel-core/columns/duration.js.map +1 -1
  543. package/gel-core/columns/integer.cjs.map +1 -1
  544. package/gel-core/columns/integer.d.cts +0 -1
  545. package/gel-core/columns/integer.d.ts +0 -1
  546. package/gel-core/columns/integer.js.map +1 -1
  547. package/gel-core/columns/json.cjs.map +1 -1
  548. package/gel-core/columns/json.d.cts +0 -1
  549. package/gel-core/columns/json.d.ts +0 -1
  550. package/gel-core/columns/json.js.map +1 -1
  551. package/gel-core/columns/localdate.cjs.map +1 -1
  552. package/gel-core/columns/localdate.d.cts +0 -1
  553. package/gel-core/columns/localdate.d.ts +0 -1
  554. package/gel-core/columns/localdate.js.map +1 -1
  555. package/gel-core/columns/localtime.cjs.map +1 -1
  556. package/gel-core/columns/localtime.d.cts +0 -1
  557. package/gel-core/columns/localtime.d.ts +0 -1
  558. package/gel-core/columns/localtime.js.map +1 -1
  559. package/gel-core/columns/real.cjs.map +1 -1
  560. package/gel-core/columns/real.d.cts +0 -1
  561. package/gel-core/columns/real.d.ts +0 -1
  562. package/gel-core/columns/real.js.map +1 -1
  563. package/gel-core/columns/relative-duration.cjs.map +1 -1
  564. package/gel-core/columns/relative-duration.d.cts +0 -1
  565. package/gel-core/columns/relative-duration.d.ts +0 -1
  566. package/gel-core/columns/relative-duration.js.map +1 -1
  567. package/gel-core/columns/smallint.cjs.map +1 -1
  568. package/gel-core/columns/smallint.d.cts +0 -1
  569. package/gel-core/columns/smallint.d.ts +0 -1
  570. package/gel-core/columns/smallint.js.map +1 -1
  571. package/gel-core/columns/text.cjs.map +1 -1
  572. package/gel-core/columns/text.d.cts +0 -1
  573. package/gel-core/columns/text.d.ts +0 -1
  574. package/gel-core/columns/text.js.map +1 -1
  575. package/gel-core/columns/timestamp.cjs.map +1 -1
  576. package/gel-core/columns/timestamp.d.cts +0 -1
  577. package/gel-core/columns/timestamp.d.ts +0 -1
  578. package/gel-core/columns/timestamp.js.map +1 -1
  579. package/gel-core/columns/timestamptz.cjs.map +1 -1
  580. package/gel-core/columns/timestamptz.d.cts +0 -1
  581. package/gel-core/columns/timestamptz.d.ts +0 -1
  582. package/gel-core/columns/timestamptz.js.map +1 -1
  583. package/gel-core/columns/uuid.cjs.map +1 -1
  584. package/gel-core/columns/uuid.d.cts +0 -1
  585. package/gel-core/columns/uuid.d.ts +0 -1
  586. package/gel-core/columns/uuid.js.map +1 -1
  587. package/gel-core/dialect.cjs +1 -1
  588. package/gel-core/dialect.cjs.map +1 -1
  589. package/gel-core/dialect.js +8 -2
  590. package/gel-core/dialect.js.map +1 -1
  591. package/gel-core/query-builders/count.cjs.map +1 -1
  592. package/gel-core/query-builders/count.d.cts +4 -3
  593. package/gel-core/query-builders/count.d.ts +4 -3
  594. package/gel-core/query-builders/count.js.map +1 -1
  595. package/gel-core/query-builders/insert.cjs.map +1 -1
  596. package/gel-core/query-builders/insert.d.cts +6 -9
  597. package/gel-core/query-builders/insert.d.ts +6 -9
  598. package/gel-core/query-builders/insert.js.map +1 -1
  599. package/gel-core/query-builders/select.cjs +6 -7
  600. package/gel-core/query-builders/select.cjs.map +1 -1
  601. package/gel-core/query-builders/select.js +2 -2
  602. package/gel-core/query-builders/select.js.map +1 -1
  603. package/gel-core/query-builders/update.cjs.map +1 -1
  604. package/gel-core/query-builders/update.d.cts +1 -1
  605. package/gel-core/query-builders/update.d.ts +1 -1
  606. package/gel-core/query-builders/update.js.map +1 -1
  607. package/gel-core/utils.cjs +1 -2
  608. package/gel-core/utils.cjs.map +1 -1
  609. package/gel-core/utils.d.cts +1 -1
  610. package/gel-core/utils.d.ts +1 -1
  611. package/gel-core/utils.js +1 -2
  612. package/gel-core/utils.js.map +1 -1
  613. package/gel-core/view-common.cjs +3 -0
  614. package/gel-core/view-common.cjs.map +1 -1
  615. package/gel-core/view-common.d.cts +1 -0
  616. package/gel-core/view-common.d.ts +1 -0
  617. package/gel-core/view-common.js +2 -0
  618. package/gel-core/view-common.js.map +1 -1
  619. package/gel-core/view.cjs +2 -5
  620. package/gel-core/view.cjs.map +1 -1
  621. package/gel-core/view.d.cts +1 -2
  622. package/gel-core/view.d.ts +1 -2
  623. package/gel-core/view.js +1 -3
  624. package/gel-core/view.js.map +1 -1
  625. package/libsql/driver.cjs +6 -10
  626. package/libsql/driver.cjs.map +1 -1
  627. package/libsql/driver.d.cts +3 -3
  628. package/libsql/driver.d.ts +3 -3
  629. package/libsql/driver.js +6 -10
  630. package/libsql/driver.js.map +1 -1
  631. package/libsql/http/index.cjs +6 -10
  632. package/libsql/http/index.cjs.map +1 -1
  633. package/libsql/http/index.d.cts +3 -3
  634. package/libsql/http/index.d.ts +3 -3
  635. package/libsql/http/index.js +6 -10
  636. package/libsql/http/index.js.map +1 -1
  637. package/libsql/node/index.cjs +6 -10
  638. package/libsql/node/index.cjs.map +1 -1
  639. package/libsql/node/index.d.cts +3 -3
  640. package/libsql/node/index.d.ts +3 -3
  641. package/libsql/node/index.js +6 -10
  642. package/libsql/node/index.js.map +1 -1
  643. package/libsql/session.cjs +0 -2
  644. package/libsql/session.cjs.map +1 -1
  645. package/libsql/session.d.cts +1 -1
  646. package/libsql/session.d.ts +1 -1
  647. package/libsql/session.js +0 -2
  648. package/libsql/session.js.map +1 -1
  649. package/libsql/sqlite3/index.cjs +6 -10
  650. package/libsql/sqlite3/index.cjs.map +1 -1
  651. package/libsql/sqlite3/index.d.cts +3 -3
  652. package/libsql/sqlite3/index.d.ts +3 -3
  653. package/libsql/sqlite3/index.js +6 -10
  654. package/libsql/sqlite3/index.js.map +1 -1
  655. package/libsql/wasm/index.cjs +6 -10
  656. package/libsql/wasm/index.cjs.map +1 -1
  657. package/libsql/wasm/index.d.cts +3 -3
  658. package/libsql/wasm/index.d.ts +3 -3
  659. package/libsql/wasm/index.js +6 -10
  660. package/libsql/wasm/index.js.map +1 -1
  661. package/libsql/web/index.cjs +6 -10
  662. package/libsql/web/index.cjs.map +1 -1
  663. package/libsql/web/index.d.cts +3 -3
  664. package/libsql/web/index.d.ts +3 -3
  665. package/libsql/web/index.js +6 -10
  666. package/libsql/web/index.js.map +1 -1
  667. package/libsql/ws/index.cjs +6 -10
  668. package/libsql/ws/index.cjs.map +1 -1
  669. package/libsql/ws/index.d.cts +3 -3
  670. package/libsql/ws/index.d.ts +3 -3
  671. package/libsql/ws/index.js +6 -10
  672. package/libsql/ws/index.js.map +1 -1
  673. package/migrator.cjs +42 -5
  674. package/migrator.cjs.map +1 -1
  675. package/migrator.d.cts +5 -0
  676. package/migrator.d.ts +5 -0
  677. package/migrator.js +42 -6
  678. package/migrator.js.map +1 -1
  679. package/mssql-core/alias.cjs +32 -0
  680. package/mssql-core/alias.cjs.map +1 -0
  681. package/mssql-core/alias.d.cts +4 -0
  682. package/mssql-core/alias.d.ts +4 -0
  683. package/mssql-core/alias.js +8 -0
  684. package/mssql-core/alias.js.map +1 -0
  685. package/mssql-core/checks.cjs +58 -0
  686. package/mssql-core/checks.cjs.map +1 -0
  687. package/mssql-core/checks.d.cts +18 -0
  688. package/mssql-core/checks.d.ts +18 -0
  689. package/mssql-core/checks.js +32 -0
  690. package/mssql-core/checks.js.map +1 -0
  691. package/mssql-core/columns/all.cjs +74 -0
  692. package/mssql-core/columns/all.cjs.map +1 -0
  693. package/mssql-core/columns/all.d.cts +45 -0
  694. package/mssql-core/columns/all.d.ts +45 -0
  695. package/mssql-core/columns/all.js +50 -0
  696. package/mssql-core/columns/all.js.map +1 -0
  697. package/mssql-core/columns/bigint.cjs +72 -0
  698. package/mssql-core/columns/bigint.cjs.map +1 -0
  699. package/mssql-core/columns/bigint.d.cts +25 -0
  700. package/mssql-core/columns/bigint.d.ts +25 -0
  701. package/mssql-core/columns/bigint.js +46 -0
  702. package/mssql-core/columns/bigint.js.map +1 -0
  703. package/mssql-core/columns/binary.cjs +57 -0
  704. package/mssql-core/columns/binary.cjs.map +1 -0
  705. package/mssql-core/columns/binary.d.cts +24 -0
  706. package/mssql-core/columns/binary.d.ts +24 -0
  707. package/mssql-core/columns/binary.js +31 -0
  708. package/mssql-core/columns/binary.js.map +1 -0
  709. package/mssql-core/columns/bit.cjs +54 -0
  710. package/mssql-core/columns/bit.cjs.map +1 -0
  711. package/mssql-core/columns/bit.d.cts +17 -0
  712. package/mssql-core/columns/bit.d.ts +17 -0
  713. package/mssql-core/columns/bit.js +28 -0
  714. package/mssql-core/columns/bit.js.map +1 -0
  715. package/mssql-core/columns/char.cjs +73 -0
  716. package/mssql-core/columns/char.cjs.map +1 -0
  717. package/mssql-core/columns/char.d.cts +29 -0
  718. package/mssql-core/columns/char.d.ts +29 -0
  719. package/mssql-core/columns/char.js +46 -0
  720. package/mssql-core/columns/char.js.map +1 -0
  721. package/mssql-core/columns/common.cjs +112 -0
  722. package/mssql-core/columns/common.cjs.map +1 -0
  723. package/mssql-core/columns/common.d.cts +57 -0
  724. package/mssql-core/columns/common.d.ts +57 -0
  725. package/mssql-core/columns/common.js +85 -0
  726. package/mssql-core/columns/common.js.map +1 -0
  727. package/mssql-core/columns/custom.cjs +105 -0
  728. package/mssql-core/columns/custom.cjs.map +1 -0
  729. package/mssql-core/columns/custom.d.cts +261 -0
  730. package/mssql-core/columns/custom.d.ts +261 -0
  731. package/mssql-core/columns/custom.js +79 -0
  732. package/mssql-core/columns/custom.js.map +1 -0
  733. package/mssql-core/columns/date.cjs +94 -0
  734. package/mssql-core/columns/date.cjs.map +1 -0
  735. package/mssql-core/columns/date.common.cjs +37 -0
  736. package/mssql-core/columns/date.common.cjs.map +1 -0
  737. package/mssql-core/columns/date.common.d.cts +12 -0
  738. package/mssql-core/columns/date.common.d.ts +12 -0
  739. package/mssql-core/columns/date.common.js +13 -0
  740. package/mssql-core/columns/date.common.js.map +1 -0
  741. package/mssql-core/columns/date.d.cts +39 -0
  742. package/mssql-core/columns/date.d.ts +39 -0
  743. package/mssql-core/columns/date.js +66 -0
  744. package/mssql-core/columns/date.js.map +1 -0
  745. package/mssql-core/columns/datetime.cjs +94 -0
  746. package/mssql-core/columns/datetime.cjs.map +1 -0
  747. package/mssql-core/columns/datetime.d.cts +38 -0
  748. package/mssql-core/columns/datetime.d.ts +38 -0
  749. package/mssql-core/columns/datetime.js +66 -0
  750. package/mssql-core/columns/datetime.js.map +1 -0
  751. package/mssql-core/columns/datetime2.cjs +102 -0
  752. package/mssql-core/columns/datetime2.cjs.map +1 -0
  753. package/mssql-core/columns/datetime2.d.cts +38 -0
  754. package/mssql-core/columns/datetime2.d.ts +38 -0
  755. package/mssql-core/columns/datetime2.js +74 -0
  756. package/mssql-core/columns/datetime2.js.map +1 -0
  757. package/mssql-core/columns/datetimeoffset.cjs +102 -0
  758. package/mssql-core/columns/datetimeoffset.cjs.map +1 -0
  759. package/mssql-core/columns/datetimeoffset.d.cts +39 -0
  760. package/mssql-core/columns/datetimeoffset.d.ts +39 -0
  761. package/mssql-core/columns/datetimeoffset.js +74 -0
  762. package/mssql-core/columns/datetimeoffset.js.map +1 -0
  763. package/mssql-core/columns/decimal.cjs +146 -0
  764. package/mssql-core/columns/decimal.cjs.map +1 -0
  765. package/mssql-core/columns/decimal.d.cts +58 -0
  766. package/mssql-core/columns/decimal.d.ts +58 -0
  767. package/mssql-core/columns/decimal.js +116 -0
  768. package/mssql-core/columns/decimal.js.map +1 -0
  769. package/mssql-core/columns/float.cjs +58 -0
  770. package/mssql-core/columns/float.cjs.map +1 -0
  771. package/mssql-core/columns/float.d.cts +21 -0
  772. package/mssql-core/columns/float.d.ts +21 -0
  773. package/mssql-core/columns/float.js +32 -0
  774. package/mssql-core/columns/float.js.map +1 -0
  775. package/mssql-core/columns/index.cjs +63 -0
  776. package/mssql-core/columns/index.cjs.map +1 -0
  777. package/mssql-core/columns/index.d.cts +21 -0
  778. package/mssql-core/columns/index.d.ts +21 -0
  779. package/mssql-core/columns/index.js +22 -0
  780. package/mssql-core/columns/index.js.map +1 -0
  781. package/mssql-core/columns/int.cjs +53 -0
  782. package/mssql-core/columns/int.cjs.map +1 -0
  783. package/mssql-core/columns/int.d.cts +16 -0
  784. package/mssql-core/columns/int.d.ts +16 -0
  785. package/mssql-core/columns/int.js +27 -0
  786. package/mssql-core/columns/int.js.map +1 -0
  787. package/mssql-core/columns/numeric.cjs +146 -0
  788. package/mssql-core/columns/numeric.cjs.map +1 -0
  789. package/mssql-core/columns/numeric.d.cts +58 -0
  790. package/mssql-core/columns/numeric.d.ts +58 -0
  791. package/mssql-core/columns/numeric.js +116 -0
  792. package/mssql-core/columns/numeric.js.map +1 -0
  793. package/mssql-core/columns/real.cjs +53 -0
  794. package/mssql-core/columns/real.cjs.map +1 -0
  795. package/mssql-core/columns/real.d.cts +16 -0
  796. package/mssql-core/columns/real.d.ts +16 -0
  797. package/mssql-core/columns/real.js +27 -0
  798. package/mssql-core/columns/real.js.map +1 -0
  799. package/mssql-core/columns/smallint.cjs +62 -0
  800. package/mssql-core/columns/smallint.cjs.map +1 -0
  801. package/mssql-core/columns/smallint.d.cts +17 -0
  802. package/mssql-core/columns/smallint.d.ts +17 -0
  803. package/mssql-core/columns/smallint.js +36 -0
  804. package/mssql-core/columns/smallint.js.map +1 -0
  805. package/mssql-core/columns/text.cjs +68 -0
  806. package/mssql-core/columns/text.cjs.map +1 -0
  807. package/mssql-core/columns/text.d.cts +36 -0
  808. package/mssql-core/columns/text.d.ts +36 -0
  809. package/mssql-core/columns/text.js +41 -0
  810. package/mssql-core/columns/text.js.map +1 -0
  811. package/mssql-core/columns/time.cjs +90 -0
  812. package/mssql-core/columns/time.cjs.map +1 -0
  813. package/mssql-core/columns/time.d.cts +37 -0
  814. package/mssql-core/columns/time.d.ts +37 -0
  815. package/mssql-core/columns/time.js +62 -0
  816. package/mssql-core/columns/time.js.map +1 -0
  817. package/mssql-core/columns/tinyint.cjs +62 -0
  818. package/mssql-core/columns/tinyint.cjs.map +1 -0
  819. package/mssql-core/columns/tinyint.d.cts +17 -0
  820. package/mssql-core/columns/tinyint.d.ts +17 -0
  821. package/mssql-core/columns/tinyint.js +36 -0
  822. package/mssql-core/columns/tinyint.js.map +1 -0
  823. package/mssql-core/columns/varbinary.cjs +61 -0
  824. package/mssql-core/columns/varbinary.cjs.map +1 -0
  825. package/mssql-core/columns/varbinary.d.cts +23 -0
  826. package/mssql-core/columns/varbinary.d.ts +23 -0
  827. package/mssql-core/columns/varbinary.js +35 -0
  828. package/mssql-core/columns/varbinary.js.map +1 -0
  829. package/mssql-core/columns/varchar.cjs +117 -0
  830. package/mssql-core/columns/varchar.cjs.map +1 -0
  831. package/mssql-core/columns/varchar.d.cts +59 -0
  832. package/mssql-core/columns/varchar.d.ts +59 -0
  833. package/mssql-core/columns/varchar.js +88 -0
  834. package/mssql-core/columns/varchar.js.map +1 -0
  835. package/mssql-core/db.cjs +256 -0
  836. package/mssql-core/db.cjs.map +1 -0
  837. package/mssql-core/db.d.cts +228 -0
  838. package/mssql-core/db.d.ts +228 -0
  839. package/mssql-core/db.js +237 -0
  840. package/mssql-core/db.js.map +1 -0
  841. package/mssql-core/dialect.cjs +665 -0
  842. package/mssql-core/dialect.cjs.map +1 -0
  843. package/mssql-core/dialect.d.cts +58 -0
  844. package/mssql-core/dialect.d.ts +58 -0
  845. package/mssql-core/dialect.js +637 -0
  846. package/mssql-core/dialect.js.map +1 -0
  847. package/mssql-core/expressions.cjs +49 -0
  848. package/mssql-core/expressions.cjs.map +1 -0
  849. package/mssql-core/expressions.d.cts +8 -0
  850. package/mssql-core/expressions.d.ts +8 -0
  851. package/mssql-core/expressions.js +22 -0
  852. package/mssql-core/expressions.js.map +1 -0
  853. package/mssql-core/foreign-keys.cjs +94 -0
  854. package/mssql-core/foreign-keys.cjs.map +1 -0
  855. package/mssql-core/foreign-keys.d.cts +52 -0
  856. package/mssql-core/foreign-keys.d.ts +52 -0
  857. package/mssql-core/foreign-keys.js +68 -0
  858. package/mssql-core/foreign-keys.js.map +1 -0
  859. package/mssql-core/index.cjs +55 -0
  860. package/mssql-core/index.cjs.map +1 -0
  861. package/mssql-core/index.d.cts +17 -0
  862. package/mssql-core/index.d.ts +17 -0
  863. package/mssql-core/index.js +18 -0
  864. package/mssql-core/index.js.map +1 -0
  865. package/mssql-core/indexes.cjs +82 -0
  866. package/mssql-core/indexes.cjs.map +1 -0
  867. package/mssql-core/indexes.d.cts +50 -0
  868. package/mssql-core/indexes.d.ts +50 -0
  869. package/mssql-core/indexes.js +54 -0
  870. package/mssql-core/indexes.js.map +1 -0
  871. package/mssql-core/primary-keys.cjs +66 -0
  872. package/mssql-core/primary-keys.cjs.map +1 -0
  873. package/mssql-core/primary-keys.d.cts +24 -0
  874. package/mssql-core/primary-keys.d.ts +24 -0
  875. package/mssql-core/primary-keys.js +40 -0
  876. package/mssql-core/primary-keys.js.map +1 -0
  877. package/mssql-core/query-builders/delete.cjs +107 -0
  878. package/mssql-core/query-builders/delete.cjs.map +1 -0
  879. package/mssql-core/query-builders/delete.d.cts +98 -0
  880. package/mssql-core/query-builders/delete.d.ts +98 -0
  881. package/mssql-core/query-builders/delete.js +83 -0
  882. package/mssql-core/query-builders/delete.js.map +1 -0
  883. package/mssql-core/query-builders/index.cjs +33 -0
  884. package/mssql-core/query-builders/index.cjs.map +1 -0
  885. package/mssql-core/query-builders/index.d.cts +6 -0
  886. package/mssql-core/query-builders/index.d.ts +6 -0
  887. package/mssql-core/query-builders/index.js +7 -0
  888. package/mssql-core/query-builders/index.js.map +1 -0
  889. package/mssql-core/query-builders/insert.cjs +105 -0
  890. package/mssql-core/query-builders/insert.cjs.map +1 -0
  891. package/mssql-core/query-builders/insert.d.cts +79 -0
  892. package/mssql-core/query-builders/insert.d.ts +79 -0
  893. package/mssql-core/query-builders/insert.js +80 -0
  894. package/mssql-core/query-builders/insert.js.map +1 -0
  895. package/mssql-core/query-builders/query-builder.cjs +95 -0
  896. package/mssql-core/query-builders/query-builder.cjs.map +1 -0
  897. package/mssql-core/query-builders/query-builder.d.cts +32 -0
  898. package/mssql-core/query-builders/query-builder.d.ts +32 -0
  899. package/mssql-core/query-builders/query-builder.js +71 -0
  900. package/mssql-core/query-builders/query-builder.js.map +1 -0
  901. package/mssql-core/query-builders/query.cjs +126 -0
  902. package/mssql-core/query-builders/query.cjs.map +1 -0
  903. package/mssql-core/query-builders/query.d.cts +42 -0
  904. package/mssql-core/query-builders/query.d.ts +42 -0
  905. package/mssql-core/query-builders/query.js +103 -0
  906. package/mssql-core/query-builders/query.js.map +1 -0
  907. package/mssql-core/query-builders/select.cjs +678 -0
  908. package/mssql-core/query-builders/select.cjs.map +1 -0
  909. package/mssql-core/query-builders/select.d.cts +549 -0
  910. package/mssql-core/query-builders/select.d.ts +549 -0
  911. package/mssql-core/query-builders/select.js +654 -0
  912. package/mssql-core/query-builders/select.js.map +1 -0
  913. package/mssql-core/query-builders/select.types.cjs +17 -0
  914. package/mssql-core/query-builders/select.types.cjs.map +1 -0
  915. package/mssql-core/query-builders/select.types.d.cts +142 -0
  916. package/mssql-core/query-builders/select.types.d.ts +142 -0
  917. package/mssql-core/query-builders/select.types.js +1 -0
  918. package/mssql-core/query-builders/select.types.js.map +1 -0
  919. package/mssql-core/query-builders/update.cjs +138 -0
  920. package/mssql-core/query-builders/update.cjs.map +1 -0
  921. package/mssql-core/query-builders/update.d.cts +142 -0
  922. package/mssql-core/query-builders/update.d.ts +142 -0
  923. package/mssql-core/query-builders/update.js +113 -0
  924. package/mssql-core/query-builders/update.js.map +1 -0
  925. package/mssql-core/schema.cjs +53 -0
  926. package/mssql-core/schema.cjs.map +1 -0
  927. package/mssql-core/schema.d.cts +13 -0
  928. package/mssql-core/schema.d.ts +13 -0
  929. package/mssql-core/schema.js +28 -0
  930. package/mssql-core/schema.js.map +1 -0
  931. package/mssql-core/session.cjs +74 -0
  932. package/mssql-core/session.cjs.map +1 -0
  933. package/mssql-core/session.d.cts +63 -0
  934. package/mssql-core/session.d.ts +63 -0
  935. package/mssql-core/session.js +48 -0
  936. package/mssql-core/session.js.map +1 -0
  937. package/mssql-core/subquery.cjs +17 -0
  938. package/mssql-core/subquery.cjs.map +1 -0
  939. package/mssql-core/subquery.d.cts +18 -0
  940. package/mssql-core/subquery.d.ts +18 -0
  941. package/mssql-core/subquery.js +1 -0
  942. package/mssql-core/subquery.js.map +1 -0
  943. package/mssql-core/table.cjs +81 -0
  944. package/mssql-core/table.cjs.map +1 -0
  945. package/mssql-core/table.d.cts +40 -0
  946. package/mssql-core/table.d.ts +40 -0
  947. package/mssql-core/table.js +55 -0
  948. package/mssql-core/table.js.map +1 -0
  949. package/mssql-core/unique-constraint.cjs +78 -0
  950. package/mssql-core/unique-constraint.cjs.map +1 -0
  951. package/mssql-core/unique-constraint.d.cts +24 -0
  952. package/mssql-core/unique-constraint.d.ts +24 -0
  953. package/mssql-core/unique-constraint.js +51 -0
  954. package/mssql-core/unique-constraint.js.map +1 -0
  955. package/mssql-core/utils.cjs +85 -0
  956. package/mssql-core/utils.cjs.map +1 -0
  957. package/mssql-core/utils.d.cts +31 -0
  958. package/mssql-core/utils.d.ts +31 -0
  959. package/mssql-core/utils.js +60 -0
  960. package/mssql-core/utils.js.map +1 -0
  961. package/mssql-core/view-base.cjs +33 -0
  962. package/mssql-core/view-base.cjs.map +1 -0
  963. package/mssql-core/view-base.d.cts +9 -0
  964. package/mssql-core/view-base.d.ts +9 -0
  965. package/mssql-core/view-base.js +9 -0
  966. package/mssql-core/view-base.js.map +1 -0
  967. package/mssql-core/view-common.cjs +29 -0
  968. package/mssql-core/view-common.cjs.map +1 -0
  969. package/mssql-core/view-common.d.cts +1 -0
  970. package/mssql-core/view-common.d.ts +1 -0
  971. package/mssql-core/view-common.js +5 -0
  972. package/mssql-core/view-common.js.map +1 -0
  973. package/mssql-core/view.cjs +154 -0
  974. package/mssql-core/view.cjs.map +1 -0
  975. package/mssql-core/view.d.cts +63 -0
  976. package/mssql-core/view.d.ts +63 -0
  977. package/mssql-core/view.js +125 -0
  978. package/mssql-core/view.js.map +1 -0
  979. package/mysql-core/columns/all.cjs +6 -1
  980. package/mysql-core/columns/all.cjs.map +1 -1
  981. package/mysql-core/columns/all.d.cts +5 -0
  982. package/mysql-core/columns/all.d.ts +5 -0
  983. package/mysql-core/columns/all.js +6 -1
  984. package/mysql-core/columns/all.js.map +1 -1
  985. package/mysql-core/columns/bigint.cjs.map +1 -1
  986. package/mysql-core/columns/bigint.d.cts +0 -3
  987. package/mysql-core/columns/bigint.d.ts +0 -3
  988. package/mysql-core/columns/bigint.js.map +1 -1
  989. package/mysql-core/columns/binary.cjs +0 -1
  990. package/mysql-core/columns/binary.cjs.map +1 -1
  991. package/mysql-core/columns/binary.d.cts +0 -2
  992. package/mysql-core/columns/binary.d.ts +0 -2
  993. package/mysql-core/columns/binary.js +0 -1
  994. package/mysql-core/columns/binary.js.map +1 -1
  995. package/mysql-core/columns/blob.cjs +158 -0
  996. package/mysql-core/columns/blob.cjs.map +1 -0
  997. package/mysql-core/columns/blob.d.cts +54 -0
  998. package/mysql-core/columns/blob.d.ts +54 -0
  999. package/mysql-core/columns/blob.js +127 -0
  1000. package/mysql-core/columns/blob.js.map +1 -0
  1001. package/mysql-core/columns/boolean.cjs.map +1 -1
  1002. package/mysql-core/columns/boolean.d.cts +0 -1
  1003. package/mysql-core/columns/boolean.d.ts +0 -1
  1004. package/mysql-core/columns/boolean.js.map +1 -1
  1005. package/mysql-core/columns/char.cjs +3 -4
  1006. package/mysql-core/columns/char.cjs.map +1 -1
  1007. package/mysql-core/columns/char.d.cts +3 -5
  1008. package/mysql-core/columns/char.d.ts +3 -5
  1009. package/mysql-core/columns/char.js +3 -4
  1010. package/mysql-core/columns/char.js.map +1 -1
  1011. package/mysql-core/columns/common.cjs +0 -4
  1012. package/mysql-core/columns/common.cjs.map +1 -1
  1013. package/mysql-core/columns/common.d.cts +1 -1
  1014. package/mysql-core/columns/common.d.ts +1 -1
  1015. package/mysql-core/columns/common.js +0 -4
  1016. package/mysql-core/columns/common.js.map +1 -1
  1017. package/mysql-core/columns/custom.cjs.map +1 -1
  1018. package/mysql-core/columns/custom.d.cts +0 -1
  1019. package/mysql-core/columns/custom.d.ts +0 -1
  1020. package/mysql-core/columns/custom.js.map +1 -1
  1021. package/mysql-core/columns/date.cjs.map +1 -1
  1022. package/mysql-core/columns/date.common.cjs +3 -1
  1023. package/mysql-core/columns/date.common.cjs.map +1 -1
  1024. package/mysql-core/columns/date.common.d.cts +6 -1
  1025. package/mysql-core/columns/date.common.d.ts +6 -1
  1026. package/mysql-core/columns/date.common.js +3 -1
  1027. package/mysql-core/columns/date.common.js.map +1 -1
  1028. package/mysql-core/columns/date.d.cts +0 -2
  1029. package/mysql-core/columns/date.d.ts +0 -2
  1030. package/mysql-core/columns/date.js.map +1 -1
  1031. package/mysql-core/columns/datetime.cjs.map +1 -1
  1032. package/mysql-core/columns/datetime.d.cts +0 -2
  1033. package/mysql-core/columns/datetime.d.ts +0 -2
  1034. package/mysql-core/columns/datetime.js.map +1 -1
  1035. package/mysql-core/columns/decimal.cjs.map +1 -1
  1036. package/mysql-core/columns/decimal.d.cts +0 -3
  1037. package/mysql-core/columns/decimal.d.ts +0 -3
  1038. package/mysql-core/columns/decimal.js.map +1 -1
  1039. package/mysql-core/columns/double.cjs.map +1 -1
  1040. package/mysql-core/columns/double.d.cts +0 -1
  1041. package/mysql-core/columns/double.d.ts +0 -1
  1042. package/mysql-core/columns/double.js.map +1 -1
  1043. package/mysql-core/columns/enum.cjs +5 -5
  1044. package/mysql-core/columns/enum.cjs.map +1 -1
  1045. package/mysql-core/columns/enum.d.cts +5 -7
  1046. package/mysql-core/columns/enum.d.ts +5 -7
  1047. package/mysql-core/columns/enum.js +5 -5
  1048. package/mysql-core/columns/enum.js.map +1 -1
  1049. package/mysql-core/columns/float.cjs.map +1 -1
  1050. package/mysql-core/columns/float.d.cts +0 -1
  1051. package/mysql-core/columns/float.d.ts +0 -1
  1052. package/mysql-core/columns/float.js.map +1 -1
  1053. package/mysql-core/columns/index.cjs +2 -0
  1054. package/mysql-core/columns/index.cjs.map +1 -1
  1055. package/mysql-core/columns/index.d.cts +1 -0
  1056. package/mysql-core/columns/index.d.ts +1 -0
  1057. package/mysql-core/columns/index.js +1 -0
  1058. package/mysql-core/columns/index.js.map +1 -1
  1059. package/mysql-core/columns/int.cjs.map +1 -1
  1060. package/mysql-core/columns/int.d.cts +0 -1
  1061. package/mysql-core/columns/int.d.ts +0 -1
  1062. package/mysql-core/columns/int.js.map +1 -1
  1063. package/mysql-core/columns/json.cjs.map +1 -1
  1064. package/mysql-core/columns/json.d.cts +0 -1
  1065. package/mysql-core/columns/json.d.ts +0 -1
  1066. package/mysql-core/columns/json.js.map +1 -1
  1067. package/mysql-core/columns/mediumint.cjs.map +1 -1
  1068. package/mysql-core/columns/mediumint.d.cts +0 -1
  1069. package/mysql-core/columns/mediumint.d.ts +0 -1
  1070. package/mysql-core/columns/mediumint.js.map +1 -1
  1071. package/mysql-core/columns/real.cjs.map +1 -1
  1072. package/mysql-core/columns/real.d.cts +0 -1
  1073. package/mysql-core/columns/real.d.ts +0 -1
  1074. package/mysql-core/columns/real.js.map +1 -1
  1075. package/mysql-core/columns/serial.cjs.map +1 -1
  1076. package/mysql-core/columns/serial.d.cts +0 -1
  1077. package/mysql-core/columns/serial.d.ts +0 -1
  1078. package/mysql-core/columns/serial.js.map +1 -1
  1079. package/mysql-core/columns/smallint.cjs.map +1 -1
  1080. package/mysql-core/columns/smallint.d.cts +0 -1
  1081. package/mysql-core/columns/smallint.d.ts +0 -1
  1082. package/mysql-core/columns/smallint.js.map +1 -1
  1083. package/mysql-core/columns/string.common.cjs +48 -0
  1084. package/mysql-core/columns/string.common.cjs.map +1 -0
  1085. package/mysql-core/columns/string.common.d.cts +21 -0
  1086. package/mysql-core/columns/string.common.d.ts +21 -0
  1087. package/mysql-core/columns/string.common.js +23 -0
  1088. package/mysql-core/columns/string.common.js.map +1 -0
  1089. package/mysql-core/columns/text.cjs +3 -3
  1090. package/mysql-core/columns/text.cjs.map +1 -1
  1091. package/mysql-core/columns/text.d.cts +3 -4
  1092. package/mysql-core/columns/text.d.ts +3 -4
  1093. package/mysql-core/columns/text.js +3 -3
  1094. package/mysql-core/columns/text.js.map +1 -1
  1095. package/mysql-core/columns/time.cjs.map +1 -1
  1096. package/mysql-core/columns/time.d.cts +0 -1
  1097. package/mysql-core/columns/time.d.ts +0 -1
  1098. package/mysql-core/columns/time.js.map +1 -1
  1099. package/mysql-core/columns/timestamp.cjs.map +1 -1
  1100. package/mysql-core/columns/timestamp.d.cts +0 -2
  1101. package/mysql-core/columns/timestamp.d.ts +0 -2
  1102. package/mysql-core/columns/timestamp.js.map +1 -1
  1103. package/mysql-core/columns/tinyint.cjs.map +1 -1
  1104. package/mysql-core/columns/tinyint.d.cts +0 -1
  1105. package/mysql-core/columns/tinyint.d.ts +0 -1
  1106. package/mysql-core/columns/tinyint.js.map +1 -1
  1107. package/mysql-core/columns/varbinary.cjs.map +1 -1
  1108. package/mysql-core/columns/varbinary.d.cts +0 -1
  1109. package/mysql-core/columns/varbinary.d.ts +0 -1
  1110. package/mysql-core/columns/varbinary.js.map +1 -1
  1111. package/mysql-core/columns/varchar.cjs +4 -4
  1112. package/mysql-core/columns/varchar.cjs.map +1 -1
  1113. package/mysql-core/columns/varchar.d.cts +4 -5
  1114. package/mysql-core/columns/varchar.d.ts +4 -5
  1115. package/mysql-core/columns/varchar.js +4 -4
  1116. package/mysql-core/columns/varchar.js.map +1 -1
  1117. package/mysql-core/columns/year.cjs.map +1 -1
  1118. package/mysql-core/columns/year.d.cts +0 -1
  1119. package/mysql-core/columns/year.d.ts +0 -1
  1120. package/mysql-core/columns/year.js.map +1 -1
  1121. package/mysql-core/dialect.cjs +7 -2
  1122. package/mysql-core/dialect.cjs.map +1 -1
  1123. package/mysql-core/dialect.d.cts +1 -0
  1124. package/mysql-core/dialect.d.ts +1 -0
  1125. package/mysql-core/dialect.js +14 -3
  1126. package/mysql-core/dialect.js.map +1 -1
  1127. package/mysql-core/foreign-keys.cjs +3 -0
  1128. package/mysql-core/foreign-keys.cjs.map +1 -1
  1129. package/mysql-core/foreign-keys.d.cts +1 -0
  1130. package/mysql-core/foreign-keys.d.ts +1 -0
  1131. package/mysql-core/foreign-keys.js +3 -0
  1132. package/mysql-core/foreign-keys.js.map +1 -1
  1133. package/mysql-core/indexes.cjs +2 -0
  1134. package/mysql-core/indexes.cjs.map +1 -1
  1135. package/mysql-core/indexes.d.cts +1 -0
  1136. package/mysql-core/indexes.d.ts +1 -0
  1137. package/mysql-core/indexes.js +2 -0
  1138. package/mysql-core/indexes.js.map +1 -1
  1139. package/mysql-core/primary-keys.cjs +4 -13
  1140. package/mysql-core/primary-keys.cjs.map +1 -1
  1141. package/mysql-core/primary-keys.d.cts +3 -6
  1142. package/mysql-core/primary-keys.d.ts +3 -6
  1143. package/mysql-core/primary-keys.js +4 -13
  1144. package/mysql-core/primary-keys.js.map +1 -1
  1145. package/mysql-core/query-builders/count.cjs.map +1 -1
  1146. package/mysql-core/query-builders/count.d.cts +1 -1
  1147. package/mysql-core/query-builders/count.d.ts +1 -1
  1148. package/mysql-core/query-builders/count.js.map +1 -1
  1149. package/mysql-core/query-builders/insert.cjs.map +1 -1
  1150. package/mysql-core/query-builders/insert.d.cts +2 -2
  1151. package/mysql-core/query-builders/insert.d.ts +2 -2
  1152. package/mysql-core/query-builders/insert.js.map +1 -1
  1153. package/mysql-core/query-builders/update.cjs.map +1 -1
  1154. package/mysql-core/query-builders/update.d.cts +1 -1
  1155. package/mysql-core/query-builders/update.d.ts +1 -1
  1156. package/mysql-core/query-builders/update.js.map +1 -1
  1157. package/mysql-core/unique-constraint.cjs +2 -0
  1158. package/mysql-core/unique-constraint.cjs.map +1 -1
  1159. package/mysql-core/unique-constraint.d.cts +3 -2
  1160. package/mysql-core/unique-constraint.d.ts +3 -2
  1161. package/mysql-core/unique-constraint.js +2 -0
  1162. package/mysql-core/unique-constraint.js.map +1 -1
  1163. package/mysql-proxy/driver.cjs +2 -2
  1164. package/mysql-proxy/driver.cjs.map +1 -1
  1165. package/mysql-proxy/driver.d.cts +2 -1
  1166. package/mysql-proxy/driver.d.ts +2 -1
  1167. package/mysql-proxy/driver.js +2 -2
  1168. package/mysql-proxy/driver.js.map +1 -1
  1169. package/mysql2/driver.cjs +10 -14
  1170. package/mysql2/driver.cjs.map +1 -1
  1171. package/mysql2/driver.d.cts +3 -3
  1172. package/mysql2/driver.d.ts +3 -3
  1173. package/mysql2/driver.js +10 -14
  1174. package/mysql2/driver.js.map +1 -1
  1175. package/mysql2/session.cjs.map +1 -1
  1176. package/mysql2/session.js.map +1 -1
  1177. package/neon-http/driver.cjs +10 -14
  1178. package/neon-http/driver.cjs.map +1 -1
  1179. package/neon-http/driver.d.cts +3 -3
  1180. package/neon-http/driver.d.ts +3 -3
  1181. package/neon-http/driver.js +10 -14
  1182. package/neon-http/driver.js.map +1 -1
  1183. package/neon-http/session.cjs.map +1 -1
  1184. package/neon-http/session.d.cts +1 -1
  1185. package/neon-http/session.d.ts +1 -1
  1186. package/neon-http/session.js.map +1 -1
  1187. package/neon-serverless/driver.cjs +10 -14
  1188. package/neon-serverless/driver.cjs.map +1 -1
  1189. package/neon-serverless/driver.d.cts +3 -3
  1190. package/neon-serverless/driver.d.ts +3 -3
  1191. package/neon-serverless/driver.js +10 -14
  1192. package/neon-serverless/driver.js.map +1 -1
  1193. package/neon-serverless/session.cjs.map +1 -1
  1194. package/neon-serverless/session.js.map +1 -1
  1195. package/node-mssql/driver.cjs +129 -0
  1196. package/node-mssql/driver.cjs.map +1 -0
  1197. package/node-mssql/driver.d.cts +48 -0
  1198. package/node-mssql/driver.d.ts +48 -0
  1199. package/node-mssql/driver.js +92 -0
  1200. package/node-mssql/driver.js.map +1 -0
  1201. package/node-mssql/index.cjs +25 -0
  1202. package/node-mssql/index.cjs.map +1 -0
  1203. package/node-mssql/index.d.cts +2 -0
  1204. package/node-mssql/index.d.ts +2 -0
  1205. package/node-mssql/index.js +3 -0
  1206. package/node-mssql/index.js.map +1 -0
  1207. package/node-mssql/migrator.cjs +33 -0
  1208. package/node-mssql/migrator.cjs.map +1 -0
  1209. package/node-mssql/migrator.d.cts +3 -0
  1210. package/node-mssql/migrator.d.ts +3 -0
  1211. package/node-mssql/migrator.js +9 -0
  1212. package/node-mssql/migrator.js.map +1 -0
  1213. package/node-mssql/pool.cjs +54 -0
  1214. package/node-mssql/pool.cjs.map +1 -0
  1215. package/node-mssql/pool.d.cts +8 -0
  1216. package/node-mssql/pool.d.ts +8 -0
  1217. package/node-mssql/pool.js +20 -0
  1218. package/node-mssql/pool.js.map +1 -0
  1219. package/node-mssql/session.cjs +256 -0
  1220. package/node-mssql/session.cjs.map +1 -0
  1221. package/node-mssql/session.d.cts +48 -0
  1222. package/node-mssql/session.d.ts +48 -0
  1223. package/node-mssql/session.js +224 -0
  1224. package/node-mssql/session.js.map +1 -0
  1225. package/node-postgres/driver.cjs +8 -12
  1226. package/node-postgres/driver.cjs.map +1 -1
  1227. package/node-postgres/driver.d.cts +3 -3
  1228. package/node-postgres/driver.d.ts +3 -3
  1229. package/node-postgres/driver.js +8 -12
  1230. package/node-postgres/driver.js.map +1 -1
  1231. package/node-postgres/session.cjs.map +1 -1
  1232. package/node-postgres/session.js.map +1 -1
  1233. package/op-sqlite/migrator.cjs +10 -7
  1234. package/op-sqlite/migrator.cjs.map +1 -1
  1235. package/op-sqlite/migrator.d.cts +0 -16
  1236. package/op-sqlite/migrator.d.ts +0 -16
  1237. package/op-sqlite/migrator.js +10 -7
  1238. package/op-sqlite/migrator.js.map +1 -1
  1239. package/package.json +1498 -20
  1240. package/pg-core/columns/bigint.cjs.map +1 -1
  1241. package/pg-core/columns/bigint.d.cts +0 -3
  1242. package/pg-core/columns/bigint.d.ts +0 -3
  1243. package/pg-core/columns/bigint.js.map +1 -1
  1244. package/pg-core/columns/bigserial.cjs +1 -0
  1245. package/pg-core/columns/bigserial.cjs.map +1 -1
  1246. package/pg-core/columns/bigserial.d.cts +0 -2
  1247. package/pg-core/columns/bigserial.d.ts +0 -2
  1248. package/pg-core/columns/bigserial.js +1 -0
  1249. package/pg-core/columns/bigserial.js.map +1 -1
  1250. package/pg-core/columns/boolean.cjs.map +1 -1
  1251. package/pg-core/columns/boolean.d.cts +0 -1
  1252. package/pg-core/columns/boolean.d.ts +0 -1
  1253. package/pg-core/columns/boolean.js.map +1 -1
  1254. package/pg-core/columns/bytea.cjs.map +1 -1
  1255. package/pg-core/columns/bytea.d.cts +0 -1
  1256. package/pg-core/columns/bytea.d.ts +0 -1
  1257. package/pg-core/columns/bytea.js.map +1 -1
  1258. package/pg-core/columns/char.cjs +0 -1
  1259. package/pg-core/columns/char.cjs.map +1 -1
  1260. package/pg-core/columns/char.d.cts +0 -2
  1261. package/pg-core/columns/char.d.ts +0 -2
  1262. package/pg-core/columns/char.js +0 -1
  1263. package/pg-core/columns/char.js.map +1 -1
  1264. package/pg-core/columns/cidr.cjs.map +1 -1
  1265. package/pg-core/columns/cidr.d.cts +0 -1
  1266. package/pg-core/columns/cidr.d.ts +0 -1
  1267. package/pg-core/columns/cidr.js.map +1 -1
  1268. package/pg-core/columns/common.cjs +10 -14
  1269. package/pg-core/columns/common.cjs.map +1 -1
  1270. package/pg-core/columns/common.d.cts +4 -3
  1271. package/pg-core/columns/common.d.ts +4 -3
  1272. package/pg-core/columns/common.js +10 -14
  1273. package/pg-core/columns/common.js.map +1 -1
  1274. package/pg-core/columns/custom.cjs.map +1 -1
  1275. package/pg-core/columns/custom.d.cts +0 -1
  1276. package/pg-core/columns/custom.d.ts +0 -1
  1277. package/pg-core/columns/custom.js.map +1 -1
  1278. package/pg-core/columns/date.cjs.map +1 -1
  1279. package/pg-core/columns/date.d.cts +0 -2
  1280. package/pg-core/columns/date.d.ts +0 -2
  1281. package/pg-core/columns/date.js.map +1 -1
  1282. package/pg-core/columns/double-precision.cjs.map +1 -1
  1283. package/pg-core/columns/double-precision.d.cts +0 -1
  1284. package/pg-core/columns/double-precision.d.ts +0 -1
  1285. package/pg-core/columns/double-precision.js.map +1 -1
  1286. package/pg-core/columns/enum.cjs.map +1 -1
  1287. package/pg-core/columns/enum.d.cts +0 -2
  1288. package/pg-core/columns/enum.d.ts +0 -2
  1289. package/pg-core/columns/enum.js.map +1 -1
  1290. package/pg-core/columns/inet.cjs.map +1 -1
  1291. package/pg-core/columns/inet.d.cts +0 -1
  1292. package/pg-core/columns/inet.d.ts +0 -1
  1293. package/pg-core/columns/inet.js.map +1 -1
  1294. package/pg-core/columns/integer.cjs.map +1 -1
  1295. package/pg-core/columns/integer.d.cts +0 -1
  1296. package/pg-core/columns/integer.d.ts +0 -1
  1297. package/pg-core/columns/integer.js.map +1 -1
  1298. package/pg-core/columns/interval.cjs.map +1 -1
  1299. package/pg-core/columns/interval.d.cts +0 -1
  1300. package/pg-core/columns/interval.d.ts +0 -1
  1301. package/pg-core/columns/interval.js.map +1 -1
  1302. package/pg-core/columns/json.cjs.map +1 -1
  1303. package/pg-core/columns/json.d.cts +0 -1
  1304. package/pg-core/columns/json.d.ts +0 -1
  1305. package/pg-core/columns/json.js.map +1 -1
  1306. package/pg-core/columns/jsonb.cjs.map +1 -1
  1307. package/pg-core/columns/jsonb.d.cts +0 -1
  1308. package/pg-core/columns/jsonb.d.ts +0 -1
  1309. package/pg-core/columns/jsonb.js.map +1 -1
  1310. package/pg-core/columns/line.cjs +2 -0
  1311. package/pg-core/columns/line.cjs.map +1 -1
  1312. package/pg-core/columns/line.d.cts +2 -2
  1313. package/pg-core/columns/line.d.ts +2 -2
  1314. package/pg-core/columns/line.js +2 -0
  1315. package/pg-core/columns/line.js.map +1 -1
  1316. package/pg-core/columns/macaddr.cjs.map +1 -1
  1317. package/pg-core/columns/macaddr.d.cts +0 -1
  1318. package/pg-core/columns/macaddr.d.ts +0 -1
  1319. package/pg-core/columns/macaddr.js.map +1 -1
  1320. package/pg-core/columns/macaddr8.cjs.map +1 -1
  1321. package/pg-core/columns/macaddr8.d.cts +0 -1
  1322. package/pg-core/columns/macaddr8.d.ts +0 -1
  1323. package/pg-core/columns/macaddr8.js.map +1 -1
  1324. package/pg-core/columns/numeric.cjs.map +1 -1
  1325. package/pg-core/columns/numeric.d.cts +0 -3
  1326. package/pg-core/columns/numeric.d.ts +0 -3
  1327. package/pg-core/columns/numeric.js.map +1 -1
  1328. package/pg-core/columns/point.cjs +2 -0
  1329. package/pg-core/columns/point.cjs.map +1 -1
  1330. package/pg-core/columns/point.d.cts +2 -2
  1331. package/pg-core/columns/point.d.ts +2 -2
  1332. package/pg-core/columns/point.js +2 -0
  1333. package/pg-core/columns/point.js.map +1 -1
  1334. package/pg-core/columns/postgis_extension/geometry.cjs +14 -8
  1335. package/pg-core/columns/postgis_extension/geometry.cjs.map +1 -1
  1336. package/pg-core/columns/postgis_extension/geometry.d.cts +16 -6
  1337. package/pg-core/columns/postgis_extension/geometry.d.ts +16 -6
  1338. package/pg-core/columns/postgis_extension/geometry.js +14 -8
  1339. package/pg-core/columns/postgis_extension/geometry.js.map +1 -1
  1340. package/pg-core/columns/postgis_extension/utils.cjs +3 -3
  1341. package/pg-core/columns/postgis_extension/utils.cjs.map +1 -1
  1342. package/pg-core/columns/postgis_extension/utils.d.cts +4 -1
  1343. package/pg-core/columns/postgis_extension/utils.d.ts +4 -1
  1344. package/pg-core/columns/postgis_extension/utils.js +3 -3
  1345. package/pg-core/columns/postgis_extension/utils.js.map +1 -1
  1346. package/pg-core/columns/real.cjs.map +1 -1
  1347. package/pg-core/columns/real.d.cts +0 -1
  1348. package/pg-core/columns/real.d.ts +0 -1
  1349. package/pg-core/columns/real.js.map +1 -1
  1350. package/pg-core/columns/serial.cjs.map +1 -1
  1351. package/pg-core/columns/serial.d.cts +0 -1
  1352. package/pg-core/columns/serial.d.ts +0 -1
  1353. package/pg-core/columns/serial.js.map +1 -1
  1354. package/pg-core/columns/smallint.cjs.map +1 -1
  1355. package/pg-core/columns/smallint.d.cts +0 -1
  1356. package/pg-core/columns/smallint.d.ts +0 -1
  1357. package/pg-core/columns/smallint.js.map +1 -1
  1358. package/pg-core/columns/smallserial.cjs.map +1 -1
  1359. package/pg-core/columns/smallserial.d.cts +0 -1
  1360. package/pg-core/columns/smallserial.d.ts +0 -1
  1361. package/pg-core/columns/smallserial.js.map +1 -1
  1362. package/pg-core/columns/text.cjs.map +1 -1
  1363. package/pg-core/columns/text.d.cts +0 -1
  1364. package/pg-core/columns/text.d.ts +0 -1
  1365. package/pg-core/columns/text.js.map +1 -1
  1366. package/pg-core/columns/time.cjs.map +1 -1
  1367. package/pg-core/columns/time.d.cts +0 -1
  1368. package/pg-core/columns/time.d.ts +0 -1
  1369. package/pg-core/columns/time.js.map +1 -1
  1370. package/pg-core/columns/timestamp.cjs.map +1 -1
  1371. package/pg-core/columns/timestamp.d.cts +0 -2
  1372. package/pg-core/columns/timestamp.d.ts +0 -2
  1373. package/pg-core/columns/timestamp.js.map +1 -1
  1374. package/pg-core/columns/uuid.cjs.map +1 -1
  1375. package/pg-core/columns/uuid.d.cts +0 -1
  1376. package/pg-core/columns/uuid.d.ts +0 -1
  1377. package/pg-core/columns/uuid.js.map +1 -1
  1378. package/pg-core/columns/varchar.cjs.map +1 -1
  1379. package/pg-core/columns/varchar.d.cts +0 -1
  1380. package/pg-core/columns/varchar.d.ts +0 -1
  1381. package/pg-core/columns/varchar.js.map +1 -1
  1382. package/pg-core/columns/vector_extension/bit.cjs.map +1 -1
  1383. package/pg-core/columns/vector_extension/bit.d.cts +0 -1
  1384. package/pg-core/columns/vector_extension/bit.d.ts +0 -1
  1385. package/pg-core/columns/vector_extension/bit.js.map +1 -1
  1386. package/pg-core/columns/vector_extension/halfvec.cjs.map +1 -1
  1387. package/pg-core/columns/vector_extension/halfvec.d.cts +0 -1
  1388. package/pg-core/columns/vector_extension/halfvec.d.ts +0 -1
  1389. package/pg-core/columns/vector_extension/halfvec.js.map +1 -1
  1390. package/pg-core/columns/vector_extension/sparsevec.cjs.map +1 -1
  1391. package/pg-core/columns/vector_extension/sparsevec.d.cts +0 -1
  1392. package/pg-core/columns/vector_extension/sparsevec.d.ts +0 -1
  1393. package/pg-core/columns/vector_extension/sparsevec.js.map +1 -1
  1394. package/pg-core/columns/vector_extension/vector.cjs.map +1 -1
  1395. package/pg-core/columns/vector_extension/vector.d.cts +0 -1
  1396. package/pg-core/columns/vector_extension/vector.d.ts +0 -1
  1397. package/pg-core/columns/vector_extension/vector.js.map +1 -1
  1398. package/pg-core/dialect.cjs +4 -2
  1399. package/pg-core/dialect.cjs.map +1 -1
  1400. package/pg-core/dialect.js +11 -3
  1401. package/pg-core/dialect.js.map +1 -1
  1402. package/pg-core/foreign-keys.cjs +4 -0
  1403. package/pg-core/foreign-keys.cjs.map +1 -1
  1404. package/pg-core/foreign-keys.d.cts +2 -0
  1405. package/pg-core/foreign-keys.d.ts +2 -0
  1406. package/pg-core/foreign-keys.js +4 -0
  1407. package/pg-core/foreign-keys.js.map +1 -1
  1408. package/pg-core/indexes.cjs +2 -0
  1409. package/pg-core/indexes.cjs.map +1 -1
  1410. package/pg-core/indexes.d.cts +1 -0
  1411. package/pg-core/indexes.d.ts +1 -0
  1412. package/pg-core/indexes.js +2 -0
  1413. package/pg-core/indexes.js.map +1 -1
  1414. package/pg-core/primary-keys.cjs +2 -0
  1415. package/pg-core/primary-keys.cjs.map +1 -1
  1416. package/pg-core/primary-keys.d.cts +1 -0
  1417. package/pg-core/primary-keys.d.ts +1 -0
  1418. package/pg-core/primary-keys.js +2 -0
  1419. package/pg-core/primary-keys.js.map +1 -1
  1420. package/pg-core/query-builders/count.cjs.map +1 -1
  1421. package/pg-core/query-builders/count.d.cts +4 -3
  1422. package/pg-core/query-builders/count.d.ts +4 -3
  1423. package/pg-core/query-builders/count.js.map +1 -1
  1424. package/pg-core/query-builders/insert.cjs.map +1 -1
  1425. package/pg-core/query-builders/insert.d.cts +6 -9
  1426. package/pg-core/query-builders/insert.d.ts +6 -9
  1427. package/pg-core/query-builders/insert.js.map +1 -1
  1428. package/pg-core/query-builders/select.cjs +6 -7
  1429. package/pg-core/query-builders/select.cjs.map +1 -1
  1430. package/pg-core/query-builders/select.js +2 -2
  1431. package/pg-core/query-builders/select.js.map +1 -1
  1432. package/pg-core/query-builders/update.cjs.map +1 -1
  1433. package/pg-core/query-builders/update.d.cts +1 -1
  1434. package/pg-core/query-builders/update.d.ts +1 -1
  1435. package/pg-core/query-builders/update.js.map +1 -1
  1436. package/pg-core/schema.cjs +12 -0
  1437. package/pg-core/schema.cjs.map +1 -1
  1438. package/pg-core/schema.d.cts +2 -0
  1439. package/pg-core/schema.d.ts +2 -0
  1440. package/pg-core/schema.js +13 -1
  1441. package/pg-core/schema.js.map +1 -1
  1442. package/pg-core/table.cjs +15 -2
  1443. package/pg-core/table.cjs.map +1 -1
  1444. package/pg-core/table.d.cts +5 -1
  1445. package/pg-core/table.d.ts +5 -1
  1446. package/pg-core/table.js +15 -2
  1447. package/pg-core/table.js.map +1 -1
  1448. package/pg-core/unique-constraint.cjs +2 -0
  1449. package/pg-core/unique-constraint.cjs.map +1 -1
  1450. package/pg-core/unique-constraint.d.cts +1 -0
  1451. package/pg-core/unique-constraint.d.ts +1 -0
  1452. package/pg-core/unique-constraint.js +2 -0
  1453. package/pg-core/unique-constraint.js.map +1 -1
  1454. package/pg-core/utils.cjs +1 -2
  1455. package/pg-core/utils.cjs.map +1 -1
  1456. package/pg-core/utils.d.cts +1 -1
  1457. package/pg-core/utils.d.ts +1 -1
  1458. package/pg-core/utils.js +1 -2
  1459. package/pg-core/utils.js.map +1 -1
  1460. package/pg-core/view-common.cjs +3 -0
  1461. package/pg-core/view-common.cjs.map +1 -1
  1462. package/pg-core/view-common.d.cts +1 -0
  1463. package/pg-core/view-common.d.ts +1 -0
  1464. package/pg-core/view-common.js +2 -0
  1465. package/pg-core/view-common.js.map +1 -1
  1466. package/pg-core/view.cjs +2 -5
  1467. package/pg-core/view.cjs.map +1 -1
  1468. package/pg-core/view.d.cts +1 -2
  1469. package/pg-core/view.d.ts +1 -2
  1470. package/pg-core/view.js +1 -3
  1471. package/pg-core/view.js.map +1 -1
  1472. package/pglite/driver.cjs +10 -14
  1473. package/pglite/driver.cjs.map +1 -1
  1474. package/pglite/driver.d.cts +3 -3
  1475. package/pglite/driver.d.ts +3 -3
  1476. package/pglite/driver.js +10 -14
  1477. package/pglite/driver.js.map +1 -1
  1478. package/planetscale-serverless/driver.cjs +11 -15
  1479. package/planetscale-serverless/driver.cjs.map +1 -1
  1480. package/planetscale-serverless/driver.d.cts +3 -3
  1481. package/planetscale-serverless/driver.d.ts +3 -3
  1482. package/planetscale-serverless/driver.js +11 -15
  1483. package/planetscale-serverless/driver.js.map +1 -1
  1484. package/postgres-js/driver.cjs +10 -14
  1485. package/postgres-js/driver.cjs.map +1 -1
  1486. package/postgres-js/driver.d.cts +3 -3
  1487. package/postgres-js/driver.d.ts +3 -3
  1488. package/postgres-js/driver.js +10 -14
  1489. package/postgres-js/driver.js.map +1 -1
  1490. package/relations.cjs +2 -0
  1491. package/relations.cjs.map +1 -1
  1492. package/relations.d.cts +3 -3
  1493. package/relations.d.ts +3 -3
  1494. package/relations.js +3 -1
  1495. package/relations.js.map +1 -1
  1496. package/selection-proxy.cjs +4 -3
  1497. package/selection-proxy.cjs.map +1 -1
  1498. package/selection-proxy.js +5 -4
  1499. package/selection-proxy.js.map +1 -1
  1500. package/singlestore/driver.cjs +19 -26
  1501. package/singlestore/driver.cjs.map +1 -1
  1502. package/singlestore/driver.d.cts +3 -3
  1503. package/singlestore/driver.d.ts +3 -3
  1504. package/singlestore/driver.js +19 -26
  1505. package/singlestore/driver.js.map +1 -1
  1506. package/singlestore/session.cjs.map +1 -1
  1507. package/singlestore/session.js.map +1 -1
  1508. package/singlestore-core/columns/bigint.cjs.map +1 -1
  1509. package/singlestore-core/columns/bigint.d.cts +0 -3
  1510. package/singlestore-core/columns/bigint.d.ts +0 -3
  1511. package/singlestore-core/columns/bigint.js.map +1 -1
  1512. package/singlestore-core/columns/binary.cjs +0 -1
  1513. package/singlestore-core/columns/binary.cjs.map +1 -1
  1514. package/singlestore-core/columns/binary.d.cts +0 -2
  1515. package/singlestore-core/columns/binary.d.ts +0 -2
  1516. package/singlestore-core/columns/binary.js +0 -1
  1517. package/singlestore-core/columns/binary.js.map +1 -1
  1518. package/singlestore-core/columns/boolean.cjs.map +1 -1
  1519. package/singlestore-core/columns/boolean.d.cts +0 -1
  1520. package/singlestore-core/columns/boolean.d.ts +0 -1
  1521. package/singlestore-core/columns/boolean.js.map +1 -1
  1522. package/singlestore-core/columns/char.cjs +0 -1
  1523. package/singlestore-core/columns/char.cjs.map +1 -1
  1524. package/singlestore-core/columns/char.d.cts +0 -2
  1525. package/singlestore-core/columns/char.d.ts +0 -2
  1526. package/singlestore-core/columns/char.js +0 -1
  1527. package/singlestore-core/columns/char.js.map +1 -1
  1528. package/singlestore-core/columns/common.cjs +0 -4
  1529. package/singlestore-core/columns/common.cjs.map +1 -1
  1530. package/singlestore-core/columns/common.d.cts +1 -1
  1531. package/singlestore-core/columns/common.d.ts +1 -1
  1532. package/singlestore-core/columns/common.js +0 -4
  1533. package/singlestore-core/columns/common.js.map +1 -1
  1534. package/singlestore-core/columns/custom.cjs.map +1 -1
  1535. package/singlestore-core/columns/custom.d.cts +0 -1
  1536. package/singlestore-core/columns/custom.d.ts +0 -1
  1537. package/singlestore-core/columns/custom.js.map +1 -1
  1538. package/singlestore-core/columns/date.cjs.map +1 -1
  1539. package/singlestore-core/columns/date.d.cts +0 -2
  1540. package/singlestore-core/columns/date.d.ts +0 -2
  1541. package/singlestore-core/columns/date.js.map +1 -1
  1542. package/singlestore-core/columns/datetime.cjs.map +1 -1
  1543. package/singlestore-core/columns/datetime.d.cts +0 -2
  1544. package/singlestore-core/columns/datetime.d.ts +0 -2
  1545. package/singlestore-core/columns/datetime.js.map +1 -1
  1546. package/singlestore-core/columns/decimal.cjs.map +1 -1
  1547. package/singlestore-core/columns/decimal.d.cts +0 -3
  1548. package/singlestore-core/columns/decimal.d.ts +0 -3
  1549. package/singlestore-core/columns/decimal.js.map +1 -1
  1550. package/singlestore-core/columns/double.cjs.map +1 -1
  1551. package/singlestore-core/columns/double.d.cts +0 -1
  1552. package/singlestore-core/columns/double.d.ts +0 -1
  1553. package/singlestore-core/columns/double.js.map +1 -1
  1554. package/singlestore-core/columns/enum.cjs.map +1 -1
  1555. package/singlestore-core/columns/enum.d.cts +0 -1
  1556. package/singlestore-core/columns/enum.d.ts +0 -1
  1557. package/singlestore-core/columns/enum.js.map +1 -1
  1558. package/singlestore-core/columns/float.cjs.map +1 -1
  1559. package/singlestore-core/columns/float.d.cts +0 -1
  1560. package/singlestore-core/columns/float.d.ts +0 -1
  1561. package/singlestore-core/columns/float.js.map +1 -1
  1562. package/singlestore-core/columns/int.cjs.map +1 -1
  1563. package/singlestore-core/columns/int.d.cts +0 -1
  1564. package/singlestore-core/columns/int.d.ts +0 -1
  1565. package/singlestore-core/columns/int.js.map +1 -1
  1566. package/singlestore-core/columns/json.cjs.map +1 -1
  1567. package/singlestore-core/columns/json.d.cts +0 -1
  1568. package/singlestore-core/columns/json.d.ts +0 -1
  1569. package/singlestore-core/columns/json.js.map +1 -1
  1570. package/singlestore-core/columns/mediumint.cjs.map +1 -1
  1571. package/singlestore-core/columns/mediumint.d.cts +0 -1
  1572. package/singlestore-core/columns/mediumint.d.ts +0 -1
  1573. package/singlestore-core/columns/mediumint.js.map +1 -1
  1574. package/singlestore-core/columns/real.cjs.map +1 -1
  1575. package/singlestore-core/columns/real.d.cts +0 -1
  1576. package/singlestore-core/columns/real.d.ts +0 -1
  1577. package/singlestore-core/columns/real.js.map +1 -1
  1578. package/singlestore-core/columns/serial.cjs.map +1 -1
  1579. package/singlestore-core/columns/serial.d.cts +0 -1
  1580. package/singlestore-core/columns/serial.d.ts +0 -1
  1581. package/singlestore-core/columns/serial.js.map +1 -1
  1582. package/singlestore-core/columns/smallint.cjs.map +1 -1
  1583. package/singlestore-core/columns/smallint.d.cts +0 -1
  1584. package/singlestore-core/columns/smallint.d.ts +0 -1
  1585. package/singlestore-core/columns/smallint.js.map +1 -1
  1586. package/singlestore-core/columns/text.cjs.map +1 -1
  1587. package/singlestore-core/columns/text.d.cts +0 -1
  1588. package/singlestore-core/columns/text.d.ts +0 -1
  1589. package/singlestore-core/columns/text.js.map +1 -1
  1590. package/singlestore-core/columns/time.cjs.map +1 -1
  1591. package/singlestore-core/columns/time.d.cts +0 -1
  1592. package/singlestore-core/columns/time.d.ts +0 -1
  1593. package/singlestore-core/columns/time.js.map +1 -1
  1594. package/singlestore-core/columns/timestamp.cjs.map +1 -1
  1595. package/singlestore-core/columns/timestamp.d.cts +0 -2
  1596. package/singlestore-core/columns/timestamp.d.ts +0 -2
  1597. package/singlestore-core/columns/timestamp.js.map +1 -1
  1598. package/singlestore-core/columns/tinyint.cjs.map +1 -1
  1599. package/singlestore-core/columns/tinyint.d.cts +0 -1
  1600. package/singlestore-core/columns/tinyint.d.ts +0 -1
  1601. package/singlestore-core/columns/tinyint.js.map +1 -1
  1602. package/singlestore-core/columns/varbinary.cjs.map +1 -1
  1603. package/singlestore-core/columns/varbinary.d.cts +0 -1
  1604. package/singlestore-core/columns/varbinary.d.ts +0 -1
  1605. package/singlestore-core/columns/varbinary.js.map +1 -1
  1606. package/singlestore-core/columns/varchar.cjs.map +1 -1
  1607. package/singlestore-core/columns/varchar.d.cts +0 -1
  1608. package/singlestore-core/columns/varchar.d.ts +0 -1
  1609. package/singlestore-core/columns/varchar.js.map +1 -1
  1610. package/singlestore-core/columns/vector.cjs.map +1 -1
  1611. package/singlestore-core/columns/vector.d.cts +0 -2
  1612. package/singlestore-core/columns/vector.d.ts +0 -2
  1613. package/singlestore-core/columns/vector.js.map +1 -1
  1614. package/singlestore-core/columns/year.cjs.map +1 -1
  1615. package/singlestore-core/columns/year.d.cts +0 -1
  1616. package/singlestore-core/columns/year.d.ts +0 -1
  1617. package/singlestore-core/columns/year.js.map +1 -1
  1618. package/singlestore-core/dialect.cjs +4 -2
  1619. package/singlestore-core/dialect.cjs.map +1 -1
  1620. package/singlestore-core/dialect.js +11 -3
  1621. package/singlestore-core/dialect.js.map +1 -1
  1622. package/singlestore-core/indexes.cjs +2 -0
  1623. package/singlestore-core/indexes.cjs.map +1 -1
  1624. package/singlestore-core/indexes.d.cts +1 -0
  1625. package/singlestore-core/indexes.d.ts +1 -0
  1626. package/singlestore-core/indexes.js +2 -0
  1627. package/singlestore-core/indexes.js.map +1 -1
  1628. package/singlestore-core/primary-keys.cjs +2 -0
  1629. package/singlestore-core/primary-keys.cjs.map +1 -1
  1630. package/singlestore-core/primary-keys.d.cts +1 -0
  1631. package/singlestore-core/primary-keys.d.ts +1 -0
  1632. package/singlestore-core/primary-keys.js +2 -0
  1633. package/singlestore-core/primary-keys.js.map +1 -1
  1634. package/singlestore-core/query-builders/count.cjs.map +1 -1
  1635. package/singlestore-core/query-builders/count.d.cts +1 -1
  1636. package/singlestore-core/query-builders/count.d.ts +1 -1
  1637. package/singlestore-core/query-builders/count.js.map +1 -1
  1638. package/singlestore-core/query-builders/insert.cjs.map +1 -1
  1639. package/singlestore-core/query-builders/insert.d.cts +1 -1
  1640. package/singlestore-core/query-builders/insert.d.ts +1 -1
  1641. package/singlestore-core/query-builders/insert.js.map +1 -1
  1642. package/singlestore-core/query-builders/update.cjs.map +1 -1
  1643. package/singlestore-core/query-builders/update.d.cts +1 -1
  1644. package/singlestore-core/query-builders/update.d.ts +1 -1
  1645. package/singlestore-core/query-builders/update.js.map +1 -1
  1646. package/singlestore-core/unique-constraint.cjs +2 -0
  1647. package/singlestore-core/unique-constraint.cjs.map +1 -1
  1648. package/singlestore-core/unique-constraint.d.cts +3 -2
  1649. package/singlestore-core/unique-constraint.d.ts +3 -2
  1650. package/singlestore-core/unique-constraint.js +2 -0
  1651. package/singlestore-core/unique-constraint.js.map +1 -1
  1652. package/sql/sql.cjs +11 -10
  1653. package/sql/sql.cjs.map +1 -1
  1654. package/sql/sql.d.cts +3 -3
  1655. package/sql/sql.d.ts +3 -3
  1656. package/sql/sql.js +11 -10
  1657. package/sql/sql.js.map +1 -1
  1658. package/sql-js/session.cjs.map +1 -1
  1659. package/sql-js/session.js.map +1 -1
  1660. package/sqlite-cloud/driver.cjs +6 -10
  1661. package/sqlite-cloud/driver.cjs.map +1 -1
  1662. package/sqlite-cloud/driver.d.cts +3 -3
  1663. package/sqlite-cloud/driver.d.ts +3 -3
  1664. package/sqlite-cloud/driver.js +6 -10
  1665. package/sqlite-cloud/driver.js.map +1 -1
  1666. package/sqlite-core/columns/blob.cjs.map +1 -1
  1667. package/sqlite-core/columns/blob.d.cts +0 -3
  1668. package/sqlite-core/columns/blob.d.ts +0 -3
  1669. package/sqlite-core/columns/blob.js.map +1 -1
  1670. package/sqlite-core/columns/common.cjs +0 -4
  1671. package/sqlite-core/columns/common.cjs.map +1 -1
  1672. package/sqlite-core/columns/common.js +0 -4
  1673. package/sqlite-core/columns/common.js.map +1 -1
  1674. package/sqlite-core/columns/custom.cjs.map +1 -1
  1675. package/sqlite-core/columns/custom.d.cts +0 -1
  1676. package/sqlite-core/columns/custom.d.ts +0 -1
  1677. package/sqlite-core/columns/custom.js.map +1 -1
  1678. package/sqlite-core/columns/integer.cjs.map +1 -1
  1679. package/sqlite-core/columns/integer.d.cts +0 -3
  1680. package/sqlite-core/columns/integer.d.ts +0 -3
  1681. package/sqlite-core/columns/integer.js.map +1 -1
  1682. package/sqlite-core/columns/numeric.cjs.map +1 -1
  1683. package/sqlite-core/columns/numeric.d.cts +0 -3
  1684. package/sqlite-core/columns/numeric.d.ts +0 -3
  1685. package/sqlite-core/columns/numeric.js.map +1 -1
  1686. package/sqlite-core/columns/real.cjs.map +1 -1
  1687. package/sqlite-core/columns/real.d.cts +0 -1
  1688. package/sqlite-core/columns/real.d.ts +0 -1
  1689. package/sqlite-core/columns/real.js.map +1 -1
  1690. package/sqlite-core/columns/text.cjs.map +1 -1
  1691. package/sqlite-core/columns/text.d.cts +0 -2
  1692. package/sqlite-core/columns/text.d.ts +0 -2
  1693. package/sqlite-core/columns/text.js.map +1 -1
  1694. package/sqlite-core/dialect.cjs +8 -5
  1695. package/sqlite-core/dialect.cjs.map +1 -1
  1696. package/sqlite-core/dialect.js +15 -6
  1697. package/sqlite-core/dialect.js.map +1 -1
  1698. package/sqlite-core/foreign-keys.cjs +3 -0
  1699. package/sqlite-core/foreign-keys.cjs.map +1 -1
  1700. package/sqlite-core/foreign-keys.d.cts +1 -14
  1701. package/sqlite-core/foreign-keys.d.ts +1 -14
  1702. package/sqlite-core/foreign-keys.js +3 -0
  1703. package/sqlite-core/foreign-keys.js.map +1 -1
  1704. package/sqlite-core/indexes.cjs +2 -0
  1705. package/sqlite-core/indexes.cjs.map +1 -1
  1706. package/sqlite-core/indexes.d.cts +1 -0
  1707. package/sqlite-core/indexes.d.ts +1 -0
  1708. package/sqlite-core/indexes.js +2 -0
  1709. package/sqlite-core/indexes.js.map +1 -1
  1710. package/sqlite-core/primary-keys.cjs +2 -0
  1711. package/sqlite-core/primary-keys.cjs.map +1 -1
  1712. package/sqlite-core/primary-keys.d.cts +1 -0
  1713. package/sqlite-core/primary-keys.d.ts +1 -0
  1714. package/sqlite-core/primary-keys.js +2 -0
  1715. package/sqlite-core/primary-keys.js.map +1 -1
  1716. package/sqlite-core/query-builders/count.cjs.map +1 -1
  1717. package/sqlite-core/query-builders/count.d.cts +1 -1
  1718. package/sqlite-core/query-builders/count.d.ts +1 -1
  1719. package/sqlite-core/query-builders/count.js.map +1 -1
  1720. package/sqlite-core/query-builders/insert.cjs.map +1 -1
  1721. package/sqlite-core/query-builders/insert.d.cts +2 -2
  1722. package/sqlite-core/query-builders/insert.d.ts +2 -2
  1723. package/sqlite-core/query-builders/insert.js.map +1 -1
  1724. package/sqlite-core/query-builders/update.cjs.map +1 -1
  1725. package/sqlite-core/query-builders/update.d.cts +1 -1
  1726. package/sqlite-core/query-builders/update.d.ts +1 -1
  1727. package/sqlite-core/query-builders/update.js.map +1 -1
  1728. package/sqlite-core/unique-constraint.cjs +2 -0
  1729. package/sqlite-core/unique-constraint.cjs.map +1 -1
  1730. package/sqlite-core/unique-constraint.d.cts +3 -2
  1731. package/sqlite-core/unique-constraint.d.ts +3 -2
  1732. package/sqlite-core/unique-constraint.js +2 -0
  1733. package/sqlite-core/unique-constraint.js.map +1 -1
  1734. package/sqlite-proxy/session.cjs +0 -1
  1735. package/sqlite-proxy/session.cjs.map +1 -1
  1736. package/sqlite-proxy/session.js +0 -1
  1737. package/sqlite-proxy/session.js.map +1 -1
  1738. package/table.cjs +0 -1
  1739. package/table.cjs.map +1 -1
  1740. package/table.d.cts +2 -3
  1741. package/table.d.ts +2 -3
  1742. package/table.js +0 -1
  1743. package/table.js.map +1 -1
  1744. package/tidb-serverless/driver.cjs +8 -12
  1745. package/tidb-serverless/driver.cjs.map +1 -1
  1746. package/tidb-serverless/driver.d.cts +3 -3
  1747. package/tidb-serverless/driver.d.ts +3 -3
  1748. package/tidb-serverless/driver.js +8 -12
  1749. package/tidb-serverless/driver.js.map +1 -1
  1750. package/tracing.cjs +1 -1
  1751. package/tracing.cjs.map +1 -1
  1752. package/tracing.js +1 -1
  1753. package/tracing.js.map +1 -1
  1754. package/tursodatabase/database.cjs +6 -10
  1755. package/tursodatabase/database.cjs.map +1 -1
  1756. package/tursodatabase/database.d.cts +3 -3
  1757. package/tursodatabase/database.d.ts +3 -3
  1758. package/tursodatabase/database.js +6 -10
  1759. package/tursodatabase/database.js.map +1 -1
  1760. package/tursodatabase/session.cjs +0 -2
  1761. package/tursodatabase/session.cjs.map +1 -1
  1762. package/tursodatabase/session.js +0 -2
  1763. package/tursodatabase/session.js.map +1 -1
  1764. package/tursodatabase/wasm.cjs +6 -10
  1765. package/tursodatabase/wasm.cjs.map +1 -1
  1766. package/tursodatabase/wasm.d.cts +3 -3
  1767. package/tursodatabase/wasm.d.ts +3 -3
  1768. package/tursodatabase/wasm.js +6 -10
  1769. package/tursodatabase/wasm.js.map +1 -1
  1770. package/vercel-postgres/session.cjs.map +1 -1
  1771. package/vercel-postgres/session.js.map +1 -1
  1772. package/version.cjs +2 -2
  1773. package/version.cjs.map +1 -1
  1774. package/version.d.cts +2 -2
  1775. package/version.d.ts +2 -2
  1776. package/version.js +2 -2
  1777. package/version.js.map +1 -1
package/_relations.cjs CHANGED
@@ -29,6 +29,7 @@ __export(relations_exports, {
29
29
  getOperators: () => getOperators,
30
30
  getOrderByOperators: () => getOrderByOperators,
31
31
  mapRelationalRow: () => mapRelationalRow,
32
+ mapRelationalRowFromObj: () => mapRelationalRowFromObj,
32
33
  normalizeRelation: () => normalizeRelation,
33
34
  relations: () => relations
34
35
  });
@@ -165,19 +166,15 @@ function extractTablesRelationalConfig(schema, configHelpers) {
165
166
  const relations2 = value.config(
166
167
  configHelpers(value.table)
167
168
  );
168
- let primaryKey;
169
169
  for (const [relationName, relation] of Object.entries(relations2)) {
170
170
  if (tableName) {
171
171
  const tableConfig = tablesConfig[tableName];
172
172
  tableConfig.relations[relationName] = relation;
173
- if (primaryKey) {
174
- tableConfig.primaryKey.push(...primaryKey);
175
- }
176
173
  } else {
177
174
  if (!(dbName in relationsBuffer)) {
178
175
  relationsBuffer[dbName] = {
179
- relations: {},
180
- primaryKey
176
+ relations: {}
177
+ // primaryKey,
181
178
  };
182
179
  }
183
180
  relationsBuffer[dbName].relations[relationName] = relation;
@@ -309,6 +306,52 @@ function mapRelationalRow(tablesConfig, tableConfig, row, buildQueryResultSelect
309
306
  }
310
307
  return result;
311
308
  }
309
+ function mapRelationalRowFromObj(tablesConfig, tableConfig, row, buildQueryResultSelection, mapColumnValue = (value) => value) {
310
+ const result = {};
311
+ for (const [
312
+ selectionItemIndex,
313
+ selectionItem
314
+ ] of buildQueryResultSelection.entries()) {
315
+ if (selectionItem.isJson) {
316
+ const relation = tableConfig.relations[selectionItem.tsKey];
317
+ const isOne = (0, import_entity.is)(relation, One);
318
+ const rawSubRows = row[selectionItemIndex];
319
+ let subRows = rawSubRows;
320
+ if (subRows || Array.isArray(subRows)) {
321
+ subRows = typeof rawSubRows === "string" ? JSON.parse(rawSubRows) : rawSubRows;
322
+ subRows = isOne ? subRows.flatMap((r) => Array.isArray(r) ? r : Object.values(r)) : subRows.map((r) => Array.isArray(r) ? r : Object.values(r));
323
+ }
324
+ result[selectionItem.tsKey] = isOne ? subRows && mapRelationalRowFromObj(
325
+ tablesConfig,
326
+ tablesConfig[selectionItem.relationTableTsKey],
327
+ subRows,
328
+ selectionItem.selection,
329
+ mapColumnValue
330
+ ) : (subRows ?? []).map(
331
+ (subRow) => mapRelationalRowFromObj(
332
+ tablesConfig,
333
+ tablesConfig[selectionItem.relationTableTsKey],
334
+ subRow,
335
+ selectionItem.selection,
336
+ mapColumnValue
337
+ )
338
+ );
339
+ } else {
340
+ const value = mapColumnValue(row[selectionItemIndex]);
341
+ const field = selectionItem.field;
342
+ let decoder;
343
+ if ((0, import_entity.is)(field, import_column.Column)) {
344
+ decoder = field;
345
+ } else if ((0, import_entity.is)(field, import_sql.SQL)) {
346
+ decoder = field.decoder;
347
+ } else {
348
+ decoder = field.sql.decoder;
349
+ }
350
+ result[selectionItem.tsKey] = value === null ? null : decoder.mapFromDriverValue(value);
351
+ }
352
+ }
353
+ return result;
354
+ }
312
355
  // Annotate the CommonJS export names for ESM import in node:
313
356
  0 && (module.exports = {
314
357
  Many,
@@ -322,6 +365,7 @@ function mapRelationalRow(tablesConfig, tableConfig, row, buildQueryResultSelect
322
365
  getOperators,
323
366
  getOrderByOperators,
324
367
  mapRelationalRow,
368
+ mapRelationalRowFromObj,
325
369
  normalizeRelation,
326
370
  relations
327
371
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/_relations.ts"],"sourcesContent":["import { type AnyTable, getTableUniqueName, type InferModelFromColumns, Table } from '~/table.ts';\nimport { type AnyColumn, Column } from './column.ts';\nimport { entityKind, is } from './entity.ts';\nimport { PrimaryKeyBuilder } from './pg-core/primary-keys.ts';\nimport {\n\tand,\n\tasc,\n\tbetween,\n\tdesc,\n\teq,\n\texists,\n\tgt,\n\tgte,\n\tilike,\n\tinArray,\n\tisNotNull,\n\tisNull,\n\tlike,\n\tlt,\n\tlte,\n\tne,\n\tnot,\n\tnotBetween,\n\tnotExists,\n\tnotIlike,\n\tnotInArray,\n\tnotLike,\n\tor,\n} from './sql/expressions/index.ts';\nimport { type Placeholder, SQL, sql } from './sql/sql.ts';\nimport type { Assume, ColumnsWithTable, Equal, Simplify, ValueOrArray } from './utils.ts';\n\nexport abstract class Relation<TTableName extends string = string> {\n\tstatic readonly [entityKind]: string = 'Relation';\n\n\tdeclare readonly $brand: 'Relation';\n\treadonly referencedTableName: TTableName;\n\tfieldName!: string;\n\n\tconstructor(\n\t\treadonly sourceTable: Table,\n\t\treadonly referencedTable: AnyTable<{ name: TTableName }>,\n\t\treadonly relationName: string | undefined,\n\t) {\n\t\tthis.referencedTableName = referencedTable[Table.Symbol.Name] as TTableName;\n\t}\n\n\tabstract withFieldName(fieldName: string): Relation<TTableName>;\n}\n\nexport class Relations<\n\tTTableName extends string = string,\n\tTConfig extends Record<string, Relation> = Record<string, Relation>,\n> {\n\tstatic readonly [entityKind]: string = 'Relations';\n\n\tdeclare readonly $brand: 'Relations';\n\n\tconstructor(\n\t\treadonly table: AnyTable<{ name: TTableName }>,\n\t\treadonly config: (helpers: TableRelationsHelpers<TTableName>) => TConfig,\n\t) {}\n}\n\nexport class One<\n\tTTableName extends string = string,\n\tTIsNullable extends boolean = boolean,\n> extends Relation<TTableName> {\n\tstatic override readonly [entityKind]: string = 'One';\n\n\tdeclare protected $relationBrand: 'One';\n\n\tconstructor(\n\t\tsourceTable: Table,\n\t\treferencedTable: AnyTable<{ name: TTableName }>,\n\t\treadonly config:\n\t\t\t| RelationConfig<\n\t\t\t\tTTableName,\n\t\t\t\tstring,\n\t\t\t\tAnyColumn<{ tableName: TTableName }>[]\n\t\t\t>\n\t\t\t| undefined,\n\t\treadonly isNullable: TIsNullable,\n\t) {\n\t\tsuper(sourceTable, referencedTable, config?.relationName);\n\t}\n\n\twithFieldName(fieldName: string): One<TTableName> {\n\t\tconst relation = new One(\n\t\t\tthis.sourceTable,\n\t\t\tthis.referencedTable,\n\t\t\tthis.config,\n\t\t\tthis.isNullable,\n\t\t);\n\t\trelation.fieldName = fieldName;\n\t\treturn relation;\n\t}\n}\n\nexport class Many<TTableName extends string> extends Relation<TTableName> {\n\tstatic override readonly [entityKind]: string = 'Many';\n\n\tdeclare protected $relationBrand: 'Many';\n\n\tconstructor(\n\t\tsourceTable: Table,\n\t\treferencedTable: AnyTable<{ name: TTableName }>,\n\t\treadonly config: { relationName: string } | undefined,\n\t) {\n\t\tsuper(sourceTable, referencedTable, config?.relationName);\n\t}\n\n\twithFieldName(fieldName: string): Many<TTableName> {\n\t\tconst relation = new Many(\n\t\t\tthis.sourceTable,\n\t\t\tthis.referencedTable,\n\t\t\tthis.config,\n\t\t);\n\t\trelation.fieldName = fieldName;\n\t\treturn relation;\n\t}\n}\n\nexport type TableRelationsKeysOnly<\n\tTSchema extends Record<string, unknown>,\n\tTTableName extends string,\n\tK extends keyof TSchema,\n> = TSchema[K] extends Relations<TTableName> ? K : never;\n\nexport type ExtractTableRelationsFromSchema<\n\tTSchema extends Record<string, unknown>,\n\tTTableName extends string,\n> = ExtractObjectValues<\n\t{\n\t\t[\n\t\t\tK in keyof TSchema as TableRelationsKeysOnly<\n\t\t\t\tTSchema,\n\t\t\t\tTTableName,\n\t\t\t\tK\n\t\t\t>\n\t\t]: TSchema[K] extends Relations<TTableName, infer TConfig> ? TConfig : never;\n\t}\n>;\n\nexport type ExtractObjectValues<T> = T[keyof T];\n\nexport type ExtractRelationsFromTableExtraConfigSchema<\n\tTConfig extends unknown[],\n> = ExtractObjectValues<\n\t{\n\t\t[\n\t\t\tK in keyof TConfig as TConfig[K] extends Relations<any> ? K\n\t\t\t\t: never\n\t\t]: TConfig[K] extends Relations<infer TRelationConfig> ? TRelationConfig\n\t\t\t: never;\n\t}\n>;\n\nexport function getOperators() {\n\treturn {\n\t\tand,\n\t\tbetween,\n\t\teq,\n\t\texists,\n\t\tgt,\n\t\tgte,\n\t\tilike,\n\t\tinArray,\n\t\tisNull,\n\t\tisNotNull,\n\t\tlike,\n\t\tlt,\n\t\tlte,\n\t\tne,\n\t\tnot,\n\t\tnotBetween,\n\t\tnotExists,\n\t\tnotLike,\n\t\tnotIlike,\n\t\tnotInArray,\n\t\tor,\n\t\tsql,\n\t};\n}\n\nexport type Operators = ReturnType<typeof getOperators>;\n\nexport function getOrderByOperators() {\n\treturn {\n\t\tsql,\n\t\tasc,\n\t\tdesc,\n\t};\n}\n\nexport type OrderByOperators = ReturnType<typeof getOrderByOperators>;\n\nexport type FindTableByDBName<\n\tTSchema extends TablesRelationalConfig,\n\tTTableName extends string,\n> = ExtractObjectValues<\n\t{\n\t\t[\n\t\t\tK in keyof TSchema as TSchema[K]['dbName'] extends TTableName ? K\n\t\t\t\t: never\n\t\t]: TSchema[K];\n\t}\n>;\n\nexport type DBQueryConfig<\n\tTRelationType extends 'one' | 'many' = 'one' | 'many',\n\tTIsRoot extends boolean = boolean,\n\tTSchema extends TablesRelationalConfig = TablesRelationalConfig,\n\tTTableConfig extends TableRelationalConfig = TableRelationalConfig,\n> =\n\t& {\n\t\tcolumns?:\n\t\t\t| {\n\t\t\t\t[K in keyof TTableConfig['columns']]?: boolean;\n\t\t\t}\n\t\t\t| undefined;\n\t\twith?:\n\t\t\t| {\n\t\t\t\t[K in keyof TTableConfig['relations']]?:\n\t\t\t\t\t| true\n\t\t\t\t\t| DBQueryConfig<\n\t\t\t\t\t\tTTableConfig['relations'][K] extends One ? 'one' : 'many',\n\t\t\t\t\t\tfalse,\n\t\t\t\t\t\tTSchema,\n\t\t\t\t\t\tFindTableByDBName<\n\t\t\t\t\t\t\tTSchema,\n\t\t\t\t\t\t\tTTableConfig['relations'][K]['referencedTableName']\n\t\t\t\t\t\t>\n\t\t\t\t\t>\n\t\t\t\t\t| undefined;\n\t\t\t}\n\t\t\t| undefined;\n\t\textras?:\n\t\t\t| Record<string, SQL.Aliased>\n\t\t\t| ((\n\t\t\t\tfields: Simplify<\n\t\t\t\t\t[TTableConfig['columns']] extends [never] ? {}\n\t\t\t\t\t\t: TTableConfig['columns']\n\t\t\t\t>,\n\t\t\t\toperators: { sql: Operators['sql'] },\n\t\t\t) => Record<string, SQL.Aliased>)\n\t\t\t| undefined;\n\t}\n\t& (TRelationType extends 'many' ?\n\t\t\t& {\n\t\t\t\twhere?:\n\t\t\t\t\t| SQL\n\t\t\t\t\t| undefined\n\t\t\t\t\t| ((\n\t\t\t\t\t\tfields: Simplify<\n\t\t\t\t\t\t\t[TTableConfig['columns']] extends [never] ? {}\n\t\t\t\t\t\t\t\t: TTableConfig['columns']\n\t\t\t\t\t\t>,\n\t\t\t\t\t\toperators: Operators,\n\t\t\t\t\t) => SQL | undefined);\n\t\t\t\torderBy?:\n\t\t\t\t\t| ValueOrArray<AnyColumn | SQL>\n\t\t\t\t\t| ((\n\t\t\t\t\t\tfields: Simplify<\n\t\t\t\t\t\t\t[TTableConfig['columns']] extends [never] ? {}\n\t\t\t\t\t\t\t\t: TTableConfig['columns']\n\t\t\t\t\t\t>,\n\t\t\t\t\t\toperators: OrderByOperators,\n\t\t\t\t\t) => ValueOrArray<AnyColumn | SQL>)\n\t\t\t\t\t| undefined;\n\t\t\t\tlimit?: number | Placeholder | undefined;\n\t\t\t}\n\t\t\t& (TIsRoot extends true ? {\n\t\t\t\t\toffset?: number | Placeholder | undefined;\n\t\t\t\t}\n\t\t\t\t: {})\n\t\t: {});\n\nexport interface TableRelationalConfig {\n\ttsName: string;\n\tdbName: string;\n\tcolumns: Record<string, Column>;\n\trelations: Record<string, Relation>;\n\tprimaryKey: AnyColumn[];\n\tschema?: string;\n}\n\nexport type TablesRelationalConfig = Record<string, TableRelationalConfig>;\n\nexport interface RelationalSchemaConfig<\n\tTSchema extends TablesRelationalConfig,\n> {\n\tfullSchema: Record<string, unknown>;\n\tschema: TSchema;\n\ttableNamesMap: Record<string, string>;\n}\n\nexport type ExtractTablesWithRelations<\n\tTSchema extends Record<string, unknown>,\n> = {\n\t[\n\t\tK in keyof TSchema as TSchema[K] extends Table ? K\n\t\t\t: never\n\t]: TSchema[K] extends Table ? {\n\t\t\ttsName: K & string;\n\t\t\tdbName: TSchema[K]['_']['name'];\n\t\t\tcolumns: TSchema[K]['_']['columns'];\n\t\t\trelations: ExtractTableRelationsFromSchema<\n\t\t\t\tTSchema,\n\t\t\t\tTSchema[K]['_']['name']\n\t\t\t>;\n\t\t\tprimaryKey: AnyColumn[];\n\t\t}\n\t\t: never;\n};\n\nexport type ReturnTypeOrValue<T> = T extends (...args: any[]) => infer R ? R\n\t: T;\n\nexport type BuildRelationResult<\n\tTSchema extends TablesRelationalConfig,\n\tTInclude,\n\tTRelations extends Record<string, Relation>,\n> = {\n\t[\n\t\tK in\n\t\t\t& NonUndefinedKeysOnly<TInclude>\n\t\t\t& keyof TRelations\n\t]: TRelations[K] extends infer TRel extends Relation ? BuildQueryResult<\n\t\t\tTSchema,\n\t\t\tFindTableByDBName<TSchema, TRel['referencedTableName']>,\n\t\t\tAssume<TInclude[K], true | Record<string, unknown>>\n\t\t> extends infer TResult ? TRel extends One ?\n\t\t\t\t\t| TResult\n\t\t\t\t\t| (Equal<TRel['isNullable'], false> extends true ? null : never)\n\t\t\t: TResult[]\n\t\t: never\n\t\t: never;\n};\n\nexport type NonUndefinedKeysOnly<T> =\n\t& ExtractObjectValues<\n\t\t{\n\t\t\t[K in keyof T as T[K] extends undefined ? never : K]: K;\n\t\t}\n\t>\n\t& keyof T;\n\nexport type BuildQueryResult<\n\tTSchema extends TablesRelationalConfig,\n\tTTableConfig extends TableRelationalConfig,\n\tTFullSelection extends true | Record<string, unknown>,\n> = Equal<TFullSelection, true> extends true ? InferModelFromColumns<TTableConfig['columns']>\n\t: TFullSelection extends Record<string, unknown> ? Simplify<\n\t\t\t& (TFullSelection['columns'] extends Record<string, unknown> ? InferModelFromColumns<\n\t\t\t\t\t{\n\t\t\t\t\t\t[\n\t\t\t\t\t\t\tK in Equal<\n\t\t\t\t\t\t\t\tExclude<\n\t\t\t\t\t\t\t\t\tTFullSelection['columns'][\n\t\t\t\t\t\t\t\t\t\t& keyof TFullSelection['columns']\n\t\t\t\t\t\t\t\t\t\t& keyof TTableConfig['columns']\n\t\t\t\t\t\t\t\t\t],\n\t\t\t\t\t\t\t\t\tundefined\n\t\t\t\t\t\t\t\t>,\n\t\t\t\t\t\t\t\tfalse\n\t\t\t\t\t\t\t> extends true ? Exclude<\n\t\t\t\t\t\t\t\t\tkeyof TTableConfig['columns'],\n\t\t\t\t\t\t\t\t\tNonUndefinedKeysOnly<TFullSelection['columns']>\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t:\n\t\t\t\t\t\t\t\t\t& {\n\t\t\t\t\t\t\t\t\t\t[K in keyof TFullSelection['columns']]: Equal<\n\t\t\t\t\t\t\t\t\t\t\tTFullSelection['columns'][K],\n\t\t\t\t\t\t\t\t\t\t\ttrue\n\t\t\t\t\t\t\t\t\t\t> extends true ? K\n\t\t\t\t\t\t\t\t\t\t\t: never;\n\t\t\t\t\t\t\t\t\t}[keyof TFullSelection['columns']]\n\t\t\t\t\t\t\t\t\t& keyof TTableConfig['columns']\n\t\t\t\t\t\t]: TTableConfig['columns'][K];\n\t\t\t\t\t}\n\t\t\t\t>\n\t\t\t\t: InferModelFromColumns<TTableConfig['columns']>)\n\t\t\t& (TFullSelection['extras'] extends\n\t\t\t\t| Record<string, unknown>\n\t\t\t\t| ((...args: any[]) => Record<string, unknown>) ? {\n\t\t\t\t\t[\n\t\t\t\t\t\tK in NonUndefinedKeysOnly<\n\t\t\t\t\t\t\tReturnTypeOrValue<TFullSelection['extras']>\n\t\t\t\t\t\t>\n\t\t\t\t\t]: Assume<\n\t\t\t\t\t\tReturnTypeOrValue<TFullSelection['extras']>[K],\n\t\t\t\t\t\tSQL.Aliased\n\t\t\t\t\t>['_']['type'];\n\t\t\t\t}\n\t\t\t\t: {})\n\t\t\t& (TFullSelection['with'] extends Record<string, unknown> ? BuildRelationResult<\n\t\t\t\t\tTSchema,\n\t\t\t\t\tTFullSelection['with'],\n\t\t\t\t\tTTableConfig['relations']\n\t\t\t\t>\n\t\t\t\t: {})\n\t\t>\n\t: never;\n\nexport interface RelationConfig<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends AnyColumn<{ tableName: TTableName }>[],\n> {\n\trelationName?: string;\n\tfields: TColumns;\n\treferences: ColumnsWithTable<TTableName, TForeignTableName, TColumns>;\n}\n\nexport function extractTablesRelationalConfig<\n\tTTables extends TablesRelationalConfig,\n>(\n\tschema: Record<string, unknown>,\n\tconfigHelpers: (table: Table) => any,\n): { tables: TTables; tableNamesMap: Record<string, string> } {\n\tif (\n\t\tObject.keys(schema).length === 1\n\t\t&& 'default' in schema\n\t\t&& !is(schema['default'], Table)\n\t) {\n\t\tschema = schema['default'] as Record<string, unknown>;\n\t}\n\n\t// table DB name -> schema table key\n\tconst tableNamesMap: Record<string, string> = {};\n\t// Table relations found before their tables - need to buffer them until we know the schema table key\n\tconst relationsBuffer: Record<\n\t\tstring,\n\t\t{ relations: Record<string, Relation>; primaryKey?: AnyColumn[] }\n\t> = {};\n\tconst tablesConfig: TablesRelationalConfig = {};\n\tfor (const [key, value] of Object.entries(schema)) {\n\t\tif (is(value, Table)) {\n\t\t\tconst dbName = getTableUniqueName(value);\n\t\t\tconst bufferedRelations = relationsBuffer[dbName];\n\t\t\ttableNamesMap[dbName] = key;\n\t\t\ttablesConfig[key] = {\n\t\t\t\ttsName: key,\n\t\t\t\tdbName: value[Table.Symbol.Name],\n\t\t\t\tschema: value[Table.Symbol.Schema],\n\t\t\t\tcolumns: value[Table.Symbol.Columns],\n\t\t\t\trelations: bufferedRelations?.relations ?? {},\n\t\t\t\tprimaryKey: bufferedRelations?.primaryKey ?? [],\n\t\t\t};\n\n\t\t\t// Fill in primary keys\n\t\t\tfor (\n\t\t\t\tconst column of Object.values(\n\t\t\t\t\t(value as Table)[Table.Symbol.Columns],\n\t\t\t\t)\n\t\t\t) {\n\t\t\t\tif (column.primary) {\n\t\t\t\t\ttablesConfig[key]!.primaryKey.push(column);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst extraConfig = value[Table.Symbol.ExtraConfigBuilder]?.((value as Table)[Table.Symbol.ExtraConfigColumns]);\n\t\t\tif (extraConfig) {\n\t\t\t\tfor (const configEntry of Object.values(extraConfig)) {\n\t\t\t\t\tif (is(configEntry, PrimaryKeyBuilder)) {\n\t\t\t\t\t\ttablesConfig[key]!.primaryKey.push(...configEntry.columns);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} else if (is(value, Relations)) {\n\t\t\tconst dbName = getTableUniqueName(value.table);\n\t\t\tconst tableName = tableNamesMap[dbName];\n\t\t\tconst relations: Record<string, Relation> = value.config(\n\t\t\t\tconfigHelpers(value.table),\n\t\t\t);\n\t\t\tlet primaryKey: AnyColumn[] | undefined;\n\n\t\t\tfor (const [relationName, relation] of Object.entries(relations)) {\n\t\t\t\tif (tableName) {\n\t\t\t\t\tconst tableConfig = tablesConfig[tableName]!;\n\t\t\t\t\ttableConfig.relations[relationName] = relation;\n\t\t\t\t\tif (primaryKey) {\n\t\t\t\t\t\ttableConfig.primaryKey.push(...primaryKey);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tif (!(dbName in relationsBuffer)) {\n\t\t\t\t\t\trelationsBuffer[dbName] = {\n\t\t\t\t\t\t\trelations: {},\n\t\t\t\t\t\t\tprimaryKey,\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t\trelationsBuffer[dbName]!.relations[relationName] = relation;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn { tables: tablesConfig as TTables, tableNamesMap };\n}\n\nexport function relations<\n\tTTableName extends string,\n\tTRelations extends Record<string, Relation<any>>,\n>(\n\ttable: AnyTable<{ name: TTableName }>,\n\trelations: (helpers: TableRelationsHelpers<TTableName>) => TRelations,\n): Relations<TTableName, TRelations> {\n\treturn new Relations<TTableName, TRelations>(\n\t\ttable,\n\t\t(helpers: TableRelationsHelpers<TTableName>) =>\n\t\t\tObject.fromEntries(\n\t\t\t\tObject.entries(relations(helpers)).map(([key, value]) => [\n\t\t\t\t\tkey,\n\t\t\t\t\tvalue.withFieldName(key),\n\t\t\t\t]),\n\t\t\t) as TRelations,\n\t);\n}\n\nexport function createOne<TTableName extends string>(sourceTable: Table) {\n\treturn function one<\n\t\tTForeignTable extends Table,\n\t\tTColumns extends [\n\t\t\tAnyColumn<{ tableName: TTableName }>,\n\t\t\t...AnyColumn<{ tableName: TTableName }>[],\n\t\t],\n\t>(\n\t\ttable: TForeignTable,\n\t\tconfig?: RelationConfig<TTableName, TForeignTable['_']['name'], TColumns>,\n\t): One<\n\t\tTForeignTable['_']['name'],\n\t\tEqual<TColumns[number]['_']['notNull'], true>\n\t> {\n\t\treturn new One(\n\t\t\tsourceTable,\n\t\t\ttable,\n\t\t\tconfig,\n\t\t\t(config?.fields.reduce<boolean>((res, f) => res && f.notNull, true)\n\t\t\t\t?? false) as Equal<TColumns[number]['_']['notNull'], true>,\n\t\t);\n\t};\n}\n\nexport function createMany(sourceTable: Table) {\n\treturn function many<TForeignTable extends Table>(\n\t\treferencedTable: TForeignTable,\n\t\tconfig?: { relationName: string },\n\t): Many<TForeignTable['_']['name']> {\n\t\treturn new Many(sourceTable, referencedTable, config);\n\t};\n}\n\nexport interface NormalizedRelation {\n\tfields: AnyColumn[];\n\treferences: AnyColumn[];\n}\n\nexport function normalizeRelation(\n\tschema: TablesRelationalConfig,\n\ttableNamesMap: Record<string, string>,\n\trelation: Relation,\n): NormalizedRelation {\n\tif (is(relation, One) && relation.config) {\n\t\treturn {\n\t\t\tfields: relation.config.fields,\n\t\t\treferences: relation.config.references,\n\t\t};\n\t}\n\n\tconst referencedTableTsName = tableNamesMap[getTableUniqueName(relation.referencedTable)];\n\tif (!referencedTableTsName) {\n\t\tthrow new Error(\n\t\t\t`Table \"${relation.referencedTable[Table.Symbol.Name]}\" not found in schema`,\n\t\t);\n\t}\n\n\tconst referencedTableConfig = schema[referencedTableTsName];\n\tif (!referencedTableConfig) {\n\t\tthrow new Error(`Table \"${referencedTableTsName}\" not found in schema`);\n\t}\n\n\tconst sourceTable = relation.sourceTable;\n\tconst sourceTableTsName = tableNamesMap[getTableUniqueName(sourceTable)];\n\tif (!sourceTableTsName) {\n\t\tthrow new Error(\n\t\t\t`Table \"${sourceTable[Table.Symbol.Name]}\" not found in schema`,\n\t\t);\n\t}\n\n\tconst reverseRelations: Relation[] = [];\n\tfor (\n\t\tconst referencedTableRelation of Object.values(\n\t\t\treferencedTableConfig.relations,\n\t\t)\n\t) {\n\t\tif (\n\t\t\t(relation.relationName\n\t\t\t\t&& relation !== referencedTableRelation\n\t\t\t\t&& referencedTableRelation.relationName === relation.relationName)\n\t\t\t|| (!relation.relationName\n\t\t\t\t&& referencedTableRelation.referencedTable === relation.sourceTable)\n\t\t) {\n\t\t\treverseRelations.push(referencedTableRelation);\n\t\t}\n\t}\n\n\tif (reverseRelations.length > 1) {\n\t\tthrow relation.relationName\n\t\t\t? new Error(\n\t\t\t\t`There are multiple relations with name \"${relation.relationName}\" in table \"${referencedTableTsName}\"`,\n\t\t\t)\n\t\t\t: new Error(\n\t\t\t\t`There are multiple relations between \"${referencedTableTsName}\" and \"${\n\t\t\t\t\trelation.sourceTable[Table.Symbol.Name]\n\t\t\t\t}\". Please specify relation name`,\n\t\t\t);\n\t}\n\n\tif (\n\t\treverseRelations[0]\n\t\t&& is(reverseRelations[0], One)\n\t\t&& reverseRelations[0].config\n\t) {\n\t\treturn {\n\t\t\tfields: reverseRelations[0].config.references,\n\t\t\treferences: reverseRelations[0].config.fields,\n\t\t};\n\t}\n\n\tthrow new Error(\n\t\t`There is not enough information to infer relation \"${sourceTableTsName}.${relation.fieldName}\"`,\n\t);\n}\n\nexport function createTableRelationsHelpers<TTableName extends string>(\n\tsourceTable: AnyTable<{ name: TTableName }>,\n) {\n\treturn {\n\t\tone: createOne<TTableName>(sourceTable),\n\t\tmany: createMany(sourceTable),\n\t};\n}\n\nexport type TableRelationsHelpers<TTableName extends string> = ReturnType<\n\ttypeof createTableRelationsHelpers<TTableName>\n>;\n\nexport interface BuildRelationalQueryResult<\n\tTTable extends Table = Table,\n\tTColumn extends Column = Column,\n> {\n\ttableTsKey: string;\n\tselection: {\n\t\tdbKey: string;\n\t\ttsKey: string;\n\t\tfield: TColumn | SQL | SQL.Aliased;\n\t\trelationTableTsKey: string | undefined;\n\t\tisJson: boolean;\n\t\tisExtra?: boolean;\n\t\tselection: BuildRelationalQueryResult<TTable>['selection'];\n\t}[];\n\tsql: TTable | SQL;\n}\n\nexport function mapRelationalRow(\n\ttablesConfig: TablesRelationalConfig,\n\ttableConfig: TableRelationalConfig,\n\trow: unknown[],\n\tbuildQueryResultSelection: BuildRelationalQueryResult['selection'],\n\tmapColumnValue: (value: unknown) => unknown = (value) => value,\n): Record<string, unknown> {\n\tconst result: Record<string, unknown> = {};\n\n\tfor (\n\t\tconst [\n\t\t\tselectionItemIndex,\n\t\t\tselectionItem,\n\t\t] of buildQueryResultSelection.entries()\n\t) {\n\t\tif (selectionItem.isJson) {\n\t\t\tconst relation = tableConfig.relations[selectionItem.tsKey]!;\n\t\t\tconst rawSubRows = row[selectionItemIndex] as\n\t\t\t\t| unknown[]\n\t\t\t\t| null\n\t\t\t\t| [null]\n\t\t\t\t| string;\n\t\t\tconst subRows = typeof rawSubRows === 'string'\n\t\t\t\t? (JSON.parse(rawSubRows) as unknown[])\n\t\t\t\t: rawSubRows;\n\t\t\tresult[selectionItem.tsKey] = is(relation, One)\n\t\t\t\t? subRows\n\t\t\t\t\t&& mapRelationalRow(\n\t\t\t\t\t\ttablesConfig,\n\t\t\t\t\t\ttablesConfig[selectionItem.relationTableTsKey!]!,\n\t\t\t\t\t\tsubRows,\n\t\t\t\t\t\tselectionItem.selection,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t)\n\t\t\t\t: (subRows as unknown[][]).map((subRow) =>\n\t\t\t\t\tmapRelationalRow(\n\t\t\t\t\t\ttablesConfig,\n\t\t\t\t\t\ttablesConfig[selectionItem.relationTableTsKey!]!,\n\t\t\t\t\t\tsubRow,\n\t\t\t\t\t\tselectionItem.selection,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t} else {\n\t\t\tconst value = mapColumnValue(row[selectionItemIndex]);\n\t\t\tconst field = selectionItem.field!;\n\t\t\tlet decoder;\n\t\t\tif (is(field, Column)) {\n\t\t\t\tdecoder = field;\n\t\t\t} else if (is(field, SQL)) {\n\t\t\t\tdecoder = field.decoder;\n\t\t\t} else {\n\t\t\t\tdecoder = field.sql.decoder;\n\t\t\t}\n\t\t\tresult[selectionItem.tsKey] = value === null ? null : decoder.mapFromDriverValue(value);\n\t\t}\n\t}\n\n\treturn result;\n}\n"],"mappings":"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","names":["relations"]}
1
+ {"version":3,"sources":["../src/_relations.ts"],"sourcesContent":["import { type AnyTable, getTableUniqueName, type InferModelFromColumns, Table } from '~/table.ts';\nimport { type AnyColumn, Column } from './column.ts';\nimport { entityKind, is } from './entity.ts';\nimport { PrimaryKeyBuilder } from './pg-core/primary-keys.ts';\nimport {\n\tand,\n\tasc,\n\tbetween,\n\tdesc,\n\teq,\n\texists,\n\tgt,\n\tgte,\n\tilike,\n\tinArray,\n\tisNotNull,\n\tisNull,\n\tlike,\n\tlt,\n\tlte,\n\tne,\n\tnot,\n\tnotBetween,\n\tnotExists,\n\tnotIlike,\n\tnotInArray,\n\tnotLike,\n\tor,\n} from './sql/expressions/index.ts';\nimport { type Placeholder, SQL, sql } from './sql/sql.ts';\nimport type { Assume, ColumnsWithTable, Equal, Simplify, ValueOrArray } from './utils.ts';\n\nexport abstract class Relation<TTableName extends string = string> {\n\tstatic readonly [entityKind]: string = 'Relation';\n\n\tdeclare readonly $brand: 'Relation';\n\treadonly referencedTableName: TTableName;\n\tfieldName!: string;\n\n\tconstructor(\n\t\treadonly sourceTable: Table,\n\t\treadonly referencedTable: AnyTable<{ name: TTableName }>,\n\t\treadonly relationName: string | undefined,\n\t) {\n\t\tthis.referencedTableName = referencedTable[Table.Symbol.Name] as TTableName;\n\t}\n\n\tabstract withFieldName(fieldName: string): Relation<TTableName>;\n}\n\nexport class Relations<\n\tTTableName extends string = string,\n\tTConfig extends Record<string, Relation> = Record<string, Relation>,\n> {\n\tstatic readonly [entityKind]: string = 'Relations';\n\n\tdeclare readonly $brand: 'Relations';\n\n\tconstructor(\n\t\treadonly table: AnyTable<{ name: TTableName }>,\n\t\treadonly config: (helpers: TableRelationsHelpers<TTableName>) => TConfig,\n\t) {}\n}\n\nexport class One<\n\tTTableName extends string = string,\n\tTIsNullable extends boolean = boolean,\n> extends Relation<TTableName> {\n\tstatic override readonly [entityKind]: string = 'One';\n\n\tdeclare protected $relationBrand: 'One';\n\n\tconstructor(\n\t\tsourceTable: Table,\n\t\treferencedTable: AnyTable<{ name: TTableName }>,\n\t\treadonly config:\n\t\t\t| RelationConfig<\n\t\t\t\tTTableName,\n\t\t\t\tstring,\n\t\t\t\tAnyColumn<{ tableName: TTableName }>[]\n\t\t\t>\n\t\t\t| undefined,\n\t\treadonly isNullable: TIsNullable,\n\t) {\n\t\tsuper(sourceTable, referencedTable, config?.relationName);\n\t}\n\n\twithFieldName(fieldName: string): One<TTableName> {\n\t\tconst relation = new One(\n\t\t\tthis.sourceTable,\n\t\t\tthis.referencedTable,\n\t\t\tthis.config,\n\t\t\tthis.isNullable,\n\t\t);\n\t\trelation.fieldName = fieldName;\n\t\treturn relation;\n\t}\n}\n\nexport class Many<TTableName extends string> extends Relation<TTableName> {\n\tstatic override readonly [entityKind]: string = 'Many';\n\n\tdeclare protected $relationBrand: 'Many';\n\n\tconstructor(\n\t\tsourceTable: Table,\n\t\treferencedTable: AnyTable<{ name: TTableName }>,\n\t\treadonly config: { relationName: string } | undefined,\n\t) {\n\t\tsuper(sourceTable, referencedTable, config?.relationName);\n\t}\n\n\twithFieldName(fieldName: string): Many<TTableName> {\n\t\tconst relation = new Many(\n\t\t\tthis.sourceTable,\n\t\t\tthis.referencedTable,\n\t\t\tthis.config,\n\t\t);\n\t\trelation.fieldName = fieldName;\n\t\treturn relation;\n\t}\n}\n\nexport type TableRelationsKeysOnly<\n\tTSchema extends Record<string, unknown>,\n\tTTableName extends string,\n\tK extends keyof TSchema,\n> = TSchema[K] extends Relations<TTableName> ? K : never;\n\nexport type ExtractTableRelationsFromSchema<\n\tTSchema extends Record<string, unknown>,\n\tTTableName extends string,\n> = ExtractObjectValues<\n\t{\n\t\t[\n\t\t\tK in keyof TSchema as TableRelationsKeysOnly<\n\t\t\t\tTSchema,\n\t\t\t\tTTableName,\n\t\t\t\tK\n\t\t\t>\n\t\t]: TSchema[K] extends Relations<TTableName, infer TConfig> ? TConfig : never;\n\t}\n>;\n\nexport type ExtractObjectValues<T> = T[keyof T];\n\nexport type ExtractRelationsFromTableExtraConfigSchema<\n\tTConfig extends unknown[],\n> = ExtractObjectValues<\n\t{\n\t\t[\n\t\t\tK in keyof TConfig as TConfig[K] extends Relations<any> ? K\n\t\t\t\t: never\n\t\t]: TConfig[K] extends Relations<infer TRelationConfig> ? TRelationConfig\n\t\t\t: never;\n\t}\n>;\n\nexport function getOperators() {\n\treturn {\n\t\tand,\n\t\tbetween,\n\t\teq,\n\t\texists,\n\t\tgt,\n\t\tgte,\n\t\tilike,\n\t\tinArray,\n\t\tisNull,\n\t\tisNotNull,\n\t\tlike,\n\t\tlt,\n\t\tlte,\n\t\tne,\n\t\tnot,\n\t\tnotBetween,\n\t\tnotExists,\n\t\tnotLike,\n\t\tnotIlike,\n\t\tnotInArray,\n\t\tor,\n\t\tsql,\n\t};\n}\n\nexport type Operators = ReturnType<typeof getOperators>;\n\nexport function getOrderByOperators() {\n\treturn {\n\t\tsql,\n\t\tasc,\n\t\tdesc,\n\t};\n}\n\nexport type OrderByOperators = ReturnType<typeof getOrderByOperators>;\n\nexport type FindTableByDBName<\n\tTSchema extends TablesRelationalConfig,\n\tTTableName extends string,\n> = ExtractObjectValues<\n\t{\n\t\t[\n\t\t\tK in keyof TSchema as TSchema[K]['dbName'] extends TTableName ? K\n\t\t\t\t: never\n\t\t]: TSchema[K];\n\t}\n>;\n\nexport type DBQueryConfig<\n\tTRelationType extends 'one' | 'many' = 'one' | 'many',\n\tTIsRoot extends boolean = boolean,\n\tTSchema extends TablesRelationalConfig = TablesRelationalConfig,\n\tTTableConfig extends TableRelationalConfig = TableRelationalConfig,\n> =\n\t& {\n\t\tcolumns?:\n\t\t\t| {\n\t\t\t\t[K in keyof TTableConfig['columns']]?: boolean;\n\t\t\t}\n\t\t\t| undefined;\n\t\twith?:\n\t\t\t| {\n\t\t\t\t[K in keyof TTableConfig['relations']]?:\n\t\t\t\t\t| true\n\t\t\t\t\t| DBQueryConfig<\n\t\t\t\t\t\tTTableConfig['relations'][K] extends One ? 'one' : 'many',\n\t\t\t\t\t\tfalse,\n\t\t\t\t\t\tTSchema,\n\t\t\t\t\t\tFindTableByDBName<\n\t\t\t\t\t\t\tTSchema,\n\t\t\t\t\t\t\tTTableConfig['relations'][K]['referencedTableName']\n\t\t\t\t\t\t>\n\t\t\t\t\t>\n\t\t\t\t\t| undefined;\n\t\t\t}\n\t\t\t| undefined;\n\t\textras?:\n\t\t\t| Record<string, SQL.Aliased>\n\t\t\t| ((\n\t\t\t\tfields: Simplify<\n\t\t\t\t\t[TTableConfig['columns']] extends [never] ? {}\n\t\t\t\t\t\t: TTableConfig['columns']\n\t\t\t\t>,\n\t\t\t\toperators: { sql: Operators['sql'] },\n\t\t\t) => Record<string, SQL.Aliased>)\n\t\t\t| undefined;\n\t}\n\t& (TRelationType extends 'many' ?\n\t\t\t& {\n\t\t\t\twhere?:\n\t\t\t\t\t| SQL\n\t\t\t\t\t| undefined\n\t\t\t\t\t| ((\n\t\t\t\t\t\tfields: Simplify<\n\t\t\t\t\t\t\t[TTableConfig['columns']] extends [never] ? {}\n\t\t\t\t\t\t\t\t: TTableConfig['columns']\n\t\t\t\t\t\t>,\n\t\t\t\t\t\toperators: Operators,\n\t\t\t\t\t) => SQL | undefined);\n\t\t\t\torderBy?:\n\t\t\t\t\t| ValueOrArray<AnyColumn | SQL>\n\t\t\t\t\t| ((\n\t\t\t\t\t\tfields: Simplify<\n\t\t\t\t\t\t\t[TTableConfig['columns']] extends [never] ? {}\n\t\t\t\t\t\t\t\t: TTableConfig['columns']\n\t\t\t\t\t\t>,\n\t\t\t\t\t\toperators: OrderByOperators,\n\t\t\t\t\t) => ValueOrArray<AnyColumn | SQL>)\n\t\t\t\t\t| undefined;\n\t\t\t\tlimit?: number | Placeholder | undefined;\n\t\t\t}\n\t\t\t& (TIsRoot extends true ? {\n\t\t\t\t\toffset?: number | Placeholder | undefined;\n\t\t\t\t}\n\t\t\t\t: {})\n\t\t: {});\n\nexport interface TableRelationalConfig {\n\ttsName: string;\n\tdbName: string;\n\tcolumns: Record<string, Column>;\n\trelations: Record<string, Relation>;\n\tprimaryKey: AnyColumn[];\n\tschema?: string;\n}\n\nexport type TablesRelationalConfig = Record<string, TableRelationalConfig>;\n\nexport interface RelationalSchemaConfig<\n\tTSchema extends TablesRelationalConfig,\n> {\n\tfullSchema: Record<string, unknown>;\n\tschema: TSchema;\n\ttableNamesMap: Record<string, string>;\n}\n\nexport type ExtractTablesWithRelations<\n\tTSchema extends Record<string, unknown>,\n> = {\n\t[\n\t\tK in keyof TSchema as TSchema[K] extends Table ? K\n\t\t\t: never\n\t]: TSchema[K] extends Table ? {\n\t\t\ttsName: K & string;\n\t\t\tdbName: TSchema[K]['_']['name'];\n\t\t\tcolumns: TSchema[K]['_']['columns'];\n\t\t\trelations: ExtractTableRelationsFromSchema<\n\t\t\t\tTSchema,\n\t\t\t\tTSchema[K]['_']['name']\n\t\t\t>;\n\t\t\tprimaryKey: AnyColumn[];\n\t\t}\n\t\t: never;\n};\n\nexport type ReturnTypeOrValue<T> = T extends (...args: any[]) => infer R ? R\n\t: T;\n\nexport type BuildRelationResult<\n\tTSchema extends TablesRelationalConfig,\n\tTInclude,\n\tTRelations extends Record<string, Relation>,\n> = {\n\t[\n\t\tK in\n\t\t\t& NonUndefinedKeysOnly<TInclude>\n\t\t\t& keyof TRelations\n\t]: TRelations[K] extends infer TRel extends Relation ? BuildQueryResult<\n\t\t\tTSchema,\n\t\t\tFindTableByDBName<TSchema, TRel['referencedTableName']>,\n\t\t\tAssume<TInclude[K], true | Record<string, unknown>>\n\t\t> extends infer TResult ? TRel extends One ?\n\t\t\t\t\t| TResult\n\t\t\t\t\t| (Equal<TRel['isNullable'], false> extends true ? null : never)\n\t\t\t: TResult[]\n\t\t: never\n\t\t: never;\n};\n\nexport type NonUndefinedKeysOnly<T> =\n\t& ExtractObjectValues<\n\t\t{\n\t\t\t[K in keyof T as T[K] extends undefined ? never : K]: K;\n\t\t}\n\t>\n\t& keyof T;\n\nexport type BuildQueryResult<\n\tTSchema extends TablesRelationalConfig,\n\tTTableConfig extends TableRelationalConfig,\n\tTFullSelection extends true | Record<string, unknown>,\n> = Equal<TFullSelection, true> extends true ? InferModelFromColumns<TTableConfig['columns']>\n\t: TFullSelection extends Record<string, unknown> ? Simplify<\n\t\t\t& (TFullSelection['columns'] extends Record<string, unknown> ? InferModelFromColumns<\n\t\t\t\t\t{\n\t\t\t\t\t\t[\n\t\t\t\t\t\t\tK in Equal<\n\t\t\t\t\t\t\t\tExclude<\n\t\t\t\t\t\t\t\t\tTFullSelection['columns'][\n\t\t\t\t\t\t\t\t\t\t& keyof TFullSelection['columns']\n\t\t\t\t\t\t\t\t\t\t& keyof TTableConfig['columns']\n\t\t\t\t\t\t\t\t\t],\n\t\t\t\t\t\t\t\t\tundefined\n\t\t\t\t\t\t\t\t>,\n\t\t\t\t\t\t\t\tfalse\n\t\t\t\t\t\t\t> extends true ? Exclude<\n\t\t\t\t\t\t\t\t\tkeyof TTableConfig['columns'],\n\t\t\t\t\t\t\t\t\tNonUndefinedKeysOnly<TFullSelection['columns']>\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t:\n\t\t\t\t\t\t\t\t\t& {\n\t\t\t\t\t\t\t\t\t\t[K in keyof TFullSelection['columns']]: Equal<\n\t\t\t\t\t\t\t\t\t\t\tTFullSelection['columns'][K],\n\t\t\t\t\t\t\t\t\t\t\ttrue\n\t\t\t\t\t\t\t\t\t\t> extends true ? K\n\t\t\t\t\t\t\t\t\t\t\t: never;\n\t\t\t\t\t\t\t\t\t}[keyof TFullSelection['columns']]\n\t\t\t\t\t\t\t\t\t& keyof TTableConfig['columns']\n\t\t\t\t\t\t]: TTableConfig['columns'][K];\n\t\t\t\t\t}\n\t\t\t\t>\n\t\t\t\t: InferModelFromColumns<TTableConfig['columns']>)\n\t\t\t& (TFullSelection['extras'] extends\n\t\t\t\t| Record<string, unknown>\n\t\t\t\t| ((...args: any[]) => Record<string, unknown>) ? {\n\t\t\t\t\t[\n\t\t\t\t\t\tK in NonUndefinedKeysOnly<\n\t\t\t\t\t\t\tReturnTypeOrValue<TFullSelection['extras']>\n\t\t\t\t\t\t>\n\t\t\t\t\t]: Assume<\n\t\t\t\t\t\tReturnTypeOrValue<TFullSelection['extras']>[K],\n\t\t\t\t\t\tSQL.Aliased\n\t\t\t\t\t>['_']['type'];\n\t\t\t\t}\n\t\t\t\t: {})\n\t\t\t& (TFullSelection['with'] extends Record<string, unknown> ? BuildRelationResult<\n\t\t\t\t\tTSchema,\n\t\t\t\t\tTFullSelection['with'],\n\t\t\t\t\tTTableConfig['relations']\n\t\t\t\t>\n\t\t\t\t: {})\n\t\t>\n\t: never;\n\nexport interface RelationConfig<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends AnyColumn<{ tableName: TTableName }>[],\n> {\n\trelationName?: string;\n\tfields: TColumns;\n\treferences: ColumnsWithTable<TTableName, TForeignTableName, TColumns>;\n}\n\nexport function extractTablesRelationalConfig<\n\tTTables extends TablesRelationalConfig,\n>(\n\tschema: Record<string, unknown>,\n\tconfigHelpers: (table: Table) => any,\n): { tables: TTables; tableNamesMap: Record<string, string> } {\n\tif (\n\t\tObject.keys(schema).length === 1\n\t\t&& 'default' in schema\n\t\t&& !is(schema['default'], Table)\n\t) {\n\t\tschema = schema['default'] as Record<string, unknown>;\n\t}\n\n\t// table DB name -> schema table key\n\tconst tableNamesMap: Record<string, string> = {};\n\t// Table relations found before their tables - need to buffer them until we know the schema table key\n\tconst relationsBuffer: Record<\n\t\tstring,\n\t\t{ relations: Record<string, Relation>; primaryKey?: AnyColumn[] }\n\t> = {};\n\tconst tablesConfig: TablesRelationalConfig = {};\n\tfor (const [key, value] of Object.entries(schema)) {\n\t\tif (is(value, Table)) {\n\t\t\tconst dbName = getTableUniqueName(value);\n\t\t\tconst bufferedRelations = relationsBuffer[dbName];\n\t\t\ttableNamesMap[dbName] = key;\n\t\t\ttablesConfig[key] = {\n\t\t\t\ttsName: key,\n\t\t\t\tdbName: value[Table.Symbol.Name],\n\t\t\t\tschema: value[Table.Symbol.Schema],\n\t\t\t\tcolumns: value[Table.Symbol.Columns],\n\t\t\t\trelations: bufferedRelations?.relations ?? {},\n\t\t\t\tprimaryKey: bufferedRelations?.primaryKey ?? [],\n\t\t\t};\n\n\t\t\t// Fill in primary keys\n\t\t\tfor (\n\t\t\t\tconst column of Object.values(\n\t\t\t\t\t(value as Table)[Table.Symbol.Columns],\n\t\t\t\t)\n\t\t\t) {\n\t\t\t\tif (column.primary) {\n\t\t\t\t\ttablesConfig[key]!.primaryKey.push(column);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst extraConfig = value[Table.Symbol.ExtraConfigBuilder]?.((value as Table)[Table.Symbol.ExtraConfigColumns]);\n\t\t\tif (extraConfig) {\n\t\t\t\tfor (const configEntry of Object.values(extraConfig)) {\n\t\t\t\t\tif (is(configEntry, PrimaryKeyBuilder)) {\n\t\t\t\t\t\ttablesConfig[key]!.primaryKey.push(...configEntry.columns);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} else if (is(value, Relations)) {\n\t\t\tconst dbName = getTableUniqueName(value.table);\n\t\t\tconst tableName = tableNamesMap[dbName];\n\t\t\tconst relations: Record<string, Relation> = value.config(\n\t\t\t\tconfigHelpers(value.table),\n\t\t\t);\n\t\t\t// let primaryKey: AnyColumn[] | undefined;\n\n\t\t\tfor (const [relationName, relation] of Object.entries(relations)) {\n\t\t\t\tif (tableName) {\n\t\t\t\t\tconst tableConfig = tablesConfig[tableName]!;\n\t\t\t\t\ttableConfig.relations[relationName] = relation;\n\t\t\t\t\t// if (primaryKey) {\n\t\t\t\t\t// \ttableConfig.primaryKey.push(...primaryKey);\n\t\t\t\t\t// }\n\t\t\t\t} else {\n\t\t\t\t\tif (!(dbName in relationsBuffer)) {\n\t\t\t\t\t\trelationsBuffer[dbName] = {\n\t\t\t\t\t\t\trelations: {},\n\t\t\t\t\t\t\t// primaryKey,\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t\trelationsBuffer[dbName]!.relations[relationName] = relation;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn { tables: tablesConfig as TTables, tableNamesMap };\n}\n\nexport function relations<\n\tTTableName extends string,\n\tTRelations extends Record<string, Relation<any>>,\n>(\n\ttable: AnyTable<{ name: TTableName }>,\n\trelations: (helpers: TableRelationsHelpers<TTableName>) => TRelations,\n): Relations<TTableName, TRelations> {\n\treturn new Relations<TTableName, TRelations>(\n\t\ttable,\n\t\t(helpers: TableRelationsHelpers<TTableName>) =>\n\t\t\tObject.fromEntries(\n\t\t\t\tObject.entries(relations(helpers)).map(([key, value]) => [\n\t\t\t\t\tkey,\n\t\t\t\t\tvalue.withFieldName(key),\n\t\t\t\t]),\n\t\t\t) as TRelations,\n\t);\n}\n\nexport function createOne<TTableName extends string>(sourceTable: Table) {\n\treturn function one<\n\t\tTForeignTable extends Table,\n\t\tTColumns extends [\n\t\t\tAnyColumn<{ tableName: TTableName }>,\n\t\t\t...AnyColumn<{ tableName: TTableName }>[],\n\t\t],\n\t>(\n\t\ttable: TForeignTable,\n\t\tconfig?: RelationConfig<TTableName, TForeignTable['_']['name'], TColumns>,\n\t): One<\n\t\tTForeignTable['_']['name'],\n\t\tEqual<TColumns[number]['_']['notNull'], true>\n\t> {\n\t\treturn new One(\n\t\t\tsourceTable,\n\t\t\ttable,\n\t\t\tconfig,\n\t\t\t(config?.fields.reduce<boolean>((res, f) => res && f.notNull, true)\n\t\t\t\t?? false) as Equal<TColumns[number]['_']['notNull'], true>,\n\t\t);\n\t};\n}\n\nexport function createMany(sourceTable: Table) {\n\treturn function many<TForeignTable extends Table>(\n\t\treferencedTable: TForeignTable,\n\t\tconfig?: { relationName: string },\n\t): Many<TForeignTable['_']['name']> {\n\t\treturn new Many(sourceTable, referencedTable, config);\n\t};\n}\n\nexport interface NormalizedRelation {\n\tfields: AnyColumn[];\n\treferences: AnyColumn[];\n}\n\nexport function normalizeRelation(\n\tschema: TablesRelationalConfig,\n\ttableNamesMap: Record<string, string>,\n\trelation: Relation,\n): NormalizedRelation {\n\tif (is(relation, One) && relation.config) {\n\t\treturn {\n\t\t\tfields: relation.config.fields,\n\t\t\treferences: relation.config.references,\n\t\t};\n\t}\n\n\tconst referencedTableTsName = tableNamesMap[getTableUniqueName(relation.referencedTable)];\n\tif (!referencedTableTsName) {\n\t\tthrow new Error(\n\t\t\t`Table \"${relation.referencedTable[Table.Symbol.Name]}\" not found in schema`,\n\t\t);\n\t}\n\n\tconst referencedTableConfig = schema[referencedTableTsName];\n\tif (!referencedTableConfig) {\n\t\tthrow new Error(`Table \"${referencedTableTsName}\" not found in schema`);\n\t}\n\n\tconst sourceTable = relation.sourceTable;\n\tconst sourceTableTsName = tableNamesMap[getTableUniqueName(sourceTable)];\n\tif (!sourceTableTsName) {\n\t\tthrow new Error(\n\t\t\t`Table \"${sourceTable[Table.Symbol.Name]}\" not found in schema`,\n\t\t);\n\t}\n\n\tconst reverseRelations: Relation[] = [];\n\tfor (\n\t\tconst referencedTableRelation of Object.values(\n\t\t\treferencedTableConfig.relations,\n\t\t)\n\t) {\n\t\tif (\n\t\t\t(relation.relationName\n\t\t\t\t&& relation !== referencedTableRelation\n\t\t\t\t&& referencedTableRelation.relationName === relation.relationName)\n\t\t\t|| (!relation.relationName\n\t\t\t\t&& referencedTableRelation.referencedTable === relation.sourceTable)\n\t\t) {\n\t\t\treverseRelations.push(referencedTableRelation);\n\t\t}\n\t}\n\n\tif (reverseRelations.length > 1) {\n\t\tthrow relation.relationName\n\t\t\t? new Error(\n\t\t\t\t`There are multiple relations with name \"${relation.relationName}\" in table \"${referencedTableTsName}\"`,\n\t\t\t)\n\t\t\t: new Error(\n\t\t\t\t`There are multiple relations between \"${referencedTableTsName}\" and \"${\n\t\t\t\t\trelation.sourceTable[Table.Symbol.Name]\n\t\t\t\t}\". Please specify relation name`,\n\t\t\t);\n\t}\n\n\tif (\n\t\treverseRelations[0]\n\t\t&& is(reverseRelations[0], One)\n\t\t&& reverseRelations[0].config\n\t) {\n\t\treturn {\n\t\t\tfields: reverseRelations[0].config.references,\n\t\t\treferences: reverseRelations[0].config.fields,\n\t\t};\n\t}\n\n\tthrow new Error(\n\t\t`There is not enough information to infer relation \"${sourceTableTsName}.${relation.fieldName}\"`,\n\t);\n}\n\nexport function createTableRelationsHelpers<TTableName extends string>(\n\tsourceTable: AnyTable<{ name: TTableName }>,\n) {\n\treturn {\n\t\tone: createOne<TTableName>(sourceTable),\n\t\tmany: createMany(sourceTable),\n\t};\n}\n\nexport type TableRelationsHelpers<TTableName extends string> = ReturnType<\n\ttypeof createTableRelationsHelpers<TTableName>\n>;\n\nexport interface BuildRelationalQueryResult<\n\tTTable extends Table = Table,\n\tTColumn extends Column = Column,\n> {\n\ttableTsKey: string;\n\tselection: {\n\t\tdbKey: string;\n\t\ttsKey: string;\n\t\tfield: TColumn | SQL | SQL.Aliased;\n\t\trelationTableTsKey: string | undefined;\n\t\tisJson: boolean;\n\t\tisExtra?: boolean;\n\t\tselection: BuildRelationalQueryResult<TTable>['selection'];\n\t}[];\n\tsql: TTable | SQL;\n}\n\nexport function mapRelationalRow(\n\ttablesConfig: TablesRelationalConfig,\n\ttableConfig: TableRelationalConfig,\n\trow: unknown[],\n\tbuildQueryResultSelection: BuildRelationalQueryResult['selection'],\n\tmapColumnValue: (value: unknown) => unknown = (value) => value,\n): Record<string, unknown> {\n\tconst result: Record<string, unknown> = {};\n\n\tfor (\n\t\tconst [\n\t\t\tselectionItemIndex,\n\t\t\tselectionItem,\n\t\t] of buildQueryResultSelection.entries()\n\t) {\n\t\tif (selectionItem.isJson) {\n\t\t\tconst relation = tableConfig.relations[selectionItem.tsKey]!;\n\t\t\tconst rawSubRows = row[selectionItemIndex] as\n\t\t\t\t| unknown[]\n\t\t\t\t| null\n\t\t\t\t| [null]\n\t\t\t\t| string;\n\t\t\tconst subRows = typeof rawSubRows === 'string'\n\t\t\t\t? (JSON.parse(rawSubRows) as unknown[])\n\t\t\t\t: rawSubRows;\n\t\t\tresult[selectionItem.tsKey] = is(relation, One)\n\t\t\t\t? subRows\n\t\t\t\t\t&& mapRelationalRow(\n\t\t\t\t\t\ttablesConfig,\n\t\t\t\t\t\ttablesConfig[selectionItem.relationTableTsKey!]!,\n\t\t\t\t\t\tsubRows,\n\t\t\t\t\t\tselectionItem.selection,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t)\n\t\t\t\t: (subRows as unknown[][]).map((subRow) =>\n\t\t\t\t\tmapRelationalRow(\n\t\t\t\t\t\ttablesConfig,\n\t\t\t\t\t\ttablesConfig[selectionItem.relationTableTsKey!]!,\n\t\t\t\t\t\tsubRow,\n\t\t\t\t\t\tselectionItem.selection,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t} else {\n\t\t\tconst value = mapColumnValue(row[selectionItemIndex]);\n\t\t\tconst field = selectionItem.field!;\n\t\t\tlet decoder;\n\t\t\tif (is(field, Column)) {\n\t\t\t\tdecoder = field;\n\t\t\t} else if (is(field, SQL)) {\n\t\t\t\tdecoder = field.decoder;\n\t\t\t} else {\n\t\t\t\tdecoder = field.sql.decoder;\n\t\t\t}\n\t\t\tresult[selectionItem.tsKey] = value === null ? null : decoder.mapFromDriverValue(value);\n\t\t}\n\t}\n\n\treturn result;\n}\n\nexport function mapRelationalRowFromObj(\n\ttablesConfig: TablesRelationalConfig,\n\ttableConfig: TableRelationalConfig,\n\trow: unknown[],\n\tbuildQueryResultSelection: BuildRelationalQueryResult['selection'],\n\tmapColumnValue: (value: unknown) => unknown = (value) => value,\n): Record<string, unknown> {\n\tconst result: Record<string, unknown> = {};\n\n\tfor (\n\t\tconst [\n\t\t\tselectionItemIndex,\n\t\t\tselectionItem,\n\t\t] of buildQueryResultSelection.entries()\n\t) {\n\t\tif (selectionItem.isJson) {\n\t\t\tconst relation = tableConfig.relations[selectionItem.tsKey]!;\n\t\t\tconst isOne = is(relation, One);\n\t\t\tconst rawSubRows = row[selectionItemIndex] as unknown[] | null | [null] | string;\n\n\t\t\tlet subRows = rawSubRows as unknown[] | null;\n\t\t\tif (subRows || Array.isArray(subRows)) {\n\t\t\t\tsubRows = (typeof rawSubRows === 'string' ? JSON.parse(rawSubRows) : rawSubRows) as unknown[];\n\n\t\t\t\tsubRows = isOne\n\t\t\t\t\t? subRows.flatMap((r) => Array.isArray(r) ? r : Object.values(r as any))\n\t\t\t\t\t: subRows.map((r) => Array.isArray(r) ? r : Object.values(r as any));\n\t\t\t}\n\n\t\t\tresult[selectionItem.tsKey] = isOne\n\t\t\t\t? subRows\n\t\t\t\t\t&& mapRelationalRowFromObj(\n\t\t\t\t\t\ttablesConfig,\n\t\t\t\t\t\ttablesConfig[selectionItem.relationTableTsKey!]!,\n\t\t\t\t\t\tsubRows,\n\t\t\t\t\t\tselectionItem.selection,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t)\n\t\t\t\t: ((subRows ?? []) as unknown[][]).map((subRow) =>\n\t\t\t\t\tmapRelationalRowFromObj(\n\t\t\t\t\t\ttablesConfig,\n\t\t\t\t\t\ttablesConfig[selectionItem.relationTableTsKey!]!,\n\t\t\t\t\t\tsubRow,\n\t\t\t\t\t\tselectionItem.selection,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t} else {\n\t\t\tconst value = mapColumnValue(row[selectionItemIndex]);\n\t\t\tconst field = selectionItem.field!;\n\t\t\tlet decoder;\n\t\t\tif (is(field, Column)) {\n\t\t\t\tdecoder = field;\n\t\t\t} else if (is(field, SQL)) {\n\t\t\t\tdecoder = field.decoder;\n\t\t\t} else {\n\t\t\t\tdecoder = field.sql.decoder;\n\t\t\t}\n\t\t\tresult[selectionItem.tsKey] = value === null ? null : decoder.mapFromDriverValue(value);\n\t\t}\n\t}\n\n\treturn result;\n}\n"],"mappings":"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","names":["relations"]}
package/_relations.d.cts CHANGED
@@ -213,3 +213,4 @@ export interface BuildRelationalQueryResult<TTable extends Table = Table, TColum
213
213
  sql: TTable | SQL;
214
214
  }
215
215
  export declare function mapRelationalRow(tablesConfig: TablesRelationalConfig, tableConfig: TableRelationalConfig, row: unknown[], buildQueryResultSelection: BuildRelationalQueryResult['selection'], mapColumnValue?: (value: unknown) => unknown): Record<string, unknown>;
216
+ export declare function mapRelationalRowFromObj(tablesConfig: TablesRelationalConfig, tableConfig: TableRelationalConfig, row: unknown[], buildQueryResultSelection: BuildRelationalQueryResult['selection'], mapColumnValue?: (value: unknown) => unknown): Record<string, unknown>;
package/_relations.d.ts CHANGED
@@ -213,3 +213,4 @@ export interface BuildRelationalQueryResult<TTable extends Table = Table, TColum
213
213
  sql: TTable | SQL;
214
214
  }
215
215
  export declare function mapRelationalRow(tablesConfig: TablesRelationalConfig, tableConfig: TableRelationalConfig, row: unknown[], buildQueryResultSelection: BuildRelationalQueryResult['selection'], mapColumnValue?: (value: unknown) => unknown): Record<string, unknown>;
216
+ export declare function mapRelationalRowFromObj(tablesConfig: TablesRelationalConfig, tableConfig: TableRelationalConfig, row: unknown[], buildQueryResultSelection: BuildRelationalQueryResult['selection'], mapColumnValue?: (value: unknown) => unknown): Record<string, unknown>;
package/_relations.js CHANGED
@@ -154,19 +154,15 @@ function extractTablesRelationalConfig(schema, configHelpers) {
154
154
  const relations2 = value.config(
155
155
  configHelpers(value.table)
156
156
  );
157
- let primaryKey;
158
157
  for (const [relationName, relation] of Object.entries(relations2)) {
159
158
  if (tableName) {
160
159
  const tableConfig = tablesConfig[tableName];
161
160
  tableConfig.relations[relationName] = relation;
162
- if (primaryKey) {
163
- tableConfig.primaryKey.push(...primaryKey);
164
- }
165
161
  } else {
166
162
  if (!(dbName in relationsBuffer)) {
167
163
  relationsBuffer[dbName] = {
168
- relations: {},
169
- primaryKey
164
+ relations: {}
165
+ // primaryKey,
170
166
  };
171
167
  }
172
168
  relationsBuffer[dbName].relations[relationName] = relation;
@@ -298,6 +294,52 @@ function mapRelationalRow(tablesConfig, tableConfig, row, buildQueryResultSelect
298
294
  }
299
295
  return result;
300
296
  }
297
+ function mapRelationalRowFromObj(tablesConfig, tableConfig, row, buildQueryResultSelection, mapColumnValue = (value) => value) {
298
+ const result = {};
299
+ for (const [
300
+ selectionItemIndex,
301
+ selectionItem
302
+ ] of buildQueryResultSelection.entries()) {
303
+ if (selectionItem.isJson) {
304
+ const relation = tableConfig.relations[selectionItem.tsKey];
305
+ const isOne = is(relation, One);
306
+ const rawSubRows = row[selectionItemIndex];
307
+ let subRows = rawSubRows;
308
+ if (subRows || Array.isArray(subRows)) {
309
+ subRows = typeof rawSubRows === "string" ? JSON.parse(rawSubRows) : rawSubRows;
310
+ subRows = isOne ? subRows.flatMap((r) => Array.isArray(r) ? r : Object.values(r)) : subRows.map((r) => Array.isArray(r) ? r : Object.values(r));
311
+ }
312
+ result[selectionItem.tsKey] = isOne ? subRows && mapRelationalRowFromObj(
313
+ tablesConfig,
314
+ tablesConfig[selectionItem.relationTableTsKey],
315
+ subRows,
316
+ selectionItem.selection,
317
+ mapColumnValue
318
+ ) : (subRows ?? []).map(
319
+ (subRow) => mapRelationalRowFromObj(
320
+ tablesConfig,
321
+ tablesConfig[selectionItem.relationTableTsKey],
322
+ subRow,
323
+ selectionItem.selection,
324
+ mapColumnValue
325
+ )
326
+ );
327
+ } else {
328
+ const value = mapColumnValue(row[selectionItemIndex]);
329
+ const field = selectionItem.field;
330
+ let decoder;
331
+ if (is(field, Column)) {
332
+ decoder = field;
333
+ } else if (is(field, SQL)) {
334
+ decoder = field.decoder;
335
+ } else {
336
+ decoder = field.sql.decoder;
337
+ }
338
+ result[selectionItem.tsKey] = value === null ? null : decoder.mapFromDriverValue(value);
339
+ }
340
+ }
341
+ return result;
342
+ }
301
343
  export {
302
344
  Many,
303
345
  One,
@@ -310,6 +352,7 @@ export {
310
352
  getOperators,
311
353
  getOrderByOperators,
312
354
  mapRelationalRow,
355
+ mapRelationalRowFromObj,
313
356
  normalizeRelation,
314
357
  relations
315
358
  };
package/_relations.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/_relations.ts"],"sourcesContent":["import { type AnyTable, getTableUniqueName, type InferModelFromColumns, Table } from '~/table.ts';\nimport { type AnyColumn, Column } from './column.ts';\nimport { entityKind, is } from './entity.ts';\nimport { PrimaryKeyBuilder } from './pg-core/primary-keys.ts';\nimport {\n\tand,\n\tasc,\n\tbetween,\n\tdesc,\n\teq,\n\texists,\n\tgt,\n\tgte,\n\tilike,\n\tinArray,\n\tisNotNull,\n\tisNull,\n\tlike,\n\tlt,\n\tlte,\n\tne,\n\tnot,\n\tnotBetween,\n\tnotExists,\n\tnotIlike,\n\tnotInArray,\n\tnotLike,\n\tor,\n} from './sql/expressions/index.ts';\nimport { type Placeholder, SQL, sql } from './sql/sql.ts';\nimport type { Assume, ColumnsWithTable, Equal, Simplify, ValueOrArray } from './utils.ts';\n\nexport abstract class Relation<TTableName extends string = string> {\n\tstatic readonly [entityKind]: string = 'Relation';\n\n\tdeclare readonly $brand: 'Relation';\n\treadonly referencedTableName: TTableName;\n\tfieldName!: string;\n\n\tconstructor(\n\t\treadonly sourceTable: Table,\n\t\treadonly referencedTable: AnyTable<{ name: TTableName }>,\n\t\treadonly relationName: string | undefined,\n\t) {\n\t\tthis.referencedTableName = referencedTable[Table.Symbol.Name] as TTableName;\n\t}\n\n\tabstract withFieldName(fieldName: string): Relation<TTableName>;\n}\n\nexport class Relations<\n\tTTableName extends string = string,\n\tTConfig extends Record<string, Relation> = Record<string, Relation>,\n> {\n\tstatic readonly [entityKind]: string = 'Relations';\n\n\tdeclare readonly $brand: 'Relations';\n\n\tconstructor(\n\t\treadonly table: AnyTable<{ name: TTableName }>,\n\t\treadonly config: (helpers: TableRelationsHelpers<TTableName>) => TConfig,\n\t) {}\n}\n\nexport class One<\n\tTTableName extends string = string,\n\tTIsNullable extends boolean = boolean,\n> extends Relation<TTableName> {\n\tstatic override readonly [entityKind]: string = 'One';\n\n\tdeclare protected $relationBrand: 'One';\n\n\tconstructor(\n\t\tsourceTable: Table,\n\t\treferencedTable: AnyTable<{ name: TTableName }>,\n\t\treadonly config:\n\t\t\t| RelationConfig<\n\t\t\t\tTTableName,\n\t\t\t\tstring,\n\t\t\t\tAnyColumn<{ tableName: TTableName }>[]\n\t\t\t>\n\t\t\t| undefined,\n\t\treadonly isNullable: TIsNullable,\n\t) {\n\t\tsuper(sourceTable, referencedTable, config?.relationName);\n\t}\n\n\twithFieldName(fieldName: string): One<TTableName> {\n\t\tconst relation = new One(\n\t\t\tthis.sourceTable,\n\t\t\tthis.referencedTable,\n\t\t\tthis.config,\n\t\t\tthis.isNullable,\n\t\t);\n\t\trelation.fieldName = fieldName;\n\t\treturn relation;\n\t}\n}\n\nexport class Many<TTableName extends string> extends Relation<TTableName> {\n\tstatic override readonly [entityKind]: string = 'Many';\n\n\tdeclare protected $relationBrand: 'Many';\n\n\tconstructor(\n\t\tsourceTable: Table,\n\t\treferencedTable: AnyTable<{ name: TTableName }>,\n\t\treadonly config: { relationName: string } | undefined,\n\t) {\n\t\tsuper(sourceTable, referencedTable, config?.relationName);\n\t}\n\n\twithFieldName(fieldName: string): Many<TTableName> {\n\t\tconst relation = new Many(\n\t\t\tthis.sourceTable,\n\t\t\tthis.referencedTable,\n\t\t\tthis.config,\n\t\t);\n\t\trelation.fieldName = fieldName;\n\t\treturn relation;\n\t}\n}\n\nexport type TableRelationsKeysOnly<\n\tTSchema extends Record<string, unknown>,\n\tTTableName extends string,\n\tK extends keyof TSchema,\n> = TSchema[K] extends Relations<TTableName> ? K : never;\n\nexport type ExtractTableRelationsFromSchema<\n\tTSchema extends Record<string, unknown>,\n\tTTableName extends string,\n> = ExtractObjectValues<\n\t{\n\t\t[\n\t\t\tK in keyof TSchema as TableRelationsKeysOnly<\n\t\t\t\tTSchema,\n\t\t\t\tTTableName,\n\t\t\t\tK\n\t\t\t>\n\t\t]: TSchema[K] extends Relations<TTableName, infer TConfig> ? TConfig : never;\n\t}\n>;\n\nexport type ExtractObjectValues<T> = T[keyof T];\n\nexport type ExtractRelationsFromTableExtraConfigSchema<\n\tTConfig extends unknown[],\n> = ExtractObjectValues<\n\t{\n\t\t[\n\t\t\tK in keyof TConfig as TConfig[K] extends Relations<any> ? K\n\t\t\t\t: never\n\t\t]: TConfig[K] extends Relations<infer TRelationConfig> ? TRelationConfig\n\t\t\t: never;\n\t}\n>;\n\nexport function getOperators() {\n\treturn {\n\t\tand,\n\t\tbetween,\n\t\teq,\n\t\texists,\n\t\tgt,\n\t\tgte,\n\t\tilike,\n\t\tinArray,\n\t\tisNull,\n\t\tisNotNull,\n\t\tlike,\n\t\tlt,\n\t\tlte,\n\t\tne,\n\t\tnot,\n\t\tnotBetween,\n\t\tnotExists,\n\t\tnotLike,\n\t\tnotIlike,\n\t\tnotInArray,\n\t\tor,\n\t\tsql,\n\t};\n}\n\nexport type Operators = ReturnType<typeof getOperators>;\n\nexport function getOrderByOperators() {\n\treturn {\n\t\tsql,\n\t\tasc,\n\t\tdesc,\n\t};\n}\n\nexport type OrderByOperators = ReturnType<typeof getOrderByOperators>;\n\nexport type FindTableByDBName<\n\tTSchema extends TablesRelationalConfig,\n\tTTableName extends string,\n> = ExtractObjectValues<\n\t{\n\t\t[\n\t\t\tK in keyof TSchema as TSchema[K]['dbName'] extends TTableName ? K\n\t\t\t\t: never\n\t\t]: TSchema[K];\n\t}\n>;\n\nexport type DBQueryConfig<\n\tTRelationType extends 'one' | 'many' = 'one' | 'many',\n\tTIsRoot extends boolean = boolean,\n\tTSchema extends TablesRelationalConfig = TablesRelationalConfig,\n\tTTableConfig extends TableRelationalConfig = TableRelationalConfig,\n> =\n\t& {\n\t\tcolumns?:\n\t\t\t| {\n\t\t\t\t[K in keyof TTableConfig['columns']]?: boolean;\n\t\t\t}\n\t\t\t| undefined;\n\t\twith?:\n\t\t\t| {\n\t\t\t\t[K in keyof TTableConfig['relations']]?:\n\t\t\t\t\t| true\n\t\t\t\t\t| DBQueryConfig<\n\t\t\t\t\t\tTTableConfig['relations'][K] extends One ? 'one' : 'many',\n\t\t\t\t\t\tfalse,\n\t\t\t\t\t\tTSchema,\n\t\t\t\t\t\tFindTableByDBName<\n\t\t\t\t\t\t\tTSchema,\n\t\t\t\t\t\t\tTTableConfig['relations'][K]['referencedTableName']\n\t\t\t\t\t\t>\n\t\t\t\t\t>\n\t\t\t\t\t| undefined;\n\t\t\t}\n\t\t\t| undefined;\n\t\textras?:\n\t\t\t| Record<string, SQL.Aliased>\n\t\t\t| ((\n\t\t\t\tfields: Simplify<\n\t\t\t\t\t[TTableConfig['columns']] extends [never] ? {}\n\t\t\t\t\t\t: TTableConfig['columns']\n\t\t\t\t>,\n\t\t\t\toperators: { sql: Operators['sql'] },\n\t\t\t) => Record<string, SQL.Aliased>)\n\t\t\t| undefined;\n\t}\n\t& (TRelationType extends 'many' ?\n\t\t\t& {\n\t\t\t\twhere?:\n\t\t\t\t\t| SQL\n\t\t\t\t\t| undefined\n\t\t\t\t\t| ((\n\t\t\t\t\t\tfields: Simplify<\n\t\t\t\t\t\t\t[TTableConfig['columns']] extends [never] ? {}\n\t\t\t\t\t\t\t\t: TTableConfig['columns']\n\t\t\t\t\t\t>,\n\t\t\t\t\t\toperators: Operators,\n\t\t\t\t\t) => SQL | undefined);\n\t\t\t\torderBy?:\n\t\t\t\t\t| ValueOrArray<AnyColumn | SQL>\n\t\t\t\t\t| ((\n\t\t\t\t\t\tfields: Simplify<\n\t\t\t\t\t\t\t[TTableConfig['columns']] extends [never] ? {}\n\t\t\t\t\t\t\t\t: TTableConfig['columns']\n\t\t\t\t\t\t>,\n\t\t\t\t\t\toperators: OrderByOperators,\n\t\t\t\t\t) => ValueOrArray<AnyColumn | SQL>)\n\t\t\t\t\t| undefined;\n\t\t\t\tlimit?: number | Placeholder | undefined;\n\t\t\t}\n\t\t\t& (TIsRoot extends true ? {\n\t\t\t\t\toffset?: number | Placeholder | undefined;\n\t\t\t\t}\n\t\t\t\t: {})\n\t\t: {});\n\nexport interface TableRelationalConfig {\n\ttsName: string;\n\tdbName: string;\n\tcolumns: Record<string, Column>;\n\trelations: Record<string, Relation>;\n\tprimaryKey: AnyColumn[];\n\tschema?: string;\n}\n\nexport type TablesRelationalConfig = Record<string, TableRelationalConfig>;\n\nexport interface RelationalSchemaConfig<\n\tTSchema extends TablesRelationalConfig,\n> {\n\tfullSchema: Record<string, unknown>;\n\tschema: TSchema;\n\ttableNamesMap: Record<string, string>;\n}\n\nexport type ExtractTablesWithRelations<\n\tTSchema extends Record<string, unknown>,\n> = {\n\t[\n\t\tK in keyof TSchema as TSchema[K] extends Table ? K\n\t\t\t: never\n\t]: TSchema[K] extends Table ? {\n\t\t\ttsName: K & string;\n\t\t\tdbName: TSchema[K]['_']['name'];\n\t\t\tcolumns: TSchema[K]['_']['columns'];\n\t\t\trelations: ExtractTableRelationsFromSchema<\n\t\t\t\tTSchema,\n\t\t\t\tTSchema[K]['_']['name']\n\t\t\t>;\n\t\t\tprimaryKey: AnyColumn[];\n\t\t}\n\t\t: never;\n};\n\nexport type ReturnTypeOrValue<T> = T extends (...args: any[]) => infer R ? R\n\t: T;\n\nexport type BuildRelationResult<\n\tTSchema extends TablesRelationalConfig,\n\tTInclude,\n\tTRelations extends Record<string, Relation>,\n> = {\n\t[\n\t\tK in\n\t\t\t& NonUndefinedKeysOnly<TInclude>\n\t\t\t& keyof TRelations\n\t]: TRelations[K] extends infer TRel extends Relation ? BuildQueryResult<\n\t\t\tTSchema,\n\t\t\tFindTableByDBName<TSchema, TRel['referencedTableName']>,\n\t\t\tAssume<TInclude[K], true | Record<string, unknown>>\n\t\t> extends infer TResult ? TRel extends One ?\n\t\t\t\t\t| TResult\n\t\t\t\t\t| (Equal<TRel['isNullable'], false> extends true ? null : never)\n\t\t\t: TResult[]\n\t\t: never\n\t\t: never;\n};\n\nexport type NonUndefinedKeysOnly<T> =\n\t& ExtractObjectValues<\n\t\t{\n\t\t\t[K in keyof T as T[K] extends undefined ? never : K]: K;\n\t\t}\n\t>\n\t& keyof T;\n\nexport type BuildQueryResult<\n\tTSchema extends TablesRelationalConfig,\n\tTTableConfig extends TableRelationalConfig,\n\tTFullSelection extends true | Record<string, unknown>,\n> = Equal<TFullSelection, true> extends true ? InferModelFromColumns<TTableConfig['columns']>\n\t: TFullSelection extends Record<string, unknown> ? Simplify<\n\t\t\t& (TFullSelection['columns'] extends Record<string, unknown> ? InferModelFromColumns<\n\t\t\t\t\t{\n\t\t\t\t\t\t[\n\t\t\t\t\t\t\tK in Equal<\n\t\t\t\t\t\t\t\tExclude<\n\t\t\t\t\t\t\t\t\tTFullSelection['columns'][\n\t\t\t\t\t\t\t\t\t\t& keyof TFullSelection['columns']\n\t\t\t\t\t\t\t\t\t\t& keyof TTableConfig['columns']\n\t\t\t\t\t\t\t\t\t],\n\t\t\t\t\t\t\t\t\tundefined\n\t\t\t\t\t\t\t\t>,\n\t\t\t\t\t\t\t\tfalse\n\t\t\t\t\t\t\t> extends true ? Exclude<\n\t\t\t\t\t\t\t\t\tkeyof TTableConfig['columns'],\n\t\t\t\t\t\t\t\t\tNonUndefinedKeysOnly<TFullSelection['columns']>\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t:\n\t\t\t\t\t\t\t\t\t& {\n\t\t\t\t\t\t\t\t\t\t[K in keyof TFullSelection['columns']]: Equal<\n\t\t\t\t\t\t\t\t\t\t\tTFullSelection['columns'][K],\n\t\t\t\t\t\t\t\t\t\t\ttrue\n\t\t\t\t\t\t\t\t\t\t> extends true ? K\n\t\t\t\t\t\t\t\t\t\t\t: never;\n\t\t\t\t\t\t\t\t\t}[keyof TFullSelection['columns']]\n\t\t\t\t\t\t\t\t\t& keyof TTableConfig['columns']\n\t\t\t\t\t\t]: TTableConfig['columns'][K];\n\t\t\t\t\t}\n\t\t\t\t>\n\t\t\t\t: InferModelFromColumns<TTableConfig['columns']>)\n\t\t\t& (TFullSelection['extras'] extends\n\t\t\t\t| Record<string, unknown>\n\t\t\t\t| ((...args: any[]) => Record<string, unknown>) ? {\n\t\t\t\t\t[\n\t\t\t\t\t\tK in NonUndefinedKeysOnly<\n\t\t\t\t\t\t\tReturnTypeOrValue<TFullSelection['extras']>\n\t\t\t\t\t\t>\n\t\t\t\t\t]: Assume<\n\t\t\t\t\t\tReturnTypeOrValue<TFullSelection['extras']>[K],\n\t\t\t\t\t\tSQL.Aliased\n\t\t\t\t\t>['_']['type'];\n\t\t\t\t}\n\t\t\t\t: {})\n\t\t\t& (TFullSelection['with'] extends Record<string, unknown> ? BuildRelationResult<\n\t\t\t\t\tTSchema,\n\t\t\t\t\tTFullSelection['with'],\n\t\t\t\t\tTTableConfig['relations']\n\t\t\t\t>\n\t\t\t\t: {})\n\t\t>\n\t: never;\n\nexport interface RelationConfig<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends AnyColumn<{ tableName: TTableName }>[],\n> {\n\trelationName?: string;\n\tfields: TColumns;\n\treferences: ColumnsWithTable<TTableName, TForeignTableName, TColumns>;\n}\n\nexport function extractTablesRelationalConfig<\n\tTTables extends TablesRelationalConfig,\n>(\n\tschema: Record<string, unknown>,\n\tconfigHelpers: (table: Table) => any,\n): { tables: TTables; tableNamesMap: Record<string, string> } {\n\tif (\n\t\tObject.keys(schema).length === 1\n\t\t&& 'default' in schema\n\t\t&& !is(schema['default'], Table)\n\t) {\n\t\tschema = schema['default'] as Record<string, unknown>;\n\t}\n\n\t// table DB name -> schema table key\n\tconst tableNamesMap: Record<string, string> = {};\n\t// Table relations found before their tables - need to buffer them until we know the schema table key\n\tconst relationsBuffer: Record<\n\t\tstring,\n\t\t{ relations: Record<string, Relation>; primaryKey?: AnyColumn[] }\n\t> = {};\n\tconst tablesConfig: TablesRelationalConfig = {};\n\tfor (const [key, value] of Object.entries(schema)) {\n\t\tif (is(value, Table)) {\n\t\t\tconst dbName = getTableUniqueName(value);\n\t\t\tconst bufferedRelations = relationsBuffer[dbName];\n\t\t\ttableNamesMap[dbName] = key;\n\t\t\ttablesConfig[key] = {\n\t\t\t\ttsName: key,\n\t\t\t\tdbName: value[Table.Symbol.Name],\n\t\t\t\tschema: value[Table.Symbol.Schema],\n\t\t\t\tcolumns: value[Table.Symbol.Columns],\n\t\t\t\trelations: bufferedRelations?.relations ?? {},\n\t\t\t\tprimaryKey: bufferedRelations?.primaryKey ?? [],\n\t\t\t};\n\n\t\t\t// Fill in primary keys\n\t\t\tfor (\n\t\t\t\tconst column of Object.values(\n\t\t\t\t\t(value as Table)[Table.Symbol.Columns],\n\t\t\t\t)\n\t\t\t) {\n\t\t\t\tif (column.primary) {\n\t\t\t\t\ttablesConfig[key]!.primaryKey.push(column);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst extraConfig = value[Table.Symbol.ExtraConfigBuilder]?.((value as Table)[Table.Symbol.ExtraConfigColumns]);\n\t\t\tif (extraConfig) {\n\t\t\t\tfor (const configEntry of Object.values(extraConfig)) {\n\t\t\t\t\tif (is(configEntry, PrimaryKeyBuilder)) {\n\t\t\t\t\t\ttablesConfig[key]!.primaryKey.push(...configEntry.columns);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} else if (is(value, Relations)) {\n\t\t\tconst dbName = getTableUniqueName(value.table);\n\t\t\tconst tableName = tableNamesMap[dbName];\n\t\t\tconst relations: Record<string, Relation> = value.config(\n\t\t\t\tconfigHelpers(value.table),\n\t\t\t);\n\t\t\tlet primaryKey: AnyColumn[] | undefined;\n\n\t\t\tfor (const [relationName, relation] of Object.entries(relations)) {\n\t\t\t\tif (tableName) {\n\t\t\t\t\tconst tableConfig = tablesConfig[tableName]!;\n\t\t\t\t\ttableConfig.relations[relationName] = relation;\n\t\t\t\t\tif (primaryKey) {\n\t\t\t\t\t\ttableConfig.primaryKey.push(...primaryKey);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tif (!(dbName in relationsBuffer)) {\n\t\t\t\t\t\trelationsBuffer[dbName] = {\n\t\t\t\t\t\t\trelations: {},\n\t\t\t\t\t\t\tprimaryKey,\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t\trelationsBuffer[dbName]!.relations[relationName] = relation;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn { tables: tablesConfig as TTables, tableNamesMap };\n}\n\nexport function relations<\n\tTTableName extends string,\n\tTRelations extends Record<string, Relation<any>>,\n>(\n\ttable: AnyTable<{ name: TTableName }>,\n\trelations: (helpers: TableRelationsHelpers<TTableName>) => TRelations,\n): Relations<TTableName, TRelations> {\n\treturn new Relations<TTableName, TRelations>(\n\t\ttable,\n\t\t(helpers: TableRelationsHelpers<TTableName>) =>\n\t\t\tObject.fromEntries(\n\t\t\t\tObject.entries(relations(helpers)).map(([key, value]) => [\n\t\t\t\t\tkey,\n\t\t\t\t\tvalue.withFieldName(key),\n\t\t\t\t]),\n\t\t\t) as TRelations,\n\t);\n}\n\nexport function createOne<TTableName extends string>(sourceTable: Table) {\n\treturn function one<\n\t\tTForeignTable extends Table,\n\t\tTColumns extends [\n\t\t\tAnyColumn<{ tableName: TTableName }>,\n\t\t\t...AnyColumn<{ tableName: TTableName }>[],\n\t\t],\n\t>(\n\t\ttable: TForeignTable,\n\t\tconfig?: RelationConfig<TTableName, TForeignTable['_']['name'], TColumns>,\n\t): One<\n\t\tTForeignTable['_']['name'],\n\t\tEqual<TColumns[number]['_']['notNull'], true>\n\t> {\n\t\treturn new One(\n\t\t\tsourceTable,\n\t\t\ttable,\n\t\t\tconfig,\n\t\t\t(config?.fields.reduce<boolean>((res, f) => res && f.notNull, true)\n\t\t\t\t?? false) as Equal<TColumns[number]['_']['notNull'], true>,\n\t\t);\n\t};\n}\n\nexport function createMany(sourceTable: Table) {\n\treturn function many<TForeignTable extends Table>(\n\t\treferencedTable: TForeignTable,\n\t\tconfig?: { relationName: string },\n\t): Many<TForeignTable['_']['name']> {\n\t\treturn new Many(sourceTable, referencedTable, config);\n\t};\n}\n\nexport interface NormalizedRelation {\n\tfields: AnyColumn[];\n\treferences: AnyColumn[];\n}\n\nexport function normalizeRelation(\n\tschema: TablesRelationalConfig,\n\ttableNamesMap: Record<string, string>,\n\trelation: Relation,\n): NormalizedRelation {\n\tif (is(relation, One) && relation.config) {\n\t\treturn {\n\t\t\tfields: relation.config.fields,\n\t\t\treferences: relation.config.references,\n\t\t};\n\t}\n\n\tconst referencedTableTsName = tableNamesMap[getTableUniqueName(relation.referencedTable)];\n\tif (!referencedTableTsName) {\n\t\tthrow new Error(\n\t\t\t`Table \"${relation.referencedTable[Table.Symbol.Name]}\" not found in schema`,\n\t\t);\n\t}\n\n\tconst referencedTableConfig = schema[referencedTableTsName];\n\tif (!referencedTableConfig) {\n\t\tthrow new Error(`Table \"${referencedTableTsName}\" not found in schema`);\n\t}\n\n\tconst sourceTable = relation.sourceTable;\n\tconst sourceTableTsName = tableNamesMap[getTableUniqueName(sourceTable)];\n\tif (!sourceTableTsName) {\n\t\tthrow new Error(\n\t\t\t`Table \"${sourceTable[Table.Symbol.Name]}\" not found in schema`,\n\t\t);\n\t}\n\n\tconst reverseRelations: Relation[] = [];\n\tfor (\n\t\tconst referencedTableRelation of Object.values(\n\t\t\treferencedTableConfig.relations,\n\t\t)\n\t) {\n\t\tif (\n\t\t\t(relation.relationName\n\t\t\t\t&& relation !== referencedTableRelation\n\t\t\t\t&& referencedTableRelation.relationName === relation.relationName)\n\t\t\t|| (!relation.relationName\n\t\t\t\t&& referencedTableRelation.referencedTable === relation.sourceTable)\n\t\t) {\n\t\t\treverseRelations.push(referencedTableRelation);\n\t\t}\n\t}\n\n\tif (reverseRelations.length > 1) {\n\t\tthrow relation.relationName\n\t\t\t? new Error(\n\t\t\t\t`There are multiple relations with name \"${relation.relationName}\" in table \"${referencedTableTsName}\"`,\n\t\t\t)\n\t\t\t: new Error(\n\t\t\t\t`There are multiple relations between \"${referencedTableTsName}\" and \"${\n\t\t\t\t\trelation.sourceTable[Table.Symbol.Name]\n\t\t\t\t}\". Please specify relation name`,\n\t\t\t);\n\t}\n\n\tif (\n\t\treverseRelations[0]\n\t\t&& is(reverseRelations[0], One)\n\t\t&& reverseRelations[0].config\n\t) {\n\t\treturn {\n\t\t\tfields: reverseRelations[0].config.references,\n\t\t\treferences: reverseRelations[0].config.fields,\n\t\t};\n\t}\n\n\tthrow new Error(\n\t\t`There is not enough information to infer relation \"${sourceTableTsName}.${relation.fieldName}\"`,\n\t);\n}\n\nexport function createTableRelationsHelpers<TTableName extends string>(\n\tsourceTable: AnyTable<{ name: TTableName }>,\n) {\n\treturn {\n\t\tone: createOne<TTableName>(sourceTable),\n\t\tmany: createMany(sourceTable),\n\t};\n}\n\nexport type TableRelationsHelpers<TTableName extends string> = ReturnType<\n\ttypeof createTableRelationsHelpers<TTableName>\n>;\n\nexport interface BuildRelationalQueryResult<\n\tTTable extends Table = Table,\n\tTColumn extends Column = Column,\n> {\n\ttableTsKey: string;\n\tselection: {\n\t\tdbKey: string;\n\t\ttsKey: string;\n\t\tfield: TColumn | SQL | SQL.Aliased;\n\t\trelationTableTsKey: string | undefined;\n\t\tisJson: boolean;\n\t\tisExtra?: boolean;\n\t\tselection: BuildRelationalQueryResult<TTable>['selection'];\n\t}[];\n\tsql: TTable | SQL;\n}\n\nexport function mapRelationalRow(\n\ttablesConfig: TablesRelationalConfig,\n\ttableConfig: TableRelationalConfig,\n\trow: unknown[],\n\tbuildQueryResultSelection: BuildRelationalQueryResult['selection'],\n\tmapColumnValue: (value: unknown) => unknown = (value) => value,\n): Record<string, unknown> {\n\tconst result: Record<string, unknown> = {};\n\n\tfor (\n\t\tconst [\n\t\t\tselectionItemIndex,\n\t\t\tselectionItem,\n\t\t] of buildQueryResultSelection.entries()\n\t) {\n\t\tif (selectionItem.isJson) {\n\t\t\tconst relation = tableConfig.relations[selectionItem.tsKey]!;\n\t\t\tconst rawSubRows = row[selectionItemIndex] as\n\t\t\t\t| unknown[]\n\t\t\t\t| null\n\t\t\t\t| [null]\n\t\t\t\t| string;\n\t\t\tconst subRows = typeof rawSubRows === 'string'\n\t\t\t\t? (JSON.parse(rawSubRows) as unknown[])\n\t\t\t\t: rawSubRows;\n\t\t\tresult[selectionItem.tsKey] = is(relation, One)\n\t\t\t\t? subRows\n\t\t\t\t\t&& mapRelationalRow(\n\t\t\t\t\t\ttablesConfig,\n\t\t\t\t\t\ttablesConfig[selectionItem.relationTableTsKey!]!,\n\t\t\t\t\t\tsubRows,\n\t\t\t\t\t\tselectionItem.selection,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t)\n\t\t\t\t: (subRows as unknown[][]).map((subRow) =>\n\t\t\t\t\tmapRelationalRow(\n\t\t\t\t\t\ttablesConfig,\n\t\t\t\t\t\ttablesConfig[selectionItem.relationTableTsKey!]!,\n\t\t\t\t\t\tsubRow,\n\t\t\t\t\t\tselectionItem.selection,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t} else {\n\t\t\tconst value = mapColumnValue(row[selectionItemIndex]);\n\t\t\tconst field = selectionItem.field!;\n\t\t\tlet decoder;\n\t\t\tif (is(field, Column)) {\n\t\t\t\tdecoder = field;\n\t\t\t} else if (is(field, SQL)) {\n\t\t\t\tdecoder = field.decoder;\n\t\t\t} else {\n\t\t\t\tdecoder = field.sql.decoder;\n\t\t\t}\n\t\t\tresult[selectionItem.tsKey] = value === null ? null : decoder.mapFromDriverValue(value);\n\t\t}\n\t}\n\n\treturn result;\n}\n"],"mappings":"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","names":["relations"]}
1
+ {"version":3,"sources":["../src/_relations.ts"],"sourcesContent":["import { type AnyTable, getTableUniqueName, type InferModelFromColumns, Table } from '~/table.ts';\nimport { type AnyColumn, Column } from './column.ts';\nimport { entityKind, is } from './entity.ts';\nimport { PrimaryKeyBuilder } from './pg-core/primary-keys.ts';\nimport {\n\tand,\n\tasc,\n\tbetween,\n\tdesc,\n\teq,\n\texists,\n\tgt,\n\tgte,\n\tilike,\n\tinArray,\n\tisNotNull,\n\tisNull,\n\tlike,\n\tlt,\n\tlte,\n\tne,\n\tnot,\n\tnotBetween,\n\tnotExists,\n\tnotIlike,\n\tnotInArray,\n\tnotLike,\n\tor,\n} from './sql/expressions/index.ts';\nimport { type Placeholder, SQL, sql } from './sql/sql.ts';\nimport type { Assume, ColumnsWithTable, Equal, Simplify, ValueOrArray } from './utils.ts';\n\nexport abstract class Relation<TTableName extends string = string> {\n\tstatic readonly [entityKind]: string = 'Relation';\n\n\tdeclare readonly $brand: 'Relation';\n\treadonly referencedTableName: TTableName;\n\tfieldName!: string;\n\n\tconstructor(\n\t\treadonly sourceTable: Table,\n\t\treadonly referencedTable: AnyTable<{ name: TTableName }>,\n\t\treadonly relationName: string | undefined,\n\t) {\n\t\tthis.referencedTableName = referencedTable[Table.Symbol.Name] as TTableName;\n\t}\n\n\tabstract withFieldName(fieldName: string): Relation<TTableName>;\n}\n\nexport class Relations<\n\tTTableName extends string = string,\n\tTConfig extends Record<string, Relation> = Record<string, Relation>,\n> {\n\tstatic readonly [entityKind]: string = 'Relations';\n\n\tdeclare readonly $brand: 'Relations';\n\n\tconstructor(\n\t\treadonly table: AnyTable<{ name: TTableName }>,\n\t\treadonly config: (helpers: TableRelationsHelpers<TTableName>) => TConfig,\n\t) {}\n}\n\nexport class One<\n\tTTableName extends string = string,\n\tTIsNullable extends boolean = boolean,\n> extends Relation<TTableName> {\n\tstatic override readonly [entityKind]: string = 'One';\n\n\tdeclare protected $relationBrand: 'One';\n\n\tconstructor(\n\t\tsourceTable: Table,\n\t\treferencedTable: AnyTable<{ name: TTableName }>,\n\t\treadonly config:\n\t\t\t| RelationConfig<\n\t\t\t\tTTableName,\n\t\t\t\tstring,\n\t\t\t\tAnyColumn<{ tableName: TTableName }>[]\n\t\t\t>\n\t\t\t| undefined,\n\t\treadonly isNullable: TIsNullable,\n\t) {\n\t\tsuper(sourceTable, referencedTable, config?.relationName);\n\t}\n\n\twithFieldName(fieldName: string): One<TTableName> {\n\t\tconst relation = new One(\n\t\t\tthis.sourceTable,\n\t\t\tthis.referencedTable,\n\t\t\tthis.config,\n\t\t\tthis.isNullable,\n\t\t);\n\t\trelation.fieldName = fieldName;\n\t\treturn relation;\n\t}\n}\n\nexport class Many<TTableName extends string> extends Relation<TTableName> {\n\tstatic override readonly [entityKind]: string = 'Many';\n\n\tdeclare protected $relationBrand: 'Many';\n\n\tconstructor(\n\t\tsourceTable: Table,\n\t\treferencedTable: AnyTable<{ name: TTableName }>,\n\t\treadonly config: { relationName: string } | undefined,\n\t) {\n\t\tsuper(sourceTable, referencedTable, config?.relationName);\n\t}\n\n\twithFieldName(fieldName: string): Many<TTableName> {\n\t\tconst relation = new Many(\n\t\t\tthis.sourceTable,\n\t\t\tthis.referencedTable,\n\t\t\tthis.config,\n\t\t);\n\t\trelation.fieldName = fieldName;\n\t\treturn relation;\n\t}\n}\n\nexport type TableRelationsKeysOnly<\n\tTSchema extends Record<string, unknown>,\n\tTTableName extends string,\n\tK extends keyof TSchema,\n> = TSchema[K] extends Relations<TTableName> ? K : never;\n\nexport type ExtractTableRelationsFromSchema<\n\tTSchema extends Record<string, unknown>,\n\tTTableName extends string,\n> = ExtractObjectValues<\n\t{\n\t\t[\n\t\t\tK in keyof TSchema as TableRelationsKeysOnly<\n\t\t\t\tTSchema,\n\t\t\t\tTTableName,\n\t\t\t\tK\n\t\t\t>\n\t\t]: TSchema[K] extends Relations<TTableName, infer TConfig> ? TConfig : never;\n\t}\n>;\n\nexport type ExtractObjectValues<T> = T[keyof T];\n\nexport type ExtractRelationsFromTableExtraConfigSchema<\n\tTConfig extends unknown[],\n> = ExtractObjectValues<\n\t{\n\t\t[\n\t\t\tK in keyof TConfig as TConfig[K] extends Relations<any> ? K\n\t\t\t\t: never\n\t\t]: TConfig[K] extends Relations<infer TRelationConfig> ? TRelationConfig\n\t\t\t: never;\n\t}\n>;\n\nexport function getOperators() {\n\treturn {\n\t\tand,\n\t\tbetween,\n\t\teq,\n\t\texists,\n\t\tgt,\n\t\tgte,\n\t\tilike,\n\t\tinArray,\n\t\tisNull,\n\t\tisNotNull,\n\t\tlike,\n\t\tlt,\n\t\tlte,\n\t\tne,\n\t\tnot,\n\t\tnotBetween,\n\t\tnotExists,\n\t\tnotLike,\n\t\tnotIlike,\n\t\tnotInArray,\n\t\tor,\n\t\tsql,\n\t};\n}\n\nexport type Operators = ReturnType<typeof getOperators>;\n\nexport function getOrderByOperators() {\n\treturn {\n\t\tsql,\n\t\tasc,\n\t\tdesc,\n\t};\n}\n\nexport type OrderByOperators = ReturnType<typeof getOrderByOperators>;\n\nexport type FindTableByDBName<\n\tTSchema extends TablesRelationalConfig,\n\tTTableName extends string,\n> = ExtractObjectValues<\n\t{\n\t\t[\n\t\t\tK in keyof TSchema as TSchema[K]['dbName'] extends TTableName ? K\n\t\t\t\t: never\n\t\t]: TSchema[K];\n\t}\n>;\n\nexport type DBQueryConfig<\n\tTRelationType extends 'one' | 'many' = 'one' | 'many',\n\tTIsRoot extends boolean = boolean,\n\tTSchema extends TablesRelationalConfig = TablesRelationalConfig,\n\tTTableConfig extends TableRelationalConfig = TableRelationalConfig,\n> =\n\t& {\n\t\tcolumns?:\n\t\t\t| {\n\t\t\t\t[K in keyof TTableConfig['columns']]?: boolean;\n\t\t\t}\n\t\t\t| undefined;\n\t\twith?:\n\t\t\t| {\n\t\t\t\t[K in keyof TTableConfig['relations']]?:\n\t\t\t\t\t| true\n\t\t\t\t\t| DBQueryConfig<\n\t\t\t\t\t\tTTableConfig['relations'][K] extends One ? 'one' : 'many',\n\t\t\t\t\t\tfalse,\n\t\t\t\t\t\tTSchema,\n\t\t\t\t\t\tFindTableByDBName<\n\t\t\t\t\t\t\tTSchema,\n\t\t\t\t\t\t\tTTableConfig['relations'][K]['referencedTableName']\n\t\t\t\t\t\t>\n\t\t\t\t\t>\n\t\t\t\t\t| undefined;\n\t\t\t}\n\t\t\t| undefined;\n\t\textras?:\n\t\t\t| Record<string, SQL.Aliased>\n\t\t\t| ((\n\t\t\t\tfields: Simplify<\n\t\t\t\t\t[TTableConfig['columns']] extends [never] ? {}\n\t\t\t\t\t\t: TTableConfig['columns']\n\t\t\t\t>,\n\t\t\t\toperators: { sql: Operators['sql'] },\n\t\t\t) => Record<string, SQL.Aliased>)\n\t\t\t| undefined;\n\t}\n\t& (TRelationType extends 'many' ?\n\t\t\t& {\n\t\t\t\twhere?:\n\t\t\t\t\t| SQL\n\t\t\t\t\t| undefined\n\t\t\t\t\t| ((\n\t\t\t\t\t\tfields: Simplify<\n\t\t\t\t\t\t\t[TTableConfig['columns']] extends [never] ? {}\n\t\t\t\t\t\t\t\t: TTableConfig['columns']\n\t\t\t\t\t\t>,\n\t\t\t\t\t\toperators: Operators,\n\t\t\t\t\t) => SQL | undefined);\n\t\t\t\torderBy?:\n\t\t\t\t\t| ValueOrArray<AnyColumn | SQL>\n\t\t\t\t\t| ((\n\t\t\t\t\t\tfields: Simplify<\n\t\t\t\t\t\t\t[TTableConfig['columns']] extends [never] ? {}\n\t\t\t\t\t\t\t\t: TTableConfig['columns']\n\t\t\t\t\t\t>,\n\t\t\t\t\t\toperators: OrderByOperators,\n\t\t\t\t\t) => ValueOrArray<AnyColumn | SQL>)\n\t\t\t\t\t| undefined;\n\t\t\t\tlimit?: number | Placeholder | undefined;\n\t\t\t}\n\t\t\t& (TIsRoot extends true ? {\n\t\t\t\t\toffset?: number | Placeholder | undefined;\n\t\t\t\t}\n\t\t\t\t: {})\n\t\t: {});\n\nexport interface TableRelationalConfig {\n\ttsName: string;\n\tdbName: string;\n\tcolumns: Record<string, Column>;\n\trelations: Record<string, Relation>;\n\tprimaryKey: AnyColumn[];\n\tschema?: string;\n}\n\nexport type TablesRelationalConfig = Record<string, TableRelationalConfig>;\n\nexport interface RelationalSchemaConfig<\n\tTSchema extends TablesRelationalConfig,\n> {\n\tfullSchema: Record<string, unknown>;\n\tschema: TSchema;\n\ttableNamesMap: Record<string, string>;\n}\n\nexport type ExtractTablesWithRelations<\n\tTSchema extends Record<string, unknown>,\n> = {\n\t[\n\t\tK in keyof TSchema as TSchema[K] extends Table ? K\n\t\t\t: never\n\t]: TSchema[K] extends Table ? {\n\t\t\ttsName: K & string;\n\t\t\tdbName: TSchema[K]['_']['name'];\n\t\t\tcolumns: TSchema[K]['_']['columns'];\n\t\t\trelations: ExtractTableRelationsFromSchema<\n\t\t\t\tTSchema,\n\t\t\t\tTSchema[K]['_']['name']\n\t\t\t>;\n\t\t\tprimaryKey: AnyColumn[];\n\t\t}\n\t\t: never;\n};\n\nexport type ReturnTypeOrValue<T> = T extends (...args: any[]) => infer R ? R\n\t: T;\n\nexport type BuildRelationResult<\n\tTSchema extends TablesRelationalConfig,\n\tTInclude,\n\tTRelations extends Record<string, Relation>,\n> = {\n\t[\n\t\tK in\n\t\t\t& NonUndefinedKeysOnly<TInclude>\n\t\t\t& keyof TRelations\n\t]: TRelations[K] extends infer TRel extends Relation ? BuildQueryResult<\n\t\t\tTSchema,\n\t\t\tFindTableByDBName<TSchema, TRel['referencedTableName']>,\n\t\t\tAssume<TInclude[K], true | Record<string, unknown>>\n\t\t> extends infer TResult ? TRel extends One ?\n\t\t\t\t\t| TResult\n\t\t\t\t\t| (Equal<TRel['isNullable'], false> extends true ? null : never)\n\t\t\t: TResult[]\n\t\t: never\n\t\t: never;\n};\n\nexport type NonUndefinedKeysOnly<T> =\n\t& ExtractObjectValues<\n\t\t{\n\t\t\t[K in keyof T as T[K] extends undefined ? never : K]: K;\n\t\t}\n\t>\n\t& keyof T;\n\nexport type BuildQueryResult<\n\tTSchema extends TablesRelationalConfig,\n\tTTableConfig extends TableRelationalConfig,\n\tTFullSelection extends true | Record<string, unknown>,\n> = Equal<TFullSelection, true> extends true ? InferModelFromColumns<TTableConfig['columns']>\n\t: TFullSelection extends Record<string, unknown> ? Simplify<\n\t\t\t& (TFullSelection['columns'] extends Record<string, unknown> ? InferModelFromColumns<\n\t\t\t\t\t{\n\t\t\t\t\t\t[\n\t\t\t\t\t\t\tK in Equal<\n\t\t\t\t\t\t\t\tExclude<\n\t\t\t\t\t\t\t\t\tTFullSelection['columns'][\n\t\t\t\t\t\t\t\t\t\t& keyof TFullSelection['columns']\n\t\t\t\t\t\t\t\t\t\t& keyof TTableConfig['columns']\n\t\t\t\t\t\t\t\t\t],\n\t\t\t\t\t\t\t\t\tundefined\n\t\t\t\t\t\t\t\t>,\n\t\t\t\t\t\t\t\tfalse\n\t\t\t\t\t\t\t> extends true ? Exclude<\n\t\t\t\t\t\t\t\t\tkeyof TTableConfig['columns'],\n\t\t\t\t\t\t\t\t\tNonUndefinedKeysOnly<TFullSelection['columns']>\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t:\n\t\t\t\t\t\t\t\t\t& {\n\t\t\t\t\t\t\t\t\t\t[K in keyof TFullSelection['columns']]: Equal<\n\t\t\t\t\t\t\t\t\t\t\tTFullSelection['columns'][K],\n\t\t\t\t\t\t\t\t\t\t\ttrue\n\t\t\t\t\t\t\t\t\t\t> extends true ? K\n\t\t\t\t\t\t\t\t\t\t\t: never;\n\t\t\t\t\t\t\t\t\t}[keyof TFullSelection['columns']]\n\t\t\t\t\t\t\t\t\t& keyof TTableConfig['columns']\n\t\t\t\t\t\t]: TTableConfig['columns'][K];\n\t\t\t\t\t}\n\t\t\t\t>\n\t\t\t\t: InferModelFromColumns<TTableConfig['columns']>)\n\t\t\t& (TFullSelection['extras'] extends\n\t\t\t\t| Record<string, unknown>\n\t\t\t\t| ((...args: any[]) => Record<string, unknown>) ? {\n\t\t\t\t\t[\n\t\t\t\t\t\tK in NonUndefinedKeysOnly<\n\t\t\t\t\t\t\tReturnTypeOrValue<TFullSelection['extras']>\n\t\t\t\t\t\t>\n\t\t\t\t\t]: Assume<\n\t\t\t\t\t\tReturnTypeOrValue<TFullSelection['extras']>[K],\n\t\t\t\t\t\tSQL.Aliased\n\t\t\t\t\t>['_']['type'];\n\t\t\t\t}\n\t\t\t\t: {})\n\t\t\t& (TFullSelection['with'] extends Record<string, unknown> ? BuildRelationResult<\n\t\t\t\t\tTSchema,\n\t\t\t\t\tTFullSelection['with'],\n\t\t\t\t\tTTableConfig['relations']\n\t\t\t\t>\n\t\t\t\t: {})\n\t\t>\n\t: never;\n\nexport interface RelationConfig<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends AnyColumn<{ tableName: TTableName }>[],\n> {\n\trelationName?: string;\n\tfields: TColumns;\n\treferences: ColumnsWithTable<TTableName, TForeignTableName, TColumns>;\n}\n\nexport function extractTablesRelationalConfig<\n\tTTables extends TablesRelationalConfig,\n>(\n\tschema: Record<string, unknown>,\n\tconfigHelpers: (table: Table) => any,\n): { tables: TTables; tableNamesMap: Record<string, string> } {\n\tif (\n\t\tObject.keys(schema).length === 1\n\t\t&& 'default' in schema\n\t\t&& !is(schema['default'], Table)\n\t) {\n\t\tschema = schema['default'] as Record<string, unknown>;\n\t}\n\n\t// table DB name -> schema table key\n\tconst tableNamesMap: Record<string, string> = {};\n\t// Table relations found before their tables - need to buffer them until we know the schema table key\n\tconst relationsBuffer: Record<\n\t\tstring,\n\t\t{ relations: Record<string, Relation>; primaryKey?: AnyColumn[] }\n\t> = {};\n\tconst tablesConfig: TablesRelationalConfig = {};\n\tfor (const [key, value] of Object.entries(schema)) {\n\t\tif (is(value, Table)) {\n\t\t\tconst dbName = getTableUniqueName(value);\n\t\t\tconst bufferedRelations = relationsBuffer[dbName];\n\t\t\ttableNamesMap[dbName] = key;\n\t\t\ttablesConfig[key] = {\n\t\t\t\ttsName: key,\n\t\t\t\tdbName: value[Table.Symbol.Name],\n\t\t\t\tschema: value[Table.Symbol.Schema],\n\t\t\t\tcolumns: value[Table.Symbol.Columns],\n\t\t\t\trelations: bufferedRelations?.relations ?? {},\n\t\t\t\tprimaryKey: bufferedRelations?.primaryKey ?? [],\n\t\t\t};\n\n\t\t\t// Fill in primary keys\n\t\t\tfor (\n\t\t\t\tconst column of Object.values(\n\t\t\t\t\t(value as Table)[Table.Symbol.Columns],\n\t\t\t\t)\n\t\t\t) {\n\t\t\t\tif (column.primary) {\n\t\t\t\t\ttablesConfig[key]!.primaryKey.push(column);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst extraConfig = value[Table.Symbol.ExtraConfigBuilder]?.((value as Table)[Table.Symbol.ExtraConfigColumns]);\n\t\t\tif (extraConfig) {\n\t\t\t\tfor (const configEntry of Object.values(extraConfig)) {\n\t\t\t\t\tif (is(configEntry, PrimaryKeyBuilder)) {\n\t\t\t\t\t\ttablesConfig[key]!.primaryKey.push(...configEntry.columns);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} else if (is(value, Relations)) {\n\t\t\tconst dbName = getTableUniqueName(value.table);\n\t\t\tconst tableName = tableNamesMap[dbName];\n\t\t\tconst relations: Record<string, Relation> = value.config(\n\t\t\t\tconfigHelpers(value.table),\n\t\t\t);\n\t\t\t// let primaryKey: AnyColumn[] | undefined;\n\n\t\t\tfor (const [relationName, relation] of Object.entries(relations)) {\n\t\t\t\tif (tableName) {\n\t\t\t\t\tconst tableConfig = tablesConfig[tableName]!;\n\t\t\t\t\ttableConfig.relations[relationName] = relation;\n\t\t\t\t\t// if (primaryKey) {\n\t\t\t\t\t// \ttableConfig.primaryKey.push(...primaryKey);\n\t\t\t\t\t// }\n\t\t\t\t} else {\n\t\t\t\t\tif (!(dbName in relationsBuffer)) {\n\t\t\t\t\t\trelationsBuffer[dbName] = {\n\t\t\t\t\t\t\trelations: {},\n\t\t\t\t\t\t\t// primaryKey,\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t\trelationsBuffer[dbName]!.relations[relationName] = relation;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn { tables: tablesConfig as TTables, tableNamesMap };\n}\n\nexport function relations<\n\tTTableName extends string,\n\tTRelations extends Record<string, Relation<any>>,\n>(\n\ttable: AnyTable<{ name: TTableName }>,\n\trelations: (helpers: TableRelationsHelpers<TTableName>) => TRelations,\n): Relations<TTableName, TRelations> {\n\treturn new Relations<TTableName, TRelations>(\n\t\ttable,\n\t\t(helpers: TableRelationsHelpers<TTableName>) =>\n\t\t\tObject.fromEntries(\n\t\t\t\tObject.entries(relations(helpers)).map(([key, value]) => [\n\t\t\t\t\tkey,\n\t\t\t\t\tvalue.withFieldName(key),\n\t\t\t\t]),\n\t\t\t) as TRelations,\n\t);\n}\n\nexport function createOne<TTableName extends string>(sourceTable: Table) {\n\treturn function one<\n\t\tTForeignTable extends Table,\n\t\tTColumns extends [\n\t\t\tAnyColumn<{ tableName: TTableName }>,\n\t\t\t...AnyColumn<{ tableName: TTableName }>[],\n\t\t],\n\t>(\n\t\ttable: TForeignTable,\n\t\tconfig?: RelationConfig<TTableName, TForeignTable['_']['name'], TColumns>,\n\t): One<\n\t\tTForeignTable['_']['name'],\n\t\tEqual<TColumns[number]['_']['notNull'], true>\n\t> {\n\t\treturn new One(\n\t\t\tsourceTable,\n\t\t\ttable,\n\t\t\tconfig,\n\t\t\t(config?.fields.reduce<boolean>((res, f) => res && f.notNull, true)\n\t\t\t\t?? false) as Equal<TColumns[number]['_']['notNull'], true>,\n\t\t);\n\t};\n}\n\nexport function createMany(sourceTable: Table) {\n\treturn function many<TForeignTable extends Table>(\n\t\treferencedTable: TForeignTable,\n\t\tconfig?: { relationName: string },\n\t): Many<TForeignTable['_']['name']> {\n\t\treturn new Many(sourceTable, referencedTable, config);\n\t};\n}\n\nexport interface NormalizedRelation {\n\tfields: AnyColumn[];\n\treferences: AnyColumn[];\n}\n\nexport function normalizeRelation(\n\tschema: TablesRelationalConfig,\n\ttableNamesMap: Record<string, string>,\n\trelation: Relation,\n): NormalizedRelation {\n\tif (is(relation, One) && relation.config) {\n\t\treturn {\n\t\t\tfields: relation.config.fields,\n\t\t\treferences: relation.config.references,\n\t\t};\n\t}\n\n\tconst referencedTableTsName = tableNamesMap[getTableUniqueName(relation.referencedTable)];\n\tif (!referencedTableTsName) {\n\t\tthrow new Error(\n\t\t\t`Table \"${relation.referencedTable[Table.Symbol.Name]}\" not found in schema`,\n\t\t);\n\t}\n\n\tconst referencedTableConfig = schema[referencedTableTsName];\n\tif (!referencedTableConfig) {\n\t\tthrow new Error(`Table \"${referencedTableTsName}\" not found in schema`);\n\t}\n\n\tconst sourceTable = relation.sourceTable;\n\tconst sourceTableTsName = tableNamesMap[getTableUniqueName(sourceTable)];\n\tif (!sourceTableTsName) {\n\t\tthrow new Error(\n\t\t\t`Table \"${sourceTable[Table.Symbol.Name]}\" not found in schema`,\n\t\t);\n\t}\n\n\tconst reverseRelations: Relation[] = [];\n\tfor (\n\t\tconst referencedTableRelation of Object.values(\n\t\t\treferencedTableConfig.relations,\n\t\t)\n\t) {\n\t\tif (\n\t\t\t(relation.relationName\n\t\t\t\t&& relation !== referencedTableRelation\n\t\t\t\t&& referencedTableRelation.relationName === relation.relationName)\n\t\t\t|| (!relation.relationName\n\t\t\t\t&& referencedTableRelation.referencedTable === relation.sourceTable)\n\t\t) {\n\t\t\treverseRelations.push(referencedTableRelation);\n\t\t}\n\t}\n\n\tif (reverseRelations.length > 1) {\n\t\tthrow relation.relationName\n\t\t\t? new Error(\n\t\t\t\t`There are multiple relations with name \"${relation.relationName}\" in table \"${referencedTableTsName}\"`,\n\t\t\t)\n\t\t\t: new Error(\n\t\t\t\t`There are multiple relations between \"${referencedTableTsName}\" and \"${\n\t\t\t\t\trelation.sourceTable[Table.Symbol.Name]\n\t\t\t\t}\". Please specify relation name`,\n\t\t\t);\n\t}\n\n\tif (\n\t\treverseRelations[0]\n\t\t&& is(reverseRelations[0], One)\n\t\t&& reverseRelations[0].config\n\t) {\n\t\treturn {\n\t\t\tfields: reverseRelations[0].config.references,\n\t\t\treferences: reverseRelations[0].config.fields,\n\t\t};\n\t}\n\n\tthrow new Error(\n\t\t`There is not enough information to infer relation \"${sourceTableTsName}.${relation.fieldName}\"`,\n\t);\n}\n\nexport function createTableRelationsHelpers<TTableName extends string>(\n\tsourceTable: AnyTable<{ name: TTableName }>,\n) {\n\treturn {\n\t\tone: createOne<TTableName>(sourceTable),\n\t\tmany: createMany(sourceTable),\n\t};\n}\n\nexport type TableRelationsHelpers<TTableName extends string> = ReturnType<\n\ttypeof createTableRelationsHelpers<TTableName>\n>;\n\nexport interface BuildRelationalQueryResult<\n\tTTable extends Table = Table,\n\tTColumn extends Column = Column,\n> {\n\ttableTsKey: string;\n\tselection: {\n\t\tdbKey: string;\n\t\ttsKey: string;\n\t\tfield: TColumn | SQL | SQL.Aliased;\n\t\trelationTableTsKey: string | undefined;\n\t\tisJson: boolean;\n\t\tisExtra?: boolean;\n\t\tselection: BuildRelationalQueryResult<TTable>['selection'];\n\t}[];\n\tsql: TTable | SQL;\n}\n\nexport function mapRelationalRow(\n\ttablesConfig: TablesRelationalConfig,\n\ttableConfig: TableRelationalConfig,\n\trow: unknown[],\n\tbuildQueryResultSelection: BuildRelationalQueryResult['selection'],\n\tmapColumnValue: (value: unknown) => unknown = (value) => value,\n): Record<string, unknown> {\n\tconst result: Record<string, unknown> = {};\n\n\tfor (\n\t\tconst [\n\t\t\tselectionItemIndex,\n\t\t\tselectionItem,\n\t\t] of buildQueryResultSelection.entries()\n\t) {\n\t\tif (selectionItem.isJson) {\n\t\t\tconst relation = tableConfig.relations[selectionItem.tsKey]!;\n\t\t\tconst rawSubRows = row[selectionItemIndex] as\n\t\t\t\t| unknown[]\n\t\t\t\t| null\n\t\t\t\t| [null]\n\t\t\t\t| string;\n\t\t\tconst subRows = typeof rawSubRows === 'string'\n\t\t\t\t? (JSON.parse(rawSubRows) as unknown[])\n\t\t\t\t: rawSubRows;\n\t\t\tresult[selectionItem.tsKey] = is(relation, One)\n\t\t\t\t? subRows\n\t\t\t\t\t&& mapRelationalRow(\n\t\t\t\t\t\ttablesConfig,\n\t\t\t\t\t\ttablesConfig[selectionItem.relationTableTsKey!]!,\n\t\t\t\t\t\tsubRows,\n\t\t\t\t\t\tselectionItem.selection,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t)\n\t\t\t\t: (subRows as unknown[][]).map((subRow) =>\n\t\t\t\t\tmapRelationalRow(\n\t\t\t\t\t\ttablesConfig,\n\t\t\t\t\t\ttablesConfig[selectionItem.relationTableTsKey!]!,\n\t\t\t\t\t\tsubRow,\n\t\t\t\t\t\tselectionItem.selection,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t} else {\n\t\t\tconst value = mapColumnValue(row[selectionItemIndex]);\n\t\t\tconst field = selectionItem.field!;\n\t\t\tlet decoder;\n\t\t\tif (is(field, Column)) {\n\t\t\t\tdecoder = field;\n\t\t\t} else if (is(field, SQL)) {\n\t\t\t\tdecoder = field.decoder;\n\t\t\t} else {\n\t\t\t\tdecoder = field.sql.decoder;\n\t\t\t}\n\t\t\tresult[selectionItem.tsKey] = value === null ? null : decoder.mapFromDriverValue(value);\n\t\t}\n\t}\n\n\treturn result;\n}\n\nexport function mapRelationalRowFromObj(\n\ttablesConfig: TablesRelationalConfig,\n\ttableConfig: TableRelationalConfig,\n\trow: unknown[],\n\tbuildQueryResultSelection: BuildRelationalQueryResult['selection'],\n\tmapColumnValue: (value: unknown) => unknown = (value) => value,\n): Record<string, unknown> {\n\tconst result: Record<string, unknown> = {};\n\n\tfor (\n\t\tconst [\n\t\t\tselectionItemIndex,\n\t\t\tselectionItem,\n\t\t] of buildQueryResultSelection.entries()\n\t) {\n\t\tif (selectionItem.isJson) {\n\t\t\tconst relation = tableConfig.relations[selectionItem.tsKey]!;\n\t\t\tconst isOne = is(relation, One);\n\t\t\tconst rawSubRows = row[selectionItemIndex] as unknown[] | null | [null] | string;\n\n\t\t\tlet subRows = rawSubRows as unknown[] | null;\n\t\t\tif (subRows || Array.isArray(subRows)) {\n\t\t\t\tsubRows = (typeof rawSubRows === 'string' ? JSON.parse(rawSubRows) : rawSubRows) as unknown[];\n\n\t\t\t\tsubRows = isOne\n\t\t\t\t\t? subRows.flatMap((r) => Array.isArray(r) ? r : Object.values(r as any))\n\t\t\t\t\t: subRows.map((r) => Array.isArray(r) ? r : Object.values(r as any));\n\t\t\t}\n\n\t\t\tresult[selectionItem.tsKey] = isOne\n\t\t\t\t? subRows\n\t\t\t\t\t&& mapRelationalRowFromObj(\n\t\t\t\t\t\ttablesConfig,\n\t\t\t\t\t\ttablesConfig[selectionItem.relationTableTsKey!]!,\n\t\t\t\t\t\tsubRows,\n\t\t\t\t\t\tselectionItem.selection,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t)\n\t\t\t\t: ((subRows ?? []) as unknown[][]).map((subRow) =>\n\t\t\t\t\tmapRelationalRowFromObj(\n\t\t\t\t\t\ttablesConfig,\n\t\t\t\t\t\ttablesConfig[selectionItem.relationTableTsKey!]!,\n\t\t\t\t\t\tsubRow,\n\t\t\t\t\t\tselectionItem.selection,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t} else {\n\t\t\tconst value = mapColumnValue(row[selectionItemIndex]);\n\t\t\tconst field = selectionItem.field!;\n\t\t\tlet decoder;\n\t\t\tif (is(field, Column)) {\n\t\t\t\tdecoder = field;\n\t\t\t} else if (is(field, SQL)) {\n\t\t\t\tdecoder = field.decoder;\n\t\t\t} else {\n\t\t\t\tdecoder = field.sql.decoder;\n\t\t\t}\n\t\t\tresult[selectionItem.tsKey] = value === null ? null : decoder.mapFromDriverValue(value);\n\t\t}\n\t}\n\n\treturn result;\n}\n"],"mappings":"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","names":["relations"]}
package/alias.cjs CHANGED
@@ -19,36 +19,45 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
19
19
  var alias_exports = {};
20
20
  __export(alias_exports, {
21
21
  ColumnAliasProxyHandler: () => ColumnAliasProxyHandler,
22
+ ColumnTableAliasProxyHandler: () => ColumnTableAliasProxyHandler,
22
23
  RelationTableAliasProxyHandler: () => RelationTableAliasProxyHandler,
23
24
  TableAliasProxyHandler: () => TableAliasProxyHandler,
25
+ aliasedColumn: () => aliasedColumn,
24
26
  aliasedRelation: () => aliasedRelation,
25
27
  aliasedTable: () => aliasedTable,
26
28
  aliasedTableColumn: () => aliasedTableColumn,
29
+ getOriginalColumnFromAlias: () => getOriginalColumnFromAlias,
27
30
  mapColumnsInAliasedSQLToAlias: () => mapColumnsInAliasedSQLToAlias,
28
31
  mapColumnsInSQLToAlias: () => mapColumnsInSQLToAlias
29
32
  });
30
33
  module.exports = __toCommonJS(alias_exports);
34
+ var import_column_common = require("./column-common.cjs");
31
35
  var import_column = require("./column.cjs");
32
36
  var import_entity = require("./entity.cjs");
33
37
  var import_sql = require("./sql/sql.cjs");
34
38
  var import_table = require("./table.cjs");
35
39
  var import_view_common = require("./view-common.cjs");
36
- class ColumnAliasProxyHandler {
37
- constructor(table) {
40
+ class ColumnTableAliasProxyHandler {
41
+ constructor(table, ignoreColumnAlias) {
38
42
  this.table = table;
43
+ this.ignoreColumnAlias = ignoreColumnAlias;
39
44
  }
40
- static [import_entity.entityKind] = "ColumnAliasProxyHandler";
45
+ static [import_entity.entityKind] = "ColumnTableAliasProxyHandler";
41
46
  get(columnObj, prop) {
42
47
  if (prop === "table") {
43
48
  return this.table;
44
49
  }
50
+ if (prop === "isAlias" && this.ignoreColumnAlias) {
51
+ return false;
52
+ }
45
53
  return columnObj[prop];
46
54
  }
47
55
  }
48
56
  class TableAliasProxyHandler {
49
- constructor(alias, replaceOriginalName) {
57
+ constructor(alias, replaceOriginalName, ignoreColumnAlias) {
50
58
  this.alias = alias;
51
59
  this.replaceOriginalName = replaceOriginalName;
60
+ this.ignoreColumnAlias = ignoreColumnAlias;
52
61
  }
53
62
  static [import_entity.entityKind] = "TableAliasProxyHandler";
54
63
  get(target, prop) {
@@ -77,18 +86,42 @@ class TableAliasProxyHandler {
77
86
  Object.keys(columns).map((key) => {
78
87
  proxiedColumns[key] = new Proxy(
79
88
  columns[key],
80
- new ColumnAliasProxyHandler(new Proxy(target, this))
89
+ new ColumnTableAliasProxyHandler(new Proxy(target, this), this.ignoreColumnAlias)
81
90
  );
82
91
  });
83
92
  return proxiedColumns;
84
93
  }
85
94
  const value = target[prop];
86
95
  if ((0, import_entity.is)(value, import_column.Column)) {
87
- return new Proxy(value, new ColumnAliasProxyHandler(new Proxy(target, this)));
96
+ return new Proxy(
97
+ value,
98
+ new ColumnTableAliasProxyHandler(new Proxy(target, this), this.ignoreColumnAlias)
99
+ );
88
100
  }
89
101
  return value;
90
102
  }
91
103
  }
104
+ class ColumnAliasProxyHandler {
105
+ constructor(alias) {
106
+ this.alias = alias;
107
+ }
108
+ static [import_entity.entityKind] = "ColumnAliasProxyHandler";
109
+ get(target, prop) {
110
+ if (prop === "isAlias") {
111
+ return true;
112
+ }
113
+ if (prop === "name") {
114
+ return this.alias;
115
+ }
116
+ if (prop === "keyAsName") {
117
+ return false;
118
+ }
119
+ if (prop === import_column_common.OriginalColumn) {
120
+ return () => target;
121
+ }
122
+ return target[prop];
123
+ }
124
+ }
92
125
  class RelationTableAliasProxyHandler {
93
126
  constructor(alias) {
94
127
  this.alias = alias;
@@ -102,7 +135,10 @@ class RelationTableAliasProxyHandler {
102
135
  }
103
136
  }
104
137
  function aliasedTable(table, tableAlias) {
105
- return new Proxy(table, new TableAliasProxyHandler(tableAlias, false));
138
+ return new Proxy(table, new TableAliasProxyHandler(tableAlias, false, false));
139
+ }
140
+ function aliasedColumn(column, alias) {
141
+ return new Proxy(column, new ColumnAliasProxyHandler(alias));
106
142
  }
107
143
  function aliasedRelation(relation, tableAlias) {
108
144
  return new Proxy(relation, new RelationTableAliasProxyHandler(tableAlias));
@@ -110,7 +146,10 @@ function aliasedRelation(relation, tableAlias) {
110
146
  function aliasedTableColumn(column, tableAlias) {
111
147
  return new Proxy(
112
148
  column,
113
- new ColumnAliasProxyHandler(new Proxy(column.table, new TableAliasProxyHandler(tableAlias, false)))
149
+ new ColumnTableAliasProxyHandler(
150
+ new Proxy(column.table, new TableAliasProxyHandler(tableAlias, false, false)),
151
+ false
152
+ )
114
153
  );
115
154
  }
116
155
  function mapColumnsInAliasedSQLToAlias(query, alias) {
@@ -130,14 +169,23 @@ function mapColumnsInSQLToAlias(query, alias) {
130
169
  return c;
131
170
  }));
132
171
  }
172
+ import_column.Column.prototype.as = function(alias) {
173
+ return aliasedColumn(this, alias);
174
+ };
175
+ function getOriginalColumnFromAlias(column) {
176
+ return column[import_column_common.OriginalColumn]();
177
+ }
133
178
  // Annotate the CommonJS export names for ESM import in node:
134
179
  0 && (module.exports = {
135
180
  ColumnAliasProxyHandler,
181
+ ColumnTableAliasProxyHandler,
136
182
  RelationTableAliasProxyHandler,
137
183
  TableAliasProxyHandler,
184
+ aliasedColumn,
138
185
  aliasedRelation,
139
186
  aliasedTable,
140
187
  aliasedTableColumn,
188
+ getOriginalColumnFromAlias,
141
189
  mapColumnsInAliasedSQLToAlias,
142
190
  mapColumnsInSQLToAlias
143
191
  });