drizzle-orm 1.0.0-beta.1-08e4e66 → 1.0.0-beta.1-fd8bfcc

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 (1309) hide show
  1. package/_relations.cjs +0 -48
  2. package/_relations.cjs.map +1 -1
  3. package/_relations.d.cts +0 -1
  4. package/_relations.d.ts +0 -1
  5. package/_relations.js +0 -47
  6. package/_relations.js.map +1 -1
  7. package/column-builder.cjs.map +1 -1
  8. package/column-builder.d.cts +8 -10
  9. package/column-builder.d.ts +8 -10
  10. package/column-builder.js.map +1 -1
  11. package/column.cjs +0 -2
  12. package/column.cjs.map +1 -1
  13. package/column.d.cts +0 -1
  14. package/column.d.ts +0 -1
  15. package/column.js +0 -2
  16. package/column.js.map +1 -1
  17. package/gel-core/columns/bigint.cjs.map +1 -1
  18. package/gel-core/columns/bigint.d.cts +1 -0
  19. package/gel-core/columns/bigint.d.ts +1 -0
  20. package/gel-core/columns/bigint.js.map +1 -1
  21. package/gel-core/columns/bigintT.cjs.map +1 -1
  22. package/gel-core/columns/bigintT.d.cts +1 -0
  23. package/gel-core/columns/bigintT.d.ts +1 -0
  24. package/gel-core/columns/bigintT.js.map +1 -1
  25. package/gel-core/columns/boolean.cjs.map +1 -1
  26. package/gel-core/columns/boolean.d.cts +1 -0
  27. package/gel-core/columns/boolean.d.ts +1 -0
  28. package/gel-core/columns/boolean.js.map +1 -1
  29. package/gel-core/columns/bytes.cjs.map +1 -1
  30. package/gel-core/columns/bytes.d.cts +1 -0
  31. package/gel-core/columns/bytes.d.ts +1 -0
  32. package/gel-core/columns/bytes.js.map +1 -1
  33. package/gel-core/columns/custom.cjs.map +1 -1
  34. package/gel-core/columns/custom.d.cts +1 -0
  35. package/gel-core/columns/custom.d.ts +1 -0
  36. package/gel-core/columns/custom.js.map +1 -1
  37. package/gel-core/columns/date-duration.cjs.map +1 -1
  38. package/gel-core/columns/date-duration.d.cts +1 -0
  39. package/gel-core/columns/date-duration.d.ts +1 -0
  40. package/gel-core/columns/date-duration.js.map +1 -1
  41. package/gel-core/columns/decimal.cjs.map +1 -1
  42. package/gel-core/columns/decimal.d.cts +1 -0
  43. package/gel-core/columns/decimal.d.ts +1 -0
  44. package/gel-core/columns/decimal.js.map +1 -1
  45. package/gel-core/columns/double-precision.cjs.map +1 -1
  46. package/gel-core/columns/double-precision.d.cts +1 -0
  47. package/gel-core/columns/double-precision.d.ts +1 -0
  48. package/gel-core/columns/double-precision.js.map +1 -1
  49. package/gel-core/columns/duration.cjs.map +1 -1
  50. package/gel-core/columns/duration.d.cts +1 -0
  51. package/gel-core/columns/duration.d.ts +1 -0
  52. package/gel-core/columns/duration.js.map +1 -1
  53. package/gel-core/columns/integer.cjs.map +1 -1
  54. package/gel-core/columns/integer.d.cts +1 -0
  55. package/gel-core/columns/integer.d.ts +1 -0
  56. package/gel-core/columns/integer.js.map +1 -1
  57. package/gel-core/columns/json.cjs.map +1 -1
  58. package/gel-core/columns/json.d.cts +1 -0
  59. package/gel-core/columns/json.d.ts +1 -0
  60. package/gel-core/columns/json.js.map +1 -1
  61. package/gel-core/columns/localdate.cjs.map +1 -1
  62. package/gel-core/columns/localdate.d.cts +1 -0
  63. package/gel-core/columns/localdate.d.ts +1 -0
  64. package/gel-core/columns/localdate.js.map +1 -1
  65. package/gel-core/columns/localtime.cjs.map +1 -1
  66. package/gel-core/columns/localtime.d.cts +1 -0
  67. package/gel-core/columns/localtime.d.ts +1 -0
  68. package/gel-core/columns/localtime.js.map +1 -1
  69. package/gel-core/columns/real.cjs.map +1 -1
  70. package/gel-core/columns/real.d.cts +1 -0
  71. package/gel-core/columns/real.d.ts +1 -0
  72. package/gel-core/columns/real.js.map +1 -1
  73. package/gel-core/columns/relative-duration.cjs.map +1 -1
  74. package/gel-core/columns/relative-duration.d.cts +1 -0
  75. package/gel-core/columns/relative-duration.d.ts +1 -0
  76. package/gel-core/columns/relative-duration.js.map +1 -1
  77. package/gel-core/columns/smallint.cjs.map +1 -1
  78. package/gel-core/columns/smallint.d.cts +1 -0
  79. package/gel-core/columns/smallint.d.ts +1 -0
  80. package/gel-core/columns/smallint.js.map +1 -1
  81. package/gel-core/columns/text.cjs.map +1 -1
  82. package/gel-core/columns/text.d.cts +1 -0
  83. package/gel-core/columns/text.d.ts +1 -0
  84. package/gel-core/columns/text.js.map +1 -1
  85. package/gel-core/columns/timestamp.cjs.map +1 -1
  86. package/gel-core/columns/timestamp.d.cts +1 -0
  87. package/gel-core/columns/timestamp.d.ts +1 -0
  88. package/gel-core/columns/timestamp.js.map +1 -1
  89. package/gel-core/columns/timestamptz.cjs.map +1 -1
  90. package/gel-core/columns/timestamptz.d.cts +1 -0
  91. package/gel-core/columns/timestamptz.d.ts +1 -0
  92. package/gel-core/columns/timestamptz.js.map +1 -1
  93. package/gel-core/columns/uuid.cjs.map +1 -1
  94. package/gel-core/columns/uuid.d.cts +1 -0
  95. package/gel-core/columns/uuid.d.ts +1 -0
  96. package/gel-core/columns/uuid.js.map +1 -1
  97. package/gel-core/query-builders/insert.cjs.map +1 -1
  98. package/gel-core/query-builders/insert.d.cts +9 -6
  99. package/gel-core/query-builders/insert.d.ts +9 -6
  100. package/gel-core/query-builders/insert.js.map +1 -1
  101. package/gel-core/query-builders/update.cjs.map +1 -1
  102. package/gel-core/query-builders/update.d.cts +1 -1
  103. package/gel-core/query-builders/update.d.ts +1 -1
  104. package/gel-core/query-builders/update.js.map +1 -1
  105. package/mysql-core/columns/bigint.cjs.map +1 -1
  106. package/mysql-core/columns/bigint.d.cts +2 -0
  107. package/mysql-core/columns/bigint.d.ts +2 -0
  108. package/mysql-core/columns/bigint.js.map +1 -1
  109. package/mysql-core/columns/binary.cjs +1 -0
  110. package/mysql-core/columns/binary.cjs.map +1 -1
  111. package/mysql-core/columns/binary.d.cts +2 -0
  112. package/mysql-core/columns/binary.d.ts +2 -0
  113. package/mysql-core/columns/binary.js +1 -0
  114. package/mysql-core/columns/binary.js.map +1 -1
  115. package/mysql-core/columns/boolean.cjs.map +1 -1
  116. package/mysql-core/columns/boolean.d.cts +1 -0
  117. package/mysql-core/columns/boolean.d.ts +1 -0
  118. package/mysql-core/columns/boolean.js.map +1 -1
  119. package/mysql-core/columns/char.cjs +1 -0
  120. package/mysql-core/columns/char.cjs.map +1 -1
  121. package/mysql-core/columns/char.d.cts +2 -0
  122. package/mysql-core/columns/char.d.ts +2 -0
  123. package/mysql-core/columns/char.js +1 -0
  124. package/mysql-core/columns/char.js.map +1 -1
  125. package/mysql-core/columns/common.cjs.map +1 -1
  126. package/mysql-core/columns/common.d.cts +1 -1
  127. package/mysql-core/columns/common.d.ts +1 -1
  128. package/mysql-core/columns/common.js.map +1 -1
  129. package/mysql-core/columns/custom.cjs +3 -1
  130. package/mysql-core/columns/custom.cjs.map +1 -1
  131. package/mysql-core/columns/custom.d.cts +1 -0
  132. package/mysql-core/columns/custom.d.ts +1 -0
  133. package/mysql-core/columns/custom.js +3 -1
  134. package/mysql-core/columns/custom.js.map +1 -1
  135. package/mysql-core/columns/date.cjs.map +1 -1
  136. package/mysql-core/columns/date.d.cts +2 -0
  137. package/mysql-core/columns/date.d.ts +2 -0
  138. package/mysql-core/columns/date.js.map +1 -1
  139. package/mysql-core/columns/datetime.cjs.map +1 -1
  140. package/mysql-core/columns/datetime.d.cts +2 -0
  141. package/mysql-core/columns/datetime.d.ts +2 -0
  142. package/mysql-core/columns/datetime.js.map +1 -1
  143. package/mysql-core/columns/decimal.cjs.map +1 -1
  144. package/mysql-core/columns/decimal.d.cts +3 -0
  145. package/mysql-core/columns/decimal.d.ts +3 -0
  146. package/mysql-core/columns/decimal.js.map +1 -1
  147. package/mysql-core/columns/double.cjs.map +1 -1
  148. package/mysql-core/columns/double.d.cts +1 -0
  149. package/mysql-core/columns/double.d.ts +1 -0
  150. package/mysql-core/columns/double.js.map +1 -1
  151. package/mysql-core/columns/enum.cjs.map +1 -1
  152. package/mysql-core/columns/enum.d.cts +2 -0
  153. package/mysql-core/columns/enum.d.ts +2 -0
  154. package/mysql-core/columns/enum.js.map +1 -1
  155. package/mysql-core/columns/float.cjs.map +1 -1
  156. package/mysql-core/columns/float.d.cts +1 -0
  157. package/mysql-core/columns/float.d.ts +1 -0
  158. package/mysql-core/columns/float.js.map +1 -1
  159. package/mysql-core/columns/int.cjs.map +1 -1
  160. package/mysql-core/columns/int.d.cts +1 -0
  161. package/mysql-core/columns/int.d.ts +1 -0
  162. package/mysql-core/columns/int.js.map +1 -1
  163. package/mysql-core/columns/json.cjs.map +1 -1
  164. package/mysql-core/columns/json.d.cts +1 -0
  165. package/mysql-core/columns/json.d.ts +1 -0
  166. package/mysql-core/columns/json.js.map +1 -1
  167. package/mysql-core/columns/mediumint.cjs.map +1 -1
  168. package/mysql-core/columns/mediumint.d.cts +1 -0
  169. package/mysql-core/columns/mediumint.d.ts +1 -0
  170. package/mysql-core/columns/mediumint.js.map +1 -1
  171. package/mysql-core/columns/real.cjs.map +1 -1
  172. package/mysql-core/columns/real.d.cts +1 -0
  173. package/mysql-core/columns/real.d.ts +1 -0
  174. package/mysql-core/columns/real.js.map +1 -1
  175. package/mysql-core/columns/serial.cjs.map +1 -1
  176. package/mysql-core/columns/serial.d.cts +1 -0
  177. package/mysql-core/columns/serial.d.ts +1 -0
  178. package/mysql-core/columns/serial.js.map +1 -1
  179. package/mysql-core/columns/smallint.cjs.map +1 -1
  180. package/mysql-core/columns/smallint.d.cts +1 -0
  181. package/mysql-core/columns/smallint.d.ts +1 -0
  182. package/mysql-core/columns/smallint.js.map +1 -1
  183. package/mysql-core/columns/text.cjs.map +1 -1
  184. package/mysql-core/columns/text.d.cts +1 -0
  185. package/mysql-core/columns/text.d.ts +1 -0
  186. package/mysql-core/columns/text.js.map +1 -1
  187. package/mysql-core/columns/time.cjs.map +1 -1
  188. package/mysql-core/columns/time.d.cts +1 -0
  189. package/mysql-core/columns/time.d.ts +1 -0
  190. package/mysql-core/columns/time.js.map +1 -1
  191. package/mysql-core/columns/timestamp.cjs.map +1 -1
  192. package/mysql-core/columns/timestamp.d.cts +2 -0
  193. package/mysql-core/columns/timestamp.d.ts +2 -0
  194. package/mysql-core/columns/timestamp.js.map +1 -1
  195. package/mysql-core/columns/tinyint.cjs.map +1 -1
  196. package/mysql-core/columns/tinyint.d.cts +1 -0
  197. package/mysql-core/columns/tinyint.d.ts +1 -0
  198. package/mysql-core/columns/tinyint.js.map +1 -1
  199. package/mysql-core/columns/varbinary.cjs.map +1 -1
  200. package/mysql-core/columns/varbinary.d.cts +1 -0
  201. package/mysql-core/columns/varbinary.d.ts +1 -0
  202. package/mysql-core/columns/varbinary.js.map +1 -1
  203. package/mysql-core/columns/varchar.cjs +1 -1
  204. package/mysql-core/columns/varchar.cjs.map +1 -1
  205. package/mysql-core/columns/varchar.d.cts +2 -1
  206. package/mysql-core/columns/varchar.d.ts +2 -1
  207. package/mysql-core/columns/varchar.js +1 -1
  208. package/mysql-core/columns/varchar.js.map +1 -1
  209. package/mysql-core/columns/year.cjs.map +1 -1
  210. package/mysql-core/columns/year.d.cts +1 -0
  211. package/mysql-core/columns/year.d.ts +1 -0
  212. package/mysql-core/columns/year.js.map +1 -1
  213. package/mysql-core/dialect.cjs +0 -3
  214. package/mysql-core/dialect.cjs.map +1 -1
  215. package/mysql-core/dialect.d.cts +0 -1
  216. package/mysql-core/dialect.d.ts +0 -1
  217. package/mysql-core/dialect.js +0 -3
  218. package/mysql-core/dialect.js.map +1 -1
  219. package/mysql-core/query-builders/insert.cjs.map +1 -1
  220. package/mysql-core/query-builders/insert.d.cts +2 -2
  221. package/mysql-core/query-builders/insert.d.ts +2 -2
  222. package/mysql-core/query-builders/insert.js.map +1 -1
  223. package/mysql-core/query-builders/update.cjs.map +1 -1
  224. package/mysql-core/query-builders/update.d.cts +1 -1
  225. package/mysql-core/query-builders/update.d.ts +1 -1
  226. package/mysql-core/query-builders/update.js.map +1 -1
  227. package/mysql-proxy/driver.cjs +2 -2
  228. package/mysql-proxy/driver.cjs.map +1 -1
  229. package/mysql-proxy/driver.d.cts +1 -2
  230. package/mysql-proxy/driver.d.ts +1 -2
  231. package/mysql-proxy/driver.js +2 -2
  232. package/mysql-proxy/driver.js.map +1 -1
  233. package/node-postgres/session.cjs.map +1 -1
  234. package/node-postgres/session.js.map +1 -1
  235. package/package.json +190 -1632
  236. package/pg-core/columns/bigint.cjs.map +1 -1
  237. package/pg-core/columns/bigint.d.cts +2 -0
  238. package/pg-core/columns/bigint.d.ts +2 -0
  239. package/pg-core/columns/bigint.js.map +1 -1
  240. package/pg-core/columns/bigserial.cjs +0 -1
  241. package/pg-core/columns/bigserial.cjs.map +1 -1
  242. package/pg-core/columns/bigserial.d.cts +2 -0
  243. package/pg-core/columns/bigserial.d.ts +2 -0
  244. package/pg-core/columns/bigserial.js +0 -1
  245. package/pg-core/columns/bigserial.js.map +1 -1
  246. package/pg-core/columns/boolean.cjs.map +1 -1
  247. package/pg-core/columns/boolean.d.cts +1 -0
  248. package/pg-core/columns/boolean.d.ts +1 -0
  249. package/pg-core/columns/boolean.js.map +1 -1
  250. package/pg-core/columns/bytea.cjs.map +1 -1
  251. package/pg-core/columns/bytea.d.cts +1 -0
  252. package/pg-core/columns/bytea.d.ts +1 -0
  253. package/pg-core/columns/bytea.js.map +1 -1
  254. package/pg-core/columns/char.cjs +1 -0
  255. package/pg-core/columns/char.cjs.map +1 -1
  256. package/pg-core/columns/char.d.cts +2 -0
  257. package/pg-core/columns/char.d.ts +2 -0
  258. package/pg-core/columns/char.js +1 -0
  259. package/pg-core/columns/char.js.map +1 -1
  260. package/pg-core/columns/cidr.cjs.map +1 -1
  261. package/pg-core/columns/cidr.d.cts +1 -0
  262. package/pg-core/columns/cidr.d.ts +1 -0
  263. package/pg-core/columns/cidr.js.map +1 -1
  264. package/pg-core/columns/common.cjs +10 -11
  265. package/pg-core/columns/common.cjs.map +1 -1
  266. package/pg-core/columns/common.d.cts +2 -3
  267. package/pg-core/columns/common.d.ts +2 -3
  268. package/pg-core/columns/common.js +10 -11
  269. package/pg-core/columns/common.js.map +1 -1
  270. package/pg-core/columns/custom.cjs.map +1 -1
  271. package/pg-core/columns/custom.d.cts +1 -0
  272. package/pg-core/columns/custom.d.ts +1 -0
  273. package/pg-core/columns/custom.js.map +1 -1
  274. package/pg-core/columns/date.cjs.map +1 -1
  275. package/pg-core/columns/date.d.cts +2 -0
  276. package/pg-core/columns/date.d.ts +2 -0
  277. package/pg-core/columns/date.js.map +1 -1
  278. package/pg-core/columns/double-precision.cjs.map +1 -1
  279. package/pg-core/columns/double-precision.d.cts +1 -0
  280. package/pg-core/columns/double-precision.d.ts +1 -0
  281. package/pg-core/columns/double-precision.js.map +1 -1
  282. package/pg-core/columns/enum.cjs.map +1 -1
  283. package/pg-core/columns/enum.d.cts +2 -0
  284. package/pg-core/columns/enum.d.ts +2 -0
  285. package/pg-core/columns/enum.js.map +1 -1
  286. package/pg-core/columns/inet.cjs.map +1 -1
  287. package/pg-core/columns/inet.d.cts +1 -0
  288. package/pg-core/columns/inet.d.ts +1 -0
  289. package/pg-core/columns/inet.js.map +1 -1
  290. package/pg-core/columns/integer.cjs.map +1 -1
  291. package/pg-core/columns/integer.d.cts +1 -0
  292. package/pg-core/columns/integer.d.ts +1 -0
  293. package/pg-core/columns/integer.js.map +1 -1
  294. package/pg-core/columns/interval.cjs.map +1 -1
  295. package/pg-core/columns/interval.d.cts +1 -0
  296. package/pg-core/columns/interval.d.ts +1 -0
  297. package/pg-core/columns/interval.js.map +1 -1
  298. package/pg-core/columns/json.cjs.map +1 -1
  299. package/pg-core/columns/json.d.cts +1 -0
  300. package/pg-core/columns/json.d.ts +1 -0
  301. package/pg-core/columns/json.js.map +1 -1
  302. package/pg-core/columns/jsonb.cjs.map +1 -1
  303. package/pg-core/columns/jsonb.d.cts +1 -0
  304. package/pg-core/columns/jsonb.d.ts +1 -0
  305. package/pg-core/columns/jsonb.js.map +1 -1
  306. package/pg-core/columns/line.cjs +0 -2
  307. package/pg-core/columns/line.cjs.map +1 -1
  308. package/pg-core/columns/line.d.cts +2 -2
  309. package/pg-core/columns/line.d.ts +2 -2
  310. package/pg-core/columns/line.js +0 -2
  311. package/pg-core/columns/line.js.map +1 -1
  312. package/pg-core/columns/macaddr.cjs.map +1 -1
  313. package/pg-core/columns/macaddr.d.cts +1 -0
  314. package/pg-core/columns/macaddr.d.ts +1 -0
  315. package/pg-core/columns/macaddr.js.map +1 -1
  316. package/pg-core/columns/macaddr8.cjs.map +1 -1
  317. package/pg-core/columns/macaddr8.d.cts +1 -0
  318. package/pg-core/columns/macaddr8.d.ts +1 -0
  319. package/pg-core/columns/macaddr8.js.map +1 -1
  320. package/pg-core/columns/numeric.cjs.map +1 -1
  321. package/pg-core/columns/numeric.d.cts +3 -0
  322. package/pg-core/columns/numeric.d.ts +3 -0
  323. package/pg-core/columns/numeric.js.map +1 -1
  324. package/pg-core/columns/point.cjs +0 -2
  325. package/pg-core/columns/point.cjs.map +1 -1
  326. package/pg-core/columns/point.d.cts +2 -2
  327. package/pg-core/columns/point.d.ts +2 -2
  328. package/pg-core/columns/point.js +0 -2
  329. package/pg-core/columns/point.js.map +1 -1
  330. package/pg-core/columns/postgis_extension/geometry.cjs +8 -14
  331. package/pg-core/columns/postgis_extension/geometry.cjs.map +1 -1
  332. package/pg-core/columns/postgis_extension/geometry.d.cts +6 -16
  333. package/pg-core/columns/postgis_extension/geometry.d.ts +6 -16
  334. package/pg-core/columns/postgis_extension/geometry.js +8 -14
  335. package/pg-core/columns/postgis_extension/geometry.js.map +1 -1
  336. package/pg-core/columns/postgis_extension/utils.cjs +3 -3
  337. package/pg-core/columns/postgis_extension/utils.cjs.map +1 -1
  338. package/pg-core/columns/postgis_extension/utils.d.cts +1 -4
  339. package/pg-core/columns/postgis_extension/utils.d.ts +1 -4
  340. package/pg-core/columns/postgis_extension/utils.js +3 -3
  341. package/pg-core/columns/postgis_extension/utils.js.map +1 -1
  342. package/pg-core/columns/real.cjs.map +1 -1
  343. package/pg-core/columns/real.d.cts +1 -0
  344. package/pg-core/columns/real.d.ts +1 -0
  345. package/pg-core/columns/real.js.map +1 -1
  346. package/pg-core/columns/serial.cjs.map +1 -1
  347. package/pg-core/columns/serial.d.cts +1 -0
  348. package/pg-core/columns/serial.d.ts +1 -0
  349. package/pg-core/columns/serial.js.map +1 -1
  350. package/pg-core/columns/smallint.cjs.map +1 -1
  351. package/pg-core/columns/smallint.d.cts +1 -0
  352. package/pg-core/columns/smallint.d.ts +1 -0
  353. package/pg-core/columns/smallint.js.map +1 -1
  354. package/pg-core/columns/smallserial.cjs.map +1 -1
  355. package/pg-core/columns/smallserial.d.cts +1 -0
  356. package/pg-core/columns/smallserial.d.ts +1 -0
  357. package/pg-core/columns/smallserial.js.map +1 -1
  358. package/pg-core/columns/text.cjs.map +1 -1
  359. package/pg-core/columns/text.d.cts +1 -0
  360. package/pg-core/columns/text.d.ts +1 -0
  361. package/pg-core/columns/text.js.map +1 -1
  362. package/pg-core/columns/time.cjs.map +1 -1
  363. package/pg-core/columns/time.d.cts +1 -0
  364. package/pg-core/columns/time.d.ts +1 -0
  365. package/pg-core/columns/time.js.map +1 -1
  366. package/pg-core/columns/timestamp.cjs.map +1 -1
  367. package/pg-core/columns/timestamp.d.cts +2 -0
  368. package/pg-core/columns/timestamp.d.ts +2 -0
  369. package/pg-core/columns/timestamp.js.map +1 -1
  370. package/pg-core/columns/uuid.cjs.map +1 -1
  371. package/pg-core/columns/uuid.d.cts +1 -0
  372. package/pg-core/columns/uuid.d.ts +1 -0
  373. package/pg-core/columns/uuid.js.map +1 -1
  374. package/pg-core/columns/varchar.cjs.map +1 -1
  375. package/pg-core/columns/varchar.d.cts +1 -0
  376. package/pg-core/columns/varchar.d.ts +1 -0
  377. package/pg-core/columns/varchar.js.map +1 -1
  378. package/pg-core/columns/vector_extension/bit.cjs.map +1 -1
  379. package/pg-core/columns/vector_extension/bit.d.cts +1 -0
  380. package/pg-core/columns/vector_extension/bit.d.ts +1 -0
  381. package/pg-core/columns/vector_extension/bit.js.map +1 -1
  382. package/pg-core/columns/vector_extension/halfvec.cjs.map +1 -1
  383. package/pg-core/columns/vector_extension/halfvec.d.cts +1 -0
  384. package/pg-core/columns/vector_extension/halfvec.d.ts +1 -0
  385. package/pg-core/columns/vector_extension/halfvec.js.map +1 -1
  386. package/pg-core/columns/vector_extension/sparsevec.cjs.map +1 -1
  387. package/pg-core/columns/vector_extension/sparsevec.d.cts +1 -0
  388. package/pg-core/columns/vector_extension/sparsevec.d.ts +1 -0
  389. package/pg-core/columns/vector_extension/sparsevec.js.map +1 -1
  390. package/pg-core/columns/vector_extension/vector.cjs.map +1 -1
  391. package/pg-core/columns/vector_extension/vector.d.cts +1 -0
  392. package/pg-core/columns/vector_extension/vector.d.ts +1 -0
  393. package/pg-core/columns/vector_extension/vector.js.map +1 -1
  394. package/pg-core/foreign-keys.cjs +0 -4
  395. package/pg-core/foreign-keys.cjs.map +1 -1
  396. package/pg-core/foreign-keys.d.cts +0 -2
  397. package/pg-core/foreign-keys.d.ts +0 -2
  398. package/pg-core/foreign-keys.js +0 -4
  399. package/pg-core/foreign-keys.js.map +1 -1
  400. package/pg-core/primary-keys.cjs +0 -3
  401. package/pg-core/primary-keys.cjs.map +1 -1
  402. package/pg-core/primary-keys.d.cts +0 -1
  403. package/pg-core/primary-keys.d.ts +0 -1
  404. package/pg-core/primary-keys.js +0 -3
  405. package/pg-core/primary-keys.js.map +1 -1
  406. package/pg-core/query-builders/insert.cjs.map +1 -1
  407. package/pg-core/query-builders/insert.d.cts +9 -6
  408. package/pg-core/query-builders/insert.d.ts +9 -6
  409. package/pg-core/query-builders/insert.js.map +1 -1
  410. package/pg-core/query-builders/update.cjs.map +1 -1
  411. package/pg-core/query-builders/update.d.cts +1 -1
  412. package/pg-core/query-builders/update.d.ts +1 -1
  413. package/pg-core/query-builders/update.js.map +1 -1
  414. package/pg-core/unique-constraint.cjs +0 -5
  415. package/pg-core/unique-constraint.cjs.map +1 -1
  416. package/pg-core/unique-constraint.d.cts +0 -2
  417. package/pg-core/unique-constraint.d.ts +0 -2
  418. package/pg-core/unique-constraint.js +0 -5
  419. package/pg-core/unique-constraint.js.map +1 -1
  420. package/relations.cjs +5 -0
  421. package/relations.cjs.map +1 -1
  422. package/relations.js +5 -0
  423. package/relations.js.map +1 -1
  424. package/singlestore-core/columns/bigint.cjs.map +1 -1
  425. package/singlestore-core/columns/bigint.d.cts +2 -0
  426. package/singlestore-core/columns/bigint.d.ts +2 -0
  427. package/singlestore-core/columns/bigint.js.map +1 -1
  428. package/singlestore-core/columns/binary.cjs +1 -0
  429. package/singlestore-core/columns/binary.cjs.map +1 -1
  430. package/singlestore-core/columns/binary.d.cts +2 -0
  431. package/singlestore-core/columns/binary.d.ts +2 -0
  432. package/singlestore-core/columns/binary.js +1 -0
  433. package/singlestore-core/columns/binary.js.map +1 -1
  434. package/singlestore-core/columns/boolean.cjs.map +1 -1
  435. package/singlestore-core/columns/boolean.d.cts +1 -0
  436. package/singlestore-core/columns/boolean.d.ts +1 -0
  437. package/singlestore-core/columns/boolean.js.map +1 -1
  438. package/singlestore-core/columns/char.cjs +1 -0
  439. package/singlestore-core/columns/char.cjs.map +1 -1
  440. package/singlestore-core/columns/char.d.cts +2 -0
  441. package/singlestore-core/columns/char.d.ts +2 -0
  442. package/singlestore-core/columns/char.js +1 -0
  443. package/singlestore-core/columns/char.js.map +1 -1
  444. package/singlestore-core/columns/common.cjs.map +1 -1
  445. package/singlestore-core/columns/common.d.cts +1 -1
  446. package/singlestore-core/columns/common.d.ts +1 -1
  447. package/singlestore-core/columns/common.js.map +1 -1
  448. package/singlestore-core/columns/custom.cjs.map +1 -1
  449. package/singlestore-core/columns/custom.d.cts +1 -0
  450. package/singlestore-core/columns/custom.d.ts +1 -0
  451. package/singlestore-core/columns/custom.js.map +1 -1
  452. package/singlestore-core/columns/date.cjs.map +1 -1
  453. package/singlestore-core/columns/date.d.cts +2 -0
  454. package/singlestore-core/columns/date.d.ts +2 -0
  455. package/singlestore-core/columns/date.js.map +1 -1
  456. package/singlestore-core/columns/datetime.cjs.map +1 -1
  457. package/singlestore-core/columns/datetime.d.cts +2 -0
  458. package/singlestore-core/columns/datetime.d.ts +2 -0
  459. package/singlestore-core/columns/datetime.js.map +1 -1
  460. package/singlestore-core/columns/decimal.cjs.map +1 -1
  461. package/singlestore-core/columns/decimal.d.cts +3 -0
  462. package/singlestore-core/columns/decimal.d.ts +3 -0
  463. package/singlestore-core/columns/decimal.js.map +1 -1
  464. package/singlestore-core/columns/double.cjs.map +1 -1
  465. package/singlestore-core/columns/double.d.cts +1 -0
  466. package/singlestore-core/columns/double.d.ts +1 -0
  467. package/singlestore-core/columns/double.js.map +1 -1
  468. package/singlestore-core/columns/enum.cjs.map +1 -1
  469. package/singlestore-core/columns/enum.d.cts +1 -0
  470. package/singlestore-core/columns/enum.d.ts +1 -0
  471. package/singlestore-core/columns/enum.js.map +1 -1
  472. package/singlestore-core/columns/float.cjs.map +1 -1
  473. package/singlestore-core/columns/float.d.cts +1 -0
  474. package/singlestore-core/columns/float.d.ts +1 -0
  475. package/singlestore-core/columns/float.js.map +1 -1
  476. package/singlestore-core/columns/int.cjs.map +1 -1
  477. package/singlestore-core/columns/int.d.cts +1 -0
  478. package/singlestore-core/columns/int.d.ts +1 -0
  479. package/singlestore-core/columns/int.js.map +1 -1
  480. package/singlestore-core/columns/json.cjs.map +1 -1
  481. package/singlestore-core/columns/json.d.cts +1 -0
  482. package/singlestore-core/columns/json.d.ts +1 -0
  483. package/singlestore-core/columns/json.js.map +1 -1
  484. package/singlestore-core/columns/mediumint.cjs.map +1 -1
  485. package/singlestore-core/columns/mediumint.d.cts +1 -0
  486. package/singlestore-core/columns/mediumint.d.ts +1 -0
  487. package/singlestore-core/columns/mediumint.js.map +1 -1
  488. package/singlestore-core/columns/real.cjs.map +1 -1
  489. package/singlestore-core/columns/real.d.cts +1 -0
  490. package/singlestore-core/columns/real.d.ts +1 -0
  491. package/singlestore-core/columns/real.js.map +1 -1
  492. package/singlestore-core/columns/serial.cjs.map +1 -1
  493. package/singlestore-core/columns/serial.d.cts +1 -0
  494. package/singlestore-core/columns/serial.d.ts +1 -0
  495. package/singlestore-core/columns/serial.js.map +1 -1
  496. package/singlestore-core/columns/smallint.cjs.map +1 -1
  497. package/singlestore-core/columns/smallint.d.cts +1 -0
  498. package/singlestore-core/columns/smallint.d.ts +1 -0
  499. package/singlestore-core/columns/smallint.js.map +1 -1
  500. package/singlestore-core/columns/text.cjs.map +1 -1
  501. package/singlestore-core/columns/text.d.cts +1 -0
  502. package/singlestore-core/columns/text.d.ts +1 -0
  503. package/singlestore-core/columns/text.js.map +1 -1
  504. package/singlestore-core/columns/time.cjs.map +1 -1
  505. package/singlestore-core/columns/time.d.cts +1 -0
  506. package/singlestore-core/columns/time.d.ts +1 -0
  507. package/singlestore-core/columns/time.js.map +1 -1
  508. package/singlestore-core/columns/timestamp.cjs.map +1 -1
  509. package/singlestore-core/columns/timestamp.d.cts +2 -0
  510. package/singlestore-core/columns/timestamp.d.ts +2 -0
  511. package/singlestore-core/columns/timestamp.js.map +1 -1
  512. package/singlestore-core/columns/tinyint.cjs.map +1 -1
  513. package/singlestore-core/columns/tinyint.d.cts +1 -0
  514. package/singlestore-core/columns/tinyint.d.ts +1 -0
  515. package/singlestore-core/columns/tinyint.js.map +1 -1
  516. package/singlestore-core/columns/varbinary.cjs.map +1 -1
  517. package/singlestore-core/columns/varbinary.d.cts +1 -0
  518. package/singlestore-core/columns/varbinary.d.ts +1 -0
  519. package/singlestore-core/columns/varbinary.js.map +1 -1
  520. package/singlestore-core/columns/varchar.cjs.map +1 -1
  521. package/singlestore-core/columns/varchar.d.cts +1 -0
  522. package/singlestore-core/columns/varchar.d.ts +1 -0
  523. package/singlestore-core/columns/varchar.js.map +1 -1
  524. package/singlestore-core/columns/vector.cjs.map +1 -1
  525. package/singlestore-core/columns/vector.d.cts +2 -0
  526. package/singlestore-core/columns/vector.d.ts +2 -0
  527. package/singlestore-core/columns/vector.js.map +1 -1
  528. package/singlestore-core/columns/year.cjs.map +1 -1
  529. package/singlestore-core/columns/year.d.cts +1 -0
  530. package/singlestore-core/columns/year.d.ts +1 -0
  531. package/singlestore-core/columns/year.js.map +1 -1
  532. package/singlestore-core/query-builders/insert.cjs.map +1 -1
  533. package/singlestore-core/query-builders/insert.d.cts +1 -1
  534. package/singlestore-core/query-builders/insert.d.ts +1 -1
  535. package/singlestore-core/query-builders/insert.js.map +1 -1
  536. package/singlestore-core/query-builders/update.cjs.map +1 -1
  537. package/singlestore-core/query-builders/update.d.cts +1 -1
  538. package/singlestore-core/query-builders/update.d.ts +1 -1
  539. package/singlestore-core/query-builders/update.js.map +1 -1
  540. package/sql/sql.cjs +3 -10
  541. package/sql/sql.cjs.map +1 -1
  542. package/sql/sql.d.cts +1 -1
  543. package/sql/sql.d.ts +1 -1
  544. package/sql/sql.js +3 -10
  545. package/sql/sql.js.map +1 -1
  546. package/sqlite-core/columns/blob.cjs +3 -3
  547. package/sqlite-core/columns/blob.cjs.map +1 -1
  548. package/sqlite-core/columns/blob.d.cts +3 -0
  549. package/sqlite-core/columns/blob.d.ts +3 -0
  550. package/sqlite-core/columns/blob.js +3 -3
  551. package/sqlite-core/columns/blob.js.map +1 -1
  552. package/sqlite-core/columns/custom.cjs.map +1 -1
  553. package/sqlite-core/columns/custom.d.cts +1 -0
  554. package/sqlite-core/columns/custom.d.ts +1 -0
  555. package/sqlite-core/columns/custom.js.map +1 -1
  556. package/sqlite-core/columns/integer.cjs.map +1 -1
  557. package/sqlite-core/columns/integer.d.cts +3 -0
  558. package/sqlite-core/columns/integer.d.ts +3 -0
  559. package/sqlite-core/columns/integer.js.map +1 -1
  560. package/sqlite-core/columns/numeric.cjs.map +1 -1
  561. package/sqlite-core/columns/numeric.d.cts +3 -0
  562. package/sqlite-core/columns/numeric.d.ts +3 -0
  563. package/sqlite-core/columns/numeric.js.map +1 -1
  564. package/sqlite-core/columns/real.cjs.map +1 -1
  565. package/sqlite-core/columns/real.d.cts +1 -0
  566. package/sqlite-core/columns/real.d.ts +1 -0
  567. package/sqlite-core/columns/real.js.map +1 -1
  568. package/sqlite-core/columns/text.cjs.map +1 -1
  569. package/sqlite-core/columns/text.d.cts +2 -0
  570. package/sqlite-core/columns/text.d.ts +2 -0
  571. package/sqlite-core/columns/text.js.map +1 -1
  572. package/sqlite-core/query-builders/insert.cjs.map +1 -1
  573. package/sqlite-core/query-builders/insert.d.cts +2 -2
  574. package/sqlite-core/query-builders/insert.d.ts +2 -2
  575. package/sqlite-core/query-builders/insert.js.map +1 -1
  576. package/sqlite-core/query-builders/update.cjs.map +1 -1
  577. package/sqlite-core/query-builders/update.d.cts +1 -1
  578. package/sqlite-core/query-builders/update.d.ts +1 -1
  579. package/sqlite-core/query-builders/update.js.map +1 -1
  580. package/version.cjs +1 -1
  581. package/version.d.cts +1 -1
  582. package/version.d.ts +1 -1
  583. package/version.js +1 -1
  584. package/cockroach/driver.cjs +0 -113
  585. package/cockroach/driver.cjs.map +0 -1
  586. package/cockroach/driver.d.cts +0 -42
  587. package/cockroach/driver.d.ts +0 -42
  588. package/cockroach/driver.js +0 -77
  589. package/cockroach/driver.js.map +0 -1
  590. package/cockroach/index.cjs +0 -25
  591. package/cockroach/index.cjs.map +0 -1
  592. package/cockroach/index.d.cts +0 -2
  593. package/cockroach/index.d.ts +0 -2
  594. package/cockroach/index.js +0 -3
  595. package/cockroach/index.js.map +0 -1
  596. package/cockroach/migrator.cjs +0 -33
  597. package/cockroach/migrator.cjs.map +0 -1
  598. package/cockroach/migrator.d.cts +0 -3
  599. package/cockroach/migrator.d.ts +0 -3
  600. package/cockroach/migrator.js +0 -9
  601. package/cockroach/migrator.js.map +0 -1
  602. package/cockroach/session.cjs +0 -253
  603. package/cockroach/session.cjs.map +0 -1
  604. package/cockroach/session.d.cts +0 -48
  605. package/cockroach/session.d.ts +0 -48
  606. package/cockroach/session.js +0 -217
  607. package/cockroach/session.js.map +0 -1
  608. package/cockroach-core/alias.cjs +0 -32
  609. package/cockroach-core/alias.cjs.map +0 -1
  610. package/cockroach-core/alias.d.cts +0 -4
  611. package/cockroach-core/alias.d.ts +0 -4
  612. package/cockroach-core/alias.js +0 -8
  613. package/cockroach-core/alias.js.map +0 -1
  614. package/cockroach-core/checks.cjs +0 -58
  615. package/cockroach-core/checks.cjs.map +0 -1
  616. package/cockroach-core/checks.d.cts +0 -18
  617. package/cockroach-core/checks.d.ts +0 -18
  618. package/cockroach-core/checks.js +0 -32
  619. package/cockroach-core/checks.js.map +0 -1
  620. package/cockroach-core/columns/all.cjs +0 -81
  621. package/cockroach-core/columns/all.cjs.map +0 -1
  622. package/cockroach-core/columns/all.d.cts +0 -52
  623. package/cockroach-core/columns/all.d.ts +0 -52
  624. package/cockroach-core/columns/all.js +0 -57
  625. package/cockroach-core/columns/all.js.map +0 -1
  626. package/cockroach-core/columns/bigint.cjs +0 -104
  627. package/cockroach-core/columns/bigint.cjs.map +0 -1
  628. package/cockroach-core/columns/bigint.d.cts +0 -37
  629. package/cockroach-core/columns/bigint.d.ts +0 -37
  630. package/cockroach-core/columns/bigint.js +0 -75
  631. package/cockroach-core/columns/bigint.js.map +0 -1
  632. package/cockroach-core/columns/bit.cjs +0 -61
  633. package/cockroach-core/columns/bit.cjs.map +0 -1
  634. package/cockroach-core/columns/bit.d.cts +0 -29
  635. package/cockroach-core/columns/bit.d.ts +0 -29
  636. package/cockroach-core/columns/bit.js +0 -35
  637. package/cockroach-core/columns/bit.js.map +0 -1
  638. package/cockroach-core/columns/bool.cjs +0 -59
  639. package/cockroach-core/columns/bool.cjs.map +0 -1
  640. package/cockroach-core/columns/bool.d.cts +0 -17
  641. package/cockroach-core/columns/bool.d.ts +0 -17
  642. package/cockroach-core/columns/bool.js +0 -32
  643. package/cockroach-core/columns/bool.js.map +0 -1
  644. package/cockroach-core/columns/char.cjs +0 -62
  645. package/cockroach-core/columns/char.cjs.map +0 -1
  646. package/cockroach-core/columns/char.d.cts +0 -31
  647. package/cockroach-core/columns/char.d.ts +0 -31
  648. package/cockroach-core/columns/char.js +0 -36
  649. package/cockroach-core/columns/char.js.map +0 -1
  650. package/cockroach-core/columns/common.cjs +0 -199
  651. package/cockroach-core/columns/common.cjs.map +0 -1
  652. package/cockroach-core/columns/common.d.cts +0 -98
  653. package/cockroach-core/columns/common.d.ts +0 -98
  654. package/cockroach-core/columns/common.js +0 -169
  655. package/cockroach-core/columns/common.js.map +0 -1
  656. package/cockroach-core/columns/custom.cjs +0 -102
  657. package/cockroach-core/columns/custom.cjs.map +0 -1
  658. package/cockroach-core/columns/custom.d.cts +0 -261
  659. package/cockroach-core/columns/custom.d.ts +0 -261
  660. package/cockroach-core/columns/custom.js +0 -76
  661. package/cockroach-core/columns/custom.js.map +0 -1
  662. package/cockroach-core/columns/date.cjs +0 -91
  663. package/cockroach-core/columns/date.cjs.map +0 -1
  664. package/cockroach-core/columns/date.common.cjs +0 -37
  665. package/cockroach-core/columns/date.common.cjs.map +0 -1
  666. package/cockroach-core/columns/date.common.d.cts +0 -7
  667. package/cockroach-core/columns/date.common.d.ts +0 -7
  668. package/cockroach-core/columns/date.common.js +0 -13
  669. package/cockroach-core/columns/date.common.js.map +0 -1
  670. package/cockroach-core/columns/date.d.cts +0 -36
  671. package/cockroach-core/columns/date.d.ts +0 -36
  672. package/cockroach-core/columns/date.js +0 -63
  673. package/cockroach-core/columns/date.js.map +0 -1
  674. package/cockroach-core/columns/decimal.cjs +0 -164
  675. package/cockroach-core/columns/decimal.cjs.map +0 -1
  676. package/cockroach-core/columns/decimal.d.cts +0 -80
  677. package/cockroach-core/columns/decimal.d.ts +0 -80
  678. package/cockroach-core/columns/decimal.js +0 -133
  679. package/cockroach-core/columns/decimal.js.map +0 -1
  680. package/cockroach-core/columns/enum.cjs +0 -127
  681. package/cockroach-core/columns/enum.cjs.map +0 -1
  682. package/cockroach-core/columns/enum.d.cts +0 -64
  683. package/cockroach-core/columns/enum.d.ts +0 -64
  684. package/cockroach-core/columns/enum.js +0 -96
  685. package/cockroach-core/columns/enum.js.map +0 -1
  686. package/cockroach-core/columns/float.cjs +0 -65
  687. package/cockroach-core/columns/float.cjs.map +0 -1
  688. package/cockroach-core/columns/float.d.cts +0 -18
  689. package/cockroach-core/columns/float.d.ts +0 -18
  690. package/cockroach-core/columns/float.js +0 -38
  691. package/cockroach-core/columns/float.js.map +0 -1
  692. package/cockroach-core/columns/geometry.cjs +0 -105
  693. package/cockroach-core/columns/geometry.cjs.map +0 -1
  694. package/cockroach-core/columns/geometry.d.cts +0 -60
  695. package/cockroach-core/columns/geometry.d.ts +0 -60
  696. package/cockroach-core/columns/geometry.js +0 -77
  697. package/cockroach-core/columns/geometry.js.map +0 -1
  698. package/cockroach-core/columns/index.cjs +0 -71
  699. package/cockroach-core/columns/index.cjs.map +0 -1
  700. package/cockroach-core/columns/index.d.cts +0 -25
  701. package/cockroach-core/columns/index.d.ts +0 -25
  702. package/cockroach-core/columns/index.js +0 -26
  703. package/cockroach-core/columns/index.js.map +0 -1
  704. package/cockroach-core/columns/inet.cjs +0 -56
  705. package/cockroach-core/columns/inet.cjs.map +0 -1
  706. package/cockroach-core/columns/inet.d.cts +0 -16
  707. package/cockroach-core/columns/inet.d.ts +0 -16
  708. package/cockroach-core/columns/inet.js +0 -30
  709. package/cockroach-core/columns/inet.js.map +0 -1
  710. package/cockroach-core/columns/int.common.cjs +0 -55
  711. package/cockroach-core/columns/int.common.cjs.map +0 -1
  712. package/cockroach-core/columns/int.common.d.cts +0 -11
  713. package/cockroach-core/columns/int.common.d.ts +0 -11
  714. package/cockroach-core/columns/int.common.js +0 -31
  715. package/cockroach-core/columns/int.common.js.map +0 -1
  716. package/cockroach-core/columns/integer.cjs +0 -63
  717. package/cockroach-core/columns/integer.cjs.map +0 -1
  718. package/cockroach-core/columns/integer.d.cts +0 -18
  719. package/cockroach-core/columns/integer.d.ts +0 -18
  720. package/cockroach-core/columns/integer.js +0 -37
  721. package/cockroach-core/columns/integer.js.map +0 -1
  722. package/cockroach-core/columns/interval.cjs +0 -63
  723. package/cockroach-core/columns/interval.cjs.map +0 -1
  724. package/cockroach-core/columns/interval.d.cts +0 -28
  725. package/cockroach-core/columns/interval.d.ts +0 -28
  726. package/cockroach-core/columns/interval.js +0 -37
  727. package/cockroach-core/columns/interval.js.map +0 -1
  728. package/cockroach-core/columns/jsonb.cjs +0 -72
  729. package/cockroach-core/columns/jsonb.cjs.map +0 -1
  730. package/cockroach-core/columns/jsonb.d.cts +0 -20
  731. package/cockroach-core/columns/jsonb.d.ts +0 -20
  732. package/cockroach-core/columns/jsonb.js +0 -46
  733. package/cockroach-core/columns/jsonb.js.map +0 -1
  734. package/cockroach-core/columns/real.cjs +0 -66
  735. package/cockroach-core/columns/real.cjs.map +0 -1
  736. package/cockroach-core/columns/real.d.cts +0 -21
  737. package/cockroach-core/columns/real.d.ts +0 -21
  738. package/cockroach-core/columns/real.js +0 -40
  739. package/cockroach-core/columns/real.js.map +0 -1
  740. package/cockroach-core/columns/smallint.cjs +0 -68
  741. package/cockroach-core/columns/smallint.cjs.map +0 -1
  742. package/cockroach-core/columns/smallint.d.cts +0 -19
  743. package/cockroach-core/columns/smallint.d.ts +0 -19
  744. package/cockroach-core/columns/smallint.js +0 -41
  745. package/cockroach-core/columns/smallint.js.map +0 -1
  746. package/cockroach-core/columns/string.cjs +0 -67
  747. package/cockroach-core/columns/string.cjs.map +0 -1
  748. package/cockroach-core/columns/string.d.cts +0 -36
  749. package/cockroach-core/columns/string.d.ts +0 -36
  750. package/cockroach-core/columns/string.js +0 -40
  751. package/cockroach-core/columns/string.js.map +0 -1
  752. package/cockroach-core/columns/time.cjs +0 -70
  753. package/cockroach-core/columns/time.cjs.map +0 -1
  754. package/cockroach-core/columns/time.d.cts +0 -31
  755. package/cockroach-core/columns/time.d.ts +0 -31
  756. package/cockroach-core/columns/time.js +0 -44
  757. package/cockroach-core/columns/time.js.map +0 -1
  758. package/cockroach-core/columns/timestamp.cjs +0 -111
  759. package/cockroach-core/columns/timestamp.cjs.map +0 -1
  760. package/cockroach-core/columns/timestamp.d.cts +0 -52
  761. package/cockroach-core/columns/timestamp.d.ts +0 -52
  762. package/cockroach-core/columns/timestamp.js +0 -83
  763. package/cockroach-core/columns/timestamp.js.map +0 -1
  764. package/cockroach-core/columns/utils.cjs +0 -65
  765. package/cockroach-core/columns/utils.cjs.map +0 -1
  766. package/cockroach-core/columns/utils.d.cts +0 -4
  767. package/cockroach-core/columns/utils.d.ts +0 -4
  768. package/cockroach-core/columns/utils.js +0 -41
  769. package/cockroach-core/columns/utils.js.map +0 -1
  770. package/cockroach-core/columns/uuid.cjs +0 -63
  771. package/cockroach-core/columns/uuid.cjs.map +0 -1
  772. package/cockroach-core/columns/uuid.d.cts +0 -20
  773. package/cockroach-core/columns/uuid.d.ts +0 -20
  774. package/cockroach-core/columns/uuid.js +0 -37
  775. package/cockroach-core/columns/uuid.js.map +0 -1
  776. package/cockroach-core/columns/varbit.cjs +0 -59
  777. package/cockroach-core/columns/varbit.cjs.map +0 -1
  778. package/cockroach-core/columns/varbit.d.cts +0 -24
  779. package/cockroach-core/columns/varbit.d.ts +0 -24
  780. package/cockroach-core/columns/varbit.js +0 -33
  781. package/cockroach-core/columns/varbit.js.map +0 -1
  782. package/cockroach-core/columns/varchar.cjs +0 -61
  783. package/cockroach-core/columns/varchar.cjs.map +0 -1
  784. package/cockroach-core/columns/varchar.d.cts +0 -30
  785. package/cockroach-core/columns/varchar.d.ts +0 -30
  786. package/cockroach-core/columns/varchar.js +0 -35
  787. package/cockroach-core/columns/varchar.js.map +0 -1
  788. package/cockroach-core/columns/vector.cjs +0 -65
  789. package/cockroach-core/columns/vector.cjs.map +0 -1
  790. package/cockroach-core/columns/vector.d.cts +0 -26
  791. package/cockroach-core/columns/vector.d.ts +0 -26
  792. package/cockroach-core/columns/vector.js +0 -39
  793. package/cockroach-core/columns/vector.js.map +0 -1
  794. package/cockroach-core/db.cjs +0 -346
  795. package/cockroach-core/db.cjs.map +0 -1
  796. package/cockroach-core/db.d.cts +0 -282
  797. package/cockroach-core/db.d.ts +0 -282
  798. package/cockroach-core/db.js +0 -327
  799. package/cockroach-core/db.js.map +0 -1
  800. package/cockroach-core/dialect.cjs +0 -1146
  801. package/cockroach-core/dialect.cjs.map +0 -1
  802. package/cockroach-core/dialect.d.cts +0 -65
  803. package/cockroach-core/dialect.d.ts +0 -65
  804. package/cockroach-core/dialect.js +0 -1126
  805. package/cockroach-core/dialect.js.map +0 -1
  806. package/cockroach-core/expressions.cjs +0 -49
  807. package/cockroach-core/expressions.cjs.map +0 -1
  808. package/cockroach-core/expressions.d.cts +0 -8
  809. package/cockroach-core/expressions.d.ts +0 -8
  810. package/cockroach-core/expressions.js +0 -22
  811. package/cockroach-core/expressions.js.map +0 -1
  812. package/cockroach-core/foreign-keys.cjs +0 -92
  813. package/cockroach-core/foreign-keys.cjs.map +0 -1
  814. package/cockroach-core/foreign-keys.d.cts +0 -52
  815. package/cockroach-core/foreign-keys.d.ts +0 -52
  816. package/cockroach-core/foreign-keys.js +0 -66
  817. package/cockroach-core/foreign-keys.js.map +0 -1
  818. package/cockroach-core/index.cjs +0 -61
  819. package/cockroach-core/index.cjs.map +0 -1
  820. package/cockroach-core/index.d.cts +0 -20
  821. package/cockroach-core/index.d.ts +0 -20
  822. package/cockroach-core/index.js +0 -21
  823. package/cockroach-core/index.js.map +0 -1
  824. package/cockroach-core/indexes.cjs +0 -137
  825. package/cockroach-core/indexes.cjs.map +0 -1
  826. package/cockroach-core/indexes.d.cts +0 -64
  827. package/cockroach-core/indexes.d.ts +0 -64
  828. package/cockroach-core/indexes.js +0 -109
  829. package/cockroach-core/indexes.js.map +0 -1
  830. package/cockroach-core/policies.cjs +0 -58
  831. package/cockroach-core/policies.cjs.map +0 -1
  832. package/cockroach-core/policies.d.cts +0 -24
  833. package/cockroach-core/policies.d.ts +0 -24
  834. package/cockroach-core/policies.js +0 -33
  835. package/cockroach-core/policies.js.map +0 -1
  836. package/cockroach-core/primary-keys.cjs +0 -64
  837. package/cockroach-core/primary-keys.cjs.map +0 -1
  838. package/cockroach-core/primary-keys.d.cts +0 -23
  839. package/cockroach-core/primary-keys.d.ts +0 -23
  840. package/cockroach-core/primary-keys.js +0 -38
  841. package/cockroach-core/primary-keys.js.map +0 -1
  842. package/cockroach-core/query-builders/count.cjs +0 -79
  843. package/cockroach-core/query-builders/count.cjs.map +0 -1
  844. package/cockroach-core/query-builders/count.d.cts +0 -29
  845. package/cockroach-core/query-builders/count.d.ts +0 -29
  846. package/cockroach-core/query-builders/count.js +0 -55
  847. package/cockroach-core/query-builders/count.js.map +0 -1
  848. package/cockroach-core/query-builders/delete.cjs +0 -124
  849. package/cockroach-core/query-builders/delete.cjs.map +0 -1
  850. package/cockroach-core/query-builders/delete.d.cts +0 -103
  851. package/cockroach-core/query-builders/delete.d.ts +0 -103
  852. package/cockroach-core/query-builders/delete.js +0 -100
  853. package/cockroach-core/query-builders/delete.js.map +0 -1
  854. package/cockroach-core/query-builders/index.cjs +0 -35
  855. package/cockroach-core/query-builders/index.cjs.map +0 -1
  856. package/cockroach-core/query-builders/index.d.cts +0 -7
  857. package/cockroach-core/query-builders/index.d.ts +0 -7
  858. package/cockroach-core/query-builders/index.js +0 -8
  859. package/cockroach-core/query-builders/index.js.map +0 -1
  860. package/cockroach-core/query-builders/insert.cjs +0 -213
  861. package/cockroach-core/query-builders/insert.cjs.map +0 -1
  862. package/cockroach-core/query-builders/insert.d.cts +0 -168
  863. package/cockroach-core/query-builders/insert.d.ts +0 -168
  864. package/cockroach-core/query-builders/insert.js +0 -188
  865. package/cockroach-core/query-builders/insert.js.map +0 -1
  866. package/cockroach-core/query-builders/query-builder.cjs +0 -118
  867. package/cockroach-core/query-builders/query-builder.cjs.map +0 -1
  868. package/cockroach-core/query-builders/query-builder.d.cts +0 -37
  869. package/cockroach-core/query-builders/query-builder.d.ts +0 -37
  870. package/cockroach-core/query-builders/query-builder.js +0 -94
  871. package/cockroach-core/query-builders/query-builder.js.map +0 -1
  872. package/cockroach-core/query-builders/query.cjs +0 -145
  873. package/cockroach-core/query-builders/query.cjs.map +0 -1
  874. package/cockroach-core/query-builders/query.d.cts +0 -47
  875. package/cockroach-core/query-builders/query.d.ts +0 -47
  876. package/cockroach-core/query-builders/query.js +0 -122
  877. package/cockroach-core/query-builders/query.js.map +0 -1
  878. package/cockroach-core/query-builders/raw.cjs +0 -57
  879. package/cockroach-core/query-builders/raw.cjs.map +0 -1
  880. package/cockroach-core/query-builders/raw.d.cts +0 -22
  881. package/cockroach-core/query-builders/raw.d.ts +0 -22
  882. package/cockroach-core/query-builders/raw.js +0 -33
  883. package/cockroach-core/query-builders/raw.js.map +0 -1
  884. package/cockroach-core/query-builders/refresh-materialized-view.cjs +0 -83
  885. package/cockroach-core/query-builders/refresh-materialized-view.cjs.map +0 -1
  886. package/cockroach-core/query-builders/refresh-materialized-view.d.cts +0 -28
  887. package/cockroach-core/query-builders/refresh-materialized-view.d.ts +0 -28
  888. package/cockroach-core/query-builders/refresh-materialized-view.js +0 -59
  889. package/cockroach-core/query-builders/refresh-materialized-view.js.map +0 -1
  890. package/cockroach-core/query-builders/select.cjs +0 -848
  891. package/cockroach-core/query-builders/select.cjs.map +0 -1
  892. package/cockroach-core/query-builders/select.d.cts +0 -787
  893. package/cockroach-core/query-builders/select.d.ts +0 -787
  894. package/cockroach-core/query-builders/select.js +0 -821
  895. package/cockroach-core/query-builders/select.js.map +0 -1
  896. package/cockroach-core/query-builders/select.types.cjs +0 -17
  897. package/cockroach-core/query-builders/select.types.cjs.map +0 -1
  898. package/cockroach-core/query-builders/select.types.d.cts +0 -140
  899. package/cockroach-core/query-builders/select.types.d.ts +0 -140
  900. package/cockroach-core/query-builders/select.types.js +0 -1
  901. package/cockroach-core/query-builders/select.types.js.map +0 -1
  902. package/cockroach-core/query-builders/update.cjs +0 -240
  903. package/cockroach-core/query-builders/update.cjs.map +0 -1
  904. package/cockroach-core/query-builders/update.d.cts +0 -170
  905. package/cockroach-core/query-builders/update.d.ts +0 -170
  906. package/cockroach-core/query-builders/update.js +0 -219
  907. package/cockroach-core/query-builders/update.js.map +0 -1
  908. package/cockroach-core/roles.cjs +0 -54
  909. package/cockroach-core/roles.cjs.map +0 -1
  910. package/cockroach-core/roles.d.cts +0 -12
  911. package/cockroach-core/roles.d.ts +0 -12
  912. package/cockroach-core/roles.js +0 -29
  913. package/cockroach-core/roles.js.map +0 -1
  914. package/cockroach-core/schema.cjs +0 -80
  915. package/cockroach-core/schema.cjs.map +0 -1
  916. package/cockroach-core/schema.d.cts +0 -22
  917. package/cockroach-core/schema.d.ts +0 -22
  918. package/cockroach-core/schema.js +0 -60
  919. package/cockroach-core/schema.js.map +0 -1
  920. package/cockroach-core/sequence.cjs +0 -52
  921. package/cockroach-core/sequence.cjs.map +0 -1
  922. package/cockroach-core/sequence.d.cts +0 -17
  923. package/cockroach-core/sequence.d.ts +0 -17
  924. package/cockroach-core/sequence.js +0 -25
  925. package/cockroach-core/sequence.js.map +0 -1
  926. package/cockroach-core/session.cjs +0 -120
  927. package/cockroach-core/session.cjs.map +0 -1
  928. package/cockroach-core/session.d.cts +0 -62
  929. package/cockroach-core/session.d.ts +0 -62
  930. package/cockroach-core/session.js +0 -94
  931. package/cockroach-core/session.js.map +0 -1
  932. package/cockroach-core/subquery.cjs +0 -17
  933. package/cockroach-core/subquery.cjs.map +0 -1
  934. package/cockroach-core/subquery.d.cts +0 -18
  935. package/cockroach-core/subquery.d.ts +0 -18
  936. package/cockroach-core/subquery.js +0 -1
  937. package/cockroach-core/subquery.js.map +0 -1
  938. package/cockroach-core/table.cjs +0 -100
  939. package/cockroach-core/table.cjs.map +0 -1
  940. package/cockroach-core/table.d.cts +0 -37
  941. package/cockroach-core/table.d.ts +0 -37
  942. package/cockroach-core/table.js +0 -73
  943. package/cockroach-core/table.js.map +0 -1
  944. package/cockroach-core/unique-constraint.cjs +0 -77
  945. package/cockroach-core/unique-constraint.cjs.map +0 -1
  946. package/cockroach-core/unique-constraint.d.cts +0 -23
  947. package/cockroach-core/unique-constraint.d.ts +0 -23
  948. package/cockroach-core/unique-constraint.js +0 -50
  949. package/cockroach-core/unique-constraint.js.map +0 -1
  950. package/cockroach-core/utils/array.cjs +0 -106
  951. package/cockroach-core/utils/array.cjs.map +0 -1
  952. package/cockroach-core/utils/array.d.cts +0 -3
  953. package/cockroach-core/utils/array.d.ts +0 -3
  954. package/cockroach-core/utils/array.js +0 -80
  955. package/cockroach-core/utils/array.js.map +0 -1
  956. package/cockroach-core/utils/index.cjs +0 -23
  957. package/cockroach-core/utils/index.cjs.map +0 -1
  958. package/cockroach-core/utils/index.d.cts +0 -1
  959. package/cockroach-core/utils/index.d.ts +0 -1
  960. package/cockroach-core/utils/index.js +0 -2
  961. package/cockroach-core/utils/index.js.map +0 -1
  962. package/cockroach-core/utils.cjs +0 -98
  963. package/cockroach-core/utils.cjs.map +0 -1
  964. package/cockroach-core/utils.d.cts +0 -47
  965. package/cockroach-core/utils.d.ts +0 -47
  966. package/cockroach-core/utils.js +0 -72
  967. package/cockroach-core/utils.js.map +0 -1
  968. package/cockroach-core/view-base.cjs +0 -33
  969. package/cockroach-core/view-base.cjs.map +0 -1
  970. package/cockroach-core/view-base.d.cts +0 -8
  971. package/cockroach-core/view-base.d.ts +0 -8
  972. package/cockroach-core/view-base.js +0 -9
  973. package/cockroach-core/view-base.js.map +0 -1
  974. package/cockroach-core/view.cjs +0 -271
  975. package/cockroach-core/view.cjs.map +0 -1
  976. package/cockroach-core/view.d.cts +0 -106
  977. package/cockroach-core/view.d.ts +0 -106
  978. package/cockroach-core/view.js +0 -233
  979. package/cockroach-core/view.js.map +0 -1
  980. package/mssql-core/alias.cjs +0 -32
  981. package/mssql-core/alias.cjs.map +0 -1
  982. package/mssql-core/alias.d.cts +0 -4
  983. package/mssql-core/alias.d.ts +0 -4
  984. package/mssql-core/alias.js +0 -8
  985. package/mssql-core/alias.js.map +0 -1
  986. package/mssql-core/checks.cjs +0 -58
  987. package/mssql-core/checks.cjs.map +0 -1
  988. package/mssql-core/checks.d.cts +0 -18
  989. package/mssql-core/checks.d.ts +0 -18
  990. package/mssql-core/checks.js +0 -32
  991. package/mssql-core/checks.js.map +0 -1
  992. package/mssql-core/columns/all.cjs +0 -74
  993. package/mssql-core/columns/all.cjs.map +0 -1
  994. package/mssql-core/columns/all.d.cts +0 -45
  995. package/mssql-core/columns/all.d.ts +0 -45
  996. package/mssql-core/columns/all.js +0 -50
  997. package/mssql-core/columns/all.js.map +0 -1
  998. package/mssql-core/columns/bigint.cjs +0 -72
  999. package/mssql-core/columns/bigint.cjs.map +0 -1
  1000. package/mssql-core/columns/bigint.d.cts +0 -25
  1001. package/mssql-core/columns/bigint.d.ts +0 -25
  1002. package/mssql-core/columns/bigint.js +0 -46
  1003. package/mssql-core/columns/bigint.js.map +0 -1
  1004. package/mssql-core/columns/binary.cjs +0 -57
  1005. package/mssql-core/columns/binary.cjs.map +0 -1
  1006. package/mssql-core/columns/binary.d.cts +0 -24
  1007. package/mssql-core/columns/binary.d.ts +0 -24
  1008. package/mssql-core/columns/binary.js +0 -31
  1009. package/mssql-core/columns/binary.js.map +0 -1
  1010. package/mssql-core/columns/bit.cjs +0 -54
  1011. package/mssql-core/columns/bit.cjs.map +0 -1
  1012. package/mssql-core/columns/bit.d.cts +0 -17
  1013. package/mssql-core/columns/bit.d.ts +0 -17
  1014. package/mssql-core/columns/bit.js +0 -28
  1015. package/mssql-core/columns/bit.js.map +0 -1
  1016. package/mssql-core/columns/char.cjs +0 -73
  1017. package/mssql-core/columns/char.cjs.map +0 -1
  1018. package/mssql-core/columns/char.d.cts +0 -29
  1019. package/mssql-core/columns/char.d.ts +0 -29
  1020. package/mssql-core/columns/char.js +0 -46
  1021. package/mssql-core/columns/char.js.map +0 -1
  1022. package/mssql-core/columns/common.cjs +0 -112
  1023. package/mssql-core/columns/common.cjs.map +0 -1
  1024. package/mssql-core/columns/common.d.cts +0 -57
  1025. package/mssql-core/columns/common.d.ts +0 -57
  1026. package/mssql-core/columns/common.js +0 -85
  1027. package/mssql-core/columns/common.js.map +0 -1
  1028. package/mssql-core/columns/custom.cjs +0 -105
  1029. package/mssql-core/columns/custom.cjs.map +0 -1
  1030. package/mssql-core/columns/custom.d.cts +0 -261
  1031. package/mssql-core/columns/custom.d.ts +0 -261
  1032. package/mssql-core/columns/custom.js +0 -79
  1033. package/mssql-core/columns/custom.js.map +0 -1
  1034. package/mssql-core/columns/date.cjs +0 -94
  1035. package/mssql-core/columns/date.cjs.map +0 -1
  1036. package/mssql-core/columns/date.common.cjs +0 -37
  1037. package/mssql-core/columns/date.common.cjs.map +0 -1
  1038. package/mssql-core/columns/date.common.d.cts +0 -12
  1039. package/mssql-core/columns/date.common.d.ts +0 -12
  1040. package/mssql-core/columns/date.common.js +0 -13
  1041. package/mssql-core/columns/date.common.js.map +0 -1
  1042. package/mssql-core/columns/date.d.cts +0 -39
  1043. package/mssql-core/columns/date.d.ts +0 -39
  1044. package/mssql-core/columns/date.js +0 -66
  1045. package/mssql-core/columns/date.js.map +0 -1
  1046. package/mssql-core/columns/datetime.cjs +0 -94
  1047. package/mssql-core/columns/datetime.cjs.map +0 -1
  1048. package/mssql-core/columns/datetime.d.cts +0 -38
  1049. package/mssql-core/columns/datetime.d.ts +0 -38
  1050. package/mssql-core/columns/datetime.js +0 -66
  1051. package/mssql-core/columns/datetime.js.map +0 -1
  1052. package/mssql-core/columns/datetime2.cjs +0 -102
  1053. package/mssql-core/columns/datetime2.cjs.map +0 -1
  1054. package/mssql-core/columns/datetime2.d.cts +0 -38
  1055. package/mssql-core/columns/datetime2.d.ts +0 -38
  1056. package/mssql-core/columns/datetime2.js +0 -74
  1057. package/mssql-core/columns/datetime2.js.map +0 -1
  1058. package/mssql-core/columns/datetimeoffset.cjs +0 -102
  1059. package/mssql-core/columns/datetimeoffset.cjs.map +0 -1
  1060. package/mssql-core/columns/datetimeoffset.d.cts +0 -39
  1061. package/mssql-core/columns/datetimeoffset.d.ts +0 -39
  1062. package/mssql-core/columns/datetimeoffset.js +0 -74
  1063. package/mssql-core/columns/datetimeoffset.js.map +0 -1
  1064. package/mssql-core/columns/decimal.cjs +0 -146
  1065. package/mssql-core/columns/decimal.cjs.map +0 -1
  1066. package/mssql-core/columns/decimal.d.cts +0 -58
  1067. package/mssql-core/columns/decimal.d.ts +0 -58
  1068. package/mssql-core/columns/decimal.js +0 -116
  1069. package/mssql-core/columns/decimal.js.map +0 -1
  1070. package/mssql-core/columns/float.cjs +0 -58
  1071. package/mssql-core/columns/float.cjs.map +0 -1
  1072. package/mssql-core/columns/float.d.cts +0 -21
  1073. package/mssql-core/columns/float.d.ts +0 -21
  1074. package/mssql-core/columns/float.js +0 -32
  1075. package/mssql-core/columns/float.js.map +0 -1
  1076. package/mssql-core/columns/index.cjs +0 -63
  1077. package/mssql-core/columns/index.cjs.map +0 -1
  1078. package/mssql-core/columns/index.d.cts +0 -21
  1079. package/mssql-core/columns/index.d.ts +0 -21
  1080. package/mssql-core/columns/index.js +0 -22
  1081. package/mssql-core/columns/index.js.map +0 -1
  1082. package/mssql-core/columns/int.cjs +0 -53
  1083. package/mssql-core/columns/int.cjs.map +0 -1
  1084. package/mssql-core/columns/int.d.cts +0 -16
  1085. package/mssql-core/columns/int.d.ts +0 -16
  1086. package/mssql-core/columns/int.js +0 -27
  1087. package/mssql-core/columns/int.js.map +0 -1
  1088. package/mssql-core/columns/numeric.cjs +0 -146
  1089. package/mssql-core/columns/numeric.cjs.map +0 -1
  1090. package/mssql-core/columns/numeric.d.cts +0 -58
  1091. package/mssql-core/columns/numeric.d.ts +0 -58
  1092. package/mssql-core/columns/numeric.js +0 -116
  1093. package/mssql-core/columns/numeric.js.map +0 -1
  1094. package/mssql-core/columns/real.cjs +0 -53
  1095. package/mssql-core/columns/real.cjs.map +0 -1
  1096. package/mssql-core/columns/real.d.cts +0 -16
  1097. package/mssql-core/columns/real.d.ts +0 -16
  1098. package/mssql-core/columns/real.js +0 -27
  1099. package/mssql-core/columns/real.js.map +0 -1
  1100. package/mssql-core/columns/smallint.cjs +0 -62
  1101. package/mssql-core/columns/smallint.cjs.map +0 -1
  1102. package/mssql-core/columns/smallint.d.cts +0 -17
  1103. package/mssql-core/columns/smallint.d.ts +0 -17
  1104. package/mssql-core/columns/smallint.js +0 -36
  1105. package/mssql-core/columns/smallint.js.map +0 -1
  1106. package/mssql-core/columns/text.cjs +0 -68
  1107. package/mssql-core/columns/text.cjs.map +0 -1
  1108. package/mssql-core/columns/text.d.cts +0 -36
  1109. package/mssql-core/columns/text.d.ts +0 -36
  1110. package/mssql-core/columns/text.js +0 -41
  1111. package/mssql-core/columns/text.js.map +0 -1
  1112. package/mssql-core/columns/time.cjs +0 -90
  1113. package/mssql-core/columns/time.cjs.map +0 -1
  1114. package/mssql-core/columns/time.d.cts +0 -37
  1115. package/mssql-core/columns/time.d.ts +0 -37
  1116. package/mssql-core/columns/time.js +0 -62
  1117. package/mssql-core/columns/time.js.map +0 -1
  1118. package/mssql-core/columns/tinyint.cjs +0 -62
  1119. package/mssql-core/columns/tinyint.cjs.map +0 -1
  1120. package/mssql-core/columns/tinyint.d.cts +0 -17
  1121. package/mssql-core/columns/tinyint.d.ts +0 -17
  1122. package/mssql-core/columns/tinyint.js +0 -36
  1123. package/mssql-core/columns/tinyint.js.map +0 -1
  1124. package/mssql-core/columns/varbinary.cjs +0 -61
  1125. package/mssql-core/columns/varbinary.cjs.map +0 -1
  1126. package/mssql-core/columns/varbinary.d.cts +0 -23
  1127. package/mssql-core/columns/varbinary.d.ts +0 -23
  1128. package/mssql-core/columns/varbinary.js +0 -35
  1129. package/mssql-core/columns/varbinary.js.map +0 -1
  1130. package/mssql-core/columns/varchar.cjs +0 -117
  1131. package/mssql-core/columns/varchar.cjs.map +0 -1
  1132. package/mssql-core/columns/varchar.d.cts +0 -59
  1133. package/mssql-core/columns/varchar.d.ts +0 -59
  1134. package/mssql-core/columns/varchar.js +0 -88
  1135. package/mssql-core/columns/varchar.js.map +0 -1
  1136. package/mssql-core/db.cjs +0 -254
  1137. package/mssql-core/db.cjs.map +0 -1
  1138. package/mssql-core/db.d.cts +0 -228
  1139. package/mssql-core/db.d.ts +0 -228
  1140. package/mssql-core/db.js +0 -235
  1141. package/mssql-core/db.js.map +0 -1
  1142. package/mssql-core/dialect.cjs +0 -633
  1143. package/mssql-core/dialect.cjs.map +0 -1
  1144. package/mssql-core/dialect.d.cts +0 -58
  1145. package/mssql-core/dialect.d.ts +0 -58
  1146. package/mssql-core/dialect.js +0 -599
  1147. package/mssql-core/dialect.js.map +0 -1
  1148. package/mssql-core/expressions.cjs +0 -49
  1149. package/mssql-core/expressions.cjs.map +0 -1
  1150. package/mssql-core/expressions.d.cts +0 -8
  1151. package/mssql-core/expressions.d.ts +0 -8
  1152. package/mssql-core/expressions.js +0 -22
  1153. package/mssql-core/expressions.js.map +0 -1
  1154. package/mssql-core/foreign-keys.cjs +0 -91
  1155. package/mssql-core/foreign-keys.cjs.map +0 -1
  1156. package/mssql-core/foreign-keys.d.cts +0 -51
  1157. package/mssql-core/foreign-keys.d.ts +0 -51
  1158. package/mssql-core/foreign-keys.js +0 -65
  1159. package/mssql-core/foreign-keys.js.map +0 -1
  1160. package/mssql-core/index.cjs +0 -55
  1161. package/mssql-core/index.cjs.map +0 -1
  1162. package/mssql-core/index.d.cts +0 -17
  1163. package/mssql-core/index.d.ts +0 -17
  1164. package/mssql-core/index.js +0 -18
  1165. package/mssql-core/index.js.map +0 -1
  1166. package/mssql-core/indexes.cjs +0 -80
  1167. package/mssql-core/indexes.cjs.map +0 -1
  1168. package/mssql-core/indexes.d.cts +0 -49
  1169. package/mssql-core/indexes.d.ts +0 -49
  1170. package/mssql-core/indexes.js +0 -52
  1171. package/mssql-core/indexes.js.map +0 -1
  1172. package/mssql-core/primary-keys.cjs +0 -64
  1173. package/mssql-core/primary-keys.cjs.map +0 -1
  1174. package/mssql-core/primary-keys.d.cts +0 -23
  1175. package/mssql-core/primary-keys.d.ts +0 -23
  1176. package/mssql-core/primary-keys.js +0 -38
  1177. package/mssql-core/primary-keys.js.map +0 -1
  1178. package/mssql-core/query-builders/delete.cjs +0 -107
  1179. package/mssql-core/query-builders/delete.cjs.map +0 -1
  1180. package/mssql-core/query-builders/delete.d.cts +0 -98
  1181. package/mssql-core/query-builders/delete.d.ts +0 -98
  1182. package/mssql-core/query-builders/delete.js +0 -83
  1183. package/mssql-core/query-builders/delete.js.map +0 -1
  1184. package/mssql-core/query-builders/index.cjs +0 -33
  1185. package/mssql-core/query-builders/index.cjs.map +0 -1
  1186. package/mssql-core/query-builders/index.d.cts +0 -6
  1187. package/mssql-core/query-builders/index.d.ts +0 -6
  1188. package/mssql-core/query-builders/index.js +0 -7
  1189. package/mssql-core/query-builders/index.js.map +0 -1
  1190. package/mssql-core/query-builders/insert.cjs +0 -105
  1191. package/mssql-core/query-builders/insert.cjs.map +0 -1
  1192. package/mssql-core/query-builders/insert.d.cts +0 -79
  1193. package/mssql-core/query-builders/insert.d.ts +0 -79
  1194. package/mssql-core/query-builders/insert.js +0 -80
  1195. package/mssql-core/query-builders/insert.js.map +0 -1
  1196. package/mssql-core/query-builders/query-builder.cjs +0 -95
  1197. package/mssql-core/query-builders/query-builder.cjs.map +0 -1
  1198. package/mssql-core/query-builders/query-builder.d.cts +0 -32
  1199. package/mssql-core/query-builders/query-builder.d.ts +0 -32
  1200. package/mssql-core/query-builders/query-builder.js +0 -71
  1201. package/mssql-core/query-builders/query-builder.js.map +0 -1
  1202. package/mssql-core/query-builders/query.cjs +0 -126
  1203. package/mssql-core/query-builders/query.cjs.map +0 -1
  1204. package/mssql-core/query-builders/query.d.cts +0 -42
  1205. package/mssql-core/query-builders/query.d.ts +0 -42
  1206. package/mssql-core/query-builders/query.js +0 -103
  1207. package/mssql-core/query-builders/query.js.map +0 -1
  1208. package/mssql-core/query-builders/select.cjs +0 -679
  1209. package/mssql-core/query-builders/select.cjs.map +0 -1
  1210. package/mssql-core/query-builders/select.d.cts +0 -549
  1211. package/mssql-core/query-builders/select.d.ts +0 -549
  1212. package/mssql-core/query-builders/select.js +0 -649
  1213. package/mssql-core/query-builders/select.js.map +0 -1
  1214. package/mssql-core/query-builders/select.types.cjs +0 -17
  1215. package/mssql-core/query-builders/select.types.cjs.map +0 -1
  1216. package/mssql-core/query-builders/select.types.d.cts +0 -142
  1217. package/mssql-core/query-builders/select.types.d.ts +0 -142
  1218. package/mssql-core/query-builders/select.types.js +0 -1
  1219. package/mssql-core/query-builders/select.types.js.map +0 -1
  1220. package/mssql-core/query-builders/update.cjs +0 -138
  1221. package/mssql-core/query-builders/update.cjs.map +0 -1
  1222. package/mssql-core/query-builders/update.d.cts +0 -142
  1223. package/mssql-core/query-builders/update.d.ts +0 -142
  1224. package/mssql-core/query-builders/update.js +0 -113
  1225. package/mssql-core/query-builders/update.js.map +0 -1
  1226. package/mssql-core/schema.cjs +0 -51
  1227. package/mssql-core/schema.cjs.map +0 -1
  1228. package/mssql-core/schema.d.cts +0 -22
  1229. package/mssql-core/schema.d.ts +0 -22
  1230. package/mssql-core/schema.js +0 -25
  1231. package/mssql-core/schema.js.map +0 -1
  1232. package/mssql-core/session.cjs +0 -74
  1233. package/mssql-core/session.cjs.map +0 -1
  1234. package/mssql-core/session.d.cts +0 -63
  1235. package/mssql-core/session.d.ts +0 -63
  1236. package/mssql-core/session.js +0 -48
  1237. package/mssql-core/session.js.map +0 -1
  1238. package/mssql-core/subquery.cjs +0 -17
  1239. package/mssql-core/subquery.cjs.map +0 -1
  1240. package/mssql-core/subquery.d.cts +0 -18
  1241. package/mssql-core/subquery.d.ts +0 -18
  1242. package/mssql-core/subquery.js +0 -1
  1243. package/mssql-core/subquery.js.map +0 -1
  1244. package/mssql-core/table.cjs +0 -81
  1245. package/mssql-core/table.cjs.map +0 -1
  1246. package/mssql-core/table.d.cts +0 -40
  1247. package/mssql-core/table.d.ts +0 -40
  1248. package/mssql-core/table.js +0 -55
  1249. package/mssql-core/table.js.map +0 -1
  1250. package/mssql-core/unique-constraint.cjs +0 -76
  1251. package/mssql-core/unique-constraint.cjs.map +0 -1
  1252. package/mssql-core/unique-constraint.d.cts +0 -23
  1253. package/mssql-core/unique-constraint.d.ts +0 -23
  1254. package/mssql-core/unique-constraint.js +0 -49
  1255. package/mssql-core/unique-constraint.js.map +0 -1
  1256. package/mssql-core/utils.cjs +0 -85
  1257. package/mssql-core/utils.cjs.map +0 -1
  1258. package/mssql-core/utils.d.cts +0 -31
  1259. package/mssql-core/utils.d.ts +0 -31
  1260. package/mssql-core/utils.js +0 -60
  1261. package/mssql-core/utils.js.map +0 -1
  1262. package/mssql-core/view-base.cjs +0 -33
  1263. package/mssql-core/view-base.cjs.map +0 -1
  1264. package/mssql-core/view-base.d.cts +0 -9
  1265. package/mssql-core/view-base.d.ts +0 -9
  1266. package/mssql-core/view-base.js +0 -9
  1267. package/mssql-core/view-base.js.map +0 -1
  1268. package/mssql-core/view-common.cjs +0 -29
  1269. package/mssql-core/view-common.cjs.map +0 -1
  1270. package/mssql-core/view-common.d.cts +0 -1
  1271. package/mssql-core/view-common.d.ts +0 -1
  1272. package/mssql-core/view-common.js +0 -5
  1273. package/mssql-core/view-common.js.map +0 -1
  1274. package/mssql-core/view.cjs +0 -154
  1275. package/mssql-core/view.cjs.map +0 -1
  1276. package/mssql-core/view.d.cts +0 -63
  1277. package/mssql-core/view.d.ts +0 -63
  1278. package/mssql-core/view.js +0 -125
  1279. package/mssql-core/view.js.map +0 -1
  1280. package/node-mssql/driver.cjs +0 -117
  1281. package/node-mssql/driver.cjs.map +0 -1
  1282. package/node-mssql/driver.d.cts +0 -46
  1283. package/node-mssql/driver.d.ts +0 -46
  1284. package/node-mssql/driver.js +0 -81
  1285. package/node-mssql/driver.js.map +0 -1
  1286. package/node-mssql/index.cjs +0 -25
  1287. package/node-mssql/index.cjs.map +0 -1
  1288. package/node-mssql/index.d.cts +0 -2
  1289. package/node-mssql/index.d.ts +0 -2
  1290. package/node-mssql/index.js +0 -3
  1291. package/node-mssql/index.js.map +0 -1
  1292. package/node-mssql/migrator.cjs +0 -33
  1293. package/node-mssql/migrator.cjs.map +0 -1
  1294. package/node-mssql/migrator.d.cts +0 -3
  1295. package/node-mssql/migrator.d.ts +0 -3
  1296. package/node-mssql/migrator.js +0 -9
  1297. package/node-mssql/migrator.js.map +0 -1
  1298. package/node-mssql/pool.cjs +0 -54
  1299. package/node-mssql/pool.cjs.map +0 -1
  1300. package/node-mssql/pool.d.cts +0 -8
  1301. package/node-mssql/pool.d.ts +0 -8
  1302. package/node-mssql/pool.js +0 -20
  1303. package/node-mssql/pool.js.map +0 -1
  1304. package/node-mssql/session.cjs +0 -256
  1305. package/node-mssql/session.cjs.map +0 -1
  1306. package/node-mssql/session.d.cts +0 -48
  1307. package/node-mssql/session.d.ts +0 -48
  1308. package/node-mssql/session.js +0 -224
  1309. package/node-mssql/session.js.map +0 -1
package/relations.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/relations.ts"],"sourcesContent":["import { IsAlias, OriginalName, Table, TableColumns, TableSchema } from '~/table.ts';\nimport { aliasedTable } from './alias.ts';\nimport type { CasingCache } from './casing.ts';\nimport { type AnyColumn, Column } from './column.ts';\nimport { entityKind, is } from './entity.ts';\nimport { DrizzleError } from './errors.ts';\nimport {\n\tand,\n\tarrayContained,\n\tarrayContains,\n\tarrayOverlaps,\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 { Placeholder, SQL, sql, type SQLWrapper, View } from './sql/sql.ts';\nimport type { Assume, DrizzleTypeError, Equal, Simplify, ValueOrArray } from './utils.ts';\n\nexport type FilteredSchemaEntry = Table<any> | View<string, boolean, FieldSelection>;\n\nexport type SchemaEntry = Table<any> | View<string, boolean, any>;\n\nexport type Schema = Record<string, SchemaEntry>;\n\nexport type GetTableViewColumns<T extends SchemaEntry> = T extends View<string, boolean, any> ? T['_']['selectedFields']\n\t: T extends Table<any> ? T['_']['columns']\n\t: never;\n\nexport type GetTableViewFieldSelection<T extends SchemaEntry> = T extends View<string, boolean, FieldSelection>\n\t? T['_']['selectedFields']\n\t: T extends Table<any> ? T['_']['columns']\n\t: never;\n\nexport type FieldValue =\n\t| Column<any>\n\t| SQLWrapper\n\t| SQL.Aliased\n\t| SQL;\n\nexport type FieldSelection = Record<string, FieldValue>;\n\nexport function processRelations(tablesConfig: TablesRelationalConfig, tables: Schema) {\n\tfor (const tableConfig of Object.values(tablesConfig)) {\n\t\tfor (const [relationFieldName, relation] of Object.entries(tableConfig.relations)) {\n\t\t\tif (!is(relation, Relation)) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\trelation.sourceTable = tableConfig.table;\n\t\t\trelation.fieldName = relationFieldName;\n\t\t}\n\t}\n\n\tfor (const [sourceTableName, tableConfig] of Object.entries(tablesConfig)) {\n\t\tfor (const [relationFieldName, relation] of Object.entries(tableConfig.relations)) {\n\t\t\tif (!is(relation, Relation)) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tlet reverseRelation: Relation | undefined;\n\t\t\tconst {\n\t\t\t\ttargetTableName,\n\t\t\t\talias,\n\t\t\t\tsourceColumns,\n\t\t\t\ttargetColumns,\n\t\t\t\tthroughTable,\n\t\t\t\tsourceTable,\n\t\t\t\tthrough,\n\t\t\t\ttargetTable,\n\t\t\t\twhere,\n\t\t\t\tsourceColumnTableNames,\n\t\t\t\ttargetColumnTableNames,\n\t\t\t} = relation;\n\t\t\tconst relationPrintName = `relations -> ${tableConfig.name}: { ${relationFieldName}: r.${\n\t\t\t\tis(relation, One) ? 'one' : 'many'\n\t\t\t}.${targetTableName}(...) }`;\n\n\t\t\tif (typeof alias === 'string' && !alias) {\n\t\t\t\tthrow new Error(`${relationPrintName}: \"alias\" cannot be an empty string - omit it if you don't need it`);\n\t\t\t}\n\n\t\t\tif (sourceColumns?.length === 0) {\n\t\t\t\tthrow new Error(`${relationPrintName}: \"from\" cannot be empty`);\n\t\t\t}\n\n\t\t\tif (targetColumns?.length === 0) {\n\t\t\t\tthrow new Error(`${relationPrintName}: \"to\" cannot be empty`);\n\t\t\t}\n\n\t\t\tif (sourceColumns && targetColumns) {\n\t\t\t\tif (sourceColumns.length !== targetColumns.length && !throughTable) {\n\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t`${relationPrintName}: \"from\" and \"to\" fields without \"through\" must have the same length`,\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\tfor (const sName of sourceColumnTableNames) {\n\t\t\t\t\tif (sName !== sourceTableName) {\n\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t`${relationPrintName}: all \"from\" columns must belong to table \"${sourceTableName}\", found column of table \"${sName}\"`,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tfor (const tName of targetColumnTableNames) {\n\t\t\t\t\tif (tName !== targetTableName) {\n\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t`${relationPrintName}: all \"to\" columns must belong to table \"${targetTable}\", found column of table \"${tName}\"`,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (through) {\n\t\t\t\t\tif (\n\t\t\t\t\t\tthrough.source.length !== sourceColumns.length\n\t\t\t\t\t\t|| through.target.length !== targetColumns.length\n\t\t\t\t\t) {\n\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t`${relationPrintName}: \".through(column)\" must be used either on all columns in \"from\" and \"to\" or not defined on any of them`,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\tfor (const column of through.source) {\n\t\t\t\t\t\tif (tables[column._.tableName] !== throughTable) {\n\t\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t\t`${relationPrintName}: \".through(column)\" must be used on the same table by all columns of the relation`,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tfor (const column of through.target) {\n\t\t\t\t\t\tif (tables[column._.tableName] !== throughTable) {\n\t\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t\t`${relationPrintName}: \".through(column)\" must be used on the same table by all columns of the relation`,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (sourceColumns || targetColumns) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`${relationPrintName}: relation must have either both \"from\" and \"to\" defined, or none of them`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tconst reverseTableConfig = tablesConfig[targetTableName];\n\t\t\tif (!reverseTableConfig) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`${relationPrintName}: not enough data provided to build the relation - \"from\"/\"to\" are not defined, and no reverse relations of table \"${targetTableName}\" were found\"`,\n\t\t\t\t);\n\t\t\t}\n\t\t\tif (alias) {\n\t\t\t\tconst reverseRelations = Object.values(reverseTableConfig.relations).filter((it): it is Relation =>\n\t\t\t\t\tis(it, Relation) && it.alias === alias && it !== relation\n\t\t\t\t);\n\t\t\t\tif (reverseRelations.length > 1) {\n\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t`${relationPrintName}: not enough data provided to build the relation - \"from\"/\"to\" are not defined, and multiple relations with alias \"${alias}\" found in table \"${targetTableName}\": ${\n\t\t\t\t\t\t\treverseRelations.map((it) => `\"${it.fieldName}\"`).join(', ')\n\t\t\t\t\t\t}`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\treverseRelation = reverseRelations[0];\n\t\t\t\tif (!reverseRelation) {\n\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t`${relationPrintName}: not enough data provided to build the relation - \"from\"/\"to\" are not defined, and there is no reverse relation of table \"${targetTableName}\" with alias \"${alias}\"`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tconst reverseRelations = Object.values(reverseTableConfig.relations).filter((it): it is Relation =>\n\t\t\t\t\tis(it, Relation) && it.targetTable === sourceTable && !it.alias && it !== relation\n\t\t\t\t);\n\t\t\t\tif (reverseRelations.length > 1) {\n\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t`${relationPrintName}: not enough data provided to build the relation - \"from\"/\"to\" are not defined, and multiple relations between \"${targetTableName}\" and \"${sourceTableName}\" were found.\\nHint: you can specify \"alias\" on both sides of the relation with the same value`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\treverseRelation = reverseRelations[0];\n\t\t\t\tif (!reverseRelation) {\n\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t`${relationPrintName}: not enough data provided to build the relation - \"from\"/\"to\" are not defined, and no reverse relation of table \"${targetTableName}\" with target table \"${sourceTableName}\" was found`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (!reverseRelation.sourceColumns || !reverseRelation.targetColumns) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`${relationPrintName}: not enough data provided to build the relation - \"from\"/\"to\" are not defined, and reverse relation \"${targetTableName}.${reverseRelation.fieldName}\" does not have \"from\"/\"to\" defined`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\trelation.sourceColumns = reverseRelation.targetColumns;\n\t\t\trelation.targetColumns = reverseRelation.sourceColumns;\n\t\t\trelation.through = reverseRelation.through\n\t\t\t\t? {\n\t\t\t\t\tsource: reverseRelation.through.target,\n\t\t\t\t\ttarget: reverseRelation.through.source,\n\t\t\t\t}\n\t\t\t\t: undefined;\n\t\t\trelation.throughTable = reverseRelation.throughTable;\n\t\t\trelation.isReversed = !where;\n\t\t\trelation.where = where ?? reverseRelation.where;\n\t\t}\n\t}\n\n\treturn tablesConfig;\n}\n\n/** Builds relational config for every table in schema */\nexport function buildRelations<TTables extends Schema, TConfig extends AnyRelationsBuilderConfig>(\n\ttables: TTables,\n\tconfig: TConfig,\n): ExtractTablesWithRelations<TConfig, TTables> {\n\tconst tablesConfig = {} as TablesRelationalConfig;\n\n\tfor (const [tsName, table] of Object.entries(tables)) {\n\t\ttablesConfig[tsName] = {\n\t\t\ttable,\n\t\t\tname: tsName,\n\t\t\trelations: config[tsName] ?? {},\n\t\t};\n\t}\n\n\treturn processRelations(tablesConfig, tables) as any;\n}\n\n/** Builds relational config only for tables present in relational config */\nexport function buildRelationsParts<TTables extends Schema, TConfig extends AnyRelationsBuilderConfig>(\n\ttables: TTables,\n\tconfig: TConfig,\n): ExtractTablesWithRelationsParts<TConfig, TTables> {\n\tconst tablesConfig = {} as TablesRelationalConfig;\n\n\tfor (const [tsName, relations] of Object.entries(config)) {\n\t\tif (!relations || !tables[tsName]) continue;\n\t\ttablesConfig[tsName] = {\n\t\t\ttable: tables[tsName],\n\t\t\tname: tsName,\n\t\t\trelations,\n\t\t};\n\t}\n\n\treturn processRelations(tablesConfig, tables) as any;\n}\n\nexport type RelationsRecord = Record<string, AnyRelation>;\nexport type EmptyRelations = {};\nexport type AnyRelations = TablesRelationalConfig;\n\nexport abstract class Relation<\n\tTTargetTableName extends string = string,\n> {\n\tstatic readonly [entityKind]: string = 'RelationV2';\n\tdeclare readonly $brand: 'RelationV2';\n\tdeclare public readonly relationType: 'many' | 'one';\n\n\tfieldName!: string;\n\tsourceColumns!: Column<any>[];\n\ttargetColumns!: Column<any>[];\n\talias: string | undefined;\n\twhere: AnyTableFilter | undefined;\n\tsourceTable!: SchemaEntry;\n\ttargetTable: SchemaEntry;\n\tthrough?: {\n\t\tsource: RelationsBuilderColumnBase[];\n\t\ttarget: RelationsBuilderColumnBase[];\n\t};\n\tthroughTable?: SchemaEntry;\n\tisReversed?: boolean;\n\n\t/** @internal */\n\tsourceColumnTableNames: string[] = [];\n\t/** @internal */\n\ttargetColumnTableNames: string[] = [];\n\n\tconstructor(\n\t\ttargetTable: SchemaEntry,\n\t\treadonly targetTableName: TTargetTableName,\n\t) {\n\t\tthis.targetTable = targetTable;\n\t}\n}\n\nexport type AnyRelation = Relation<string>;\n\nexport class One<\n\tTTargetTableName extends string,\n\tTOptional extends boolean = boolean,\n> extends Relation<TTargetTableName> {\n\tstatic override readonly [entityKind]: string = 'OneV2';\n\tdeclare protected $relationBrand: 'OneV2';\n\n\tpublic override readonly relationType = 'one' as const;\n\n\treadonly optional: TOptional;\n\n\tconstructor(\n\t\ttables: Schema,\n\t\ttargetTable: SchemaEntry,\n\t\ttargetTableName: TTargetTableName,\n\t\tconfig: AnyOneConfig | undefined,\n\t) {\n\t\tsuper(targetTable, targetTableName);\n\t\tthis.alias = config?.alias;\n\t\tthis.where = config?.where;\n\t\tif (config?.from) {\n\t\t\tthis.sourceColumns = ((Array.isArray(config.from)\n\t\t\t\t? config.from\n\t\t\t\t: [config.from]) as RelationsBuilderColumnBase[]).map((it: RelationsBuilderColumnBase) => {\n\t\t\t\t\tthis.throughTable ??= it._.through ? tables[it._.through._.tableName]! as SchemaEntry : undefined;\n\t\t\t\t\tthis.sourceColumnTableNames.push(it._.tableName);\n\t\t\t\t\treturn it._.column as Column;\n\t\t\t\t});\n\t\t}\n\t\tif (config?.to) {\n\t\t\tthis.targetColumns = (Array.isArray(config.to)\n\t\t\t\t? config.to\n\t\t\t\t: [config.to]).map((it: RelationsBuilderColumnBase) => {\n\t\t\t\t\tthis.throughTable ??= it._.through ? tables[it._.through._.tableName]! as SchemaEntry : undefined;\n\t\t\t\t\tthis.targetColumnTableNames.push(it._.tableName);\n\t\t\t\t\treturn it._.column as Column;\n\t\t\t\t});\n\t\t}\n\n\t\tif (this.throughTable) {\n\t\t\tthis.through = {\n\t\t\t\tsource: (Array.isArray(config?.from) ? config.from : config?.from ? [config.from] : []).map((\n\t\t\t\t\tc,\n\t\t\t\t) => c._.through!),\n\t\t\t\ttarget: (Array.isArray(config?.to) ? config.to : config?.to ? [config.to] : []).map((c) => c._.through!),\n\t\t\t};\n\t\t}\n\t\tthis.optional = (config?.optional ?? true) as TOptional;\n\t}\n}\n\nexport type AnyOne = One<string, boolean>;\n\nexport class Many<TTargetTableName extends string> extends Relation<TTargetTableName> {\n\tstatic override readonly [entityKind]: string = 'ManyV2';\n\tdeclare protected $relationBrand: 'ManyV2';\n\n\tpublic override readonly relationType = 'many' as const;\n\n\tconstructor(\n\t\ttables: Schema,\n\t\ttargetTable: SchemaEntry,\n\t\ttargetTableName: TTargetTableName,\n\t\treadonly config: AnyManyConfig | undefined,\n\t) {\n\t\tsuper(targetTable, targetTableName);\n\t\tthis.alias = config?.alias;\n\t\tthis.where = config?.where;\n\t\tif (config?.from) {\n\t\t\tthis.sourceColumns = ((Array.isArray(config.from)\n\t\t\t\t? config.from\n\t\t\t\t: [config.from]) as RelationsBuilderColumnBase[]).map((it: RelationsBuilderColumnBase) => {\n\t\t\t\t\tthis.throughTable ??= it._.through ? tables[it._.through._.tableName]! as SchemaEntry : undefined;\n\t\t\t\t\tthis.sourceColumnTableNames.push(it._.tableName);\n\t\t\t\t\treturn it._.column as Column;\n\t\t\t\t});\n\t\t}\n\t\tif (config?.to) {\n\t\t\tthis.targetColumns = (Array.isArray(config.to)\n\t\t\t\t? config.to\n\t\t\t\t: [config.to]).map((it: RelationsBuilderColumnBase) => {\n\t\t\t\t\tthis.throughTable ??= it._.through ? tables[it._.through._.tableName]! as SchemaEntry : undefined;\n\t\t\t\t\tthis.targetColumnTableNames.push(it._.tableName);\n\t\t\t\t\treturn it._.column as Column;\n\t\t\t\t});\n\t\t}\n\t\tif (this.throughTable) {\n\t\t\tthis.through = {\n\t\t\t\tsource: (Array.isArray(config?.from) ? config.from : config?.from ? [config.from] : []).map((\n\t\t\t\t\tc,\n\t\t\t\t) => c._.through!),\n\t\t\t\ttarget: (Array.isArray(config?.to) ? config.to : config?.to ? [config.to] : []).map((c) => c._.through!),\n\t\t\t};\n\t\t}\n\t}\n}\n\nexport type AnyMany = Many<string>;\n\nexport abstract class AggregatedField<T = unknown> implements SQLWrapper<T> {\n\tstatic readonly [entityKind]: string = 'AggregatedField';\n\n\tdeclare readonly $brand: 'AggregatedField';\n\n\tdeclare readonly _: {\n\t\treadonly data: T;\n\t};\n\n\tprotected table: SchemaEntry | undefined;\n\n\tonTable(table: SchemaEntry) {\n\t\tthis.table = table;\n\n\t\treturn this;\n\t}\n\n\tabstract getSQL(): SQL<T>;\n}\n\nexport class Count extends AggregatedField<number> {\n\tstatic override readonly [entityKind]: string = 'AggregatedFieldCount';\n\n\tdeclare protected $aggregatedFieldBrand: 'Count';\n\n\tprivate query: SQL<number> | undefined;\n\n\tgetSQL(): SQL<number> {\n\t\tif (!this.query) {\n\t\t\tif (!this.table) throw new Error('Table must be set before building aggregate field');\n\t\t\tthis.query = sql`select count(*) as ${sql.identifier('r')} from ${getTableAsAliasSQL(this.table)}`\n\t\t\t\t.mapWith(Number);\n\t\t}\n\n\t\treturn this.query;\n\t}\n}\n\nexport type ExtractObjectValues<T> = T[keyof T];\n\nexport const operators = {\n\tand,\n\tbetween,\n\teq,\n\texists,\n\tgt,\n\tgte,\n\tilike,\n\tinArray,\n\tarrayContains,\n\tarrayContained,\n\tarrayOverlaps,\n\tisNull,\n\tisNotNull,\n\tlike,\n\tlt,\n\tlte,\n\tne,\n\tnot,\n\tnotBetween,\n\tnotExists,\n\tnotLike,\n\tnotIlike,\n\tnotInArray,\n\tor,\n\tsql,\n};\n\nexport type Operators = typeof operators;\n\nexport const orderByOperators = {\n\tsql,\n\tasc,\n\tdesc,\n};\n\nexport type OrderByOperators = typeof orderByOperators;\n\nexport function getOrderByOperators(): OrderByOperators {\n\treturn orderByOperators;\n}\n\nexport type FindTargetTableInRelationalConfig<\n\tTConfig extends TablesRelationalConfig,\n\tTRelation extends AnyRelation,\n> = TConfig[TRelation['targetTableName']];\n\nexport interface SQLOperator {\n\tsql: Operators['sql'];\n}\n\nexport type DBQueryConfigColumns<TColumns extends FieldSelection> = {\n\t[K in keyof TColumns]?: boolean | undefined;\n};\n\nexport type DBQueryConfigExtras<TTable extends SchemaEntry> = Record<\n\tstring,\n\t| SQLWrapper\n\t| ((\n\t\ttable: TTable,\n\t\toperators: SQLOperator,\n\t) => SQLWrapper)\n>;\n\nexport type DBQueryConfigOrderByCallback<TTable extends SchemaEntry> = (\n\ttable: TTable,\n\toperators: OrderByOperators,\n) => ValueOrArray<AnyColumn | SQL>;\n\nexport type DBQueryConfigOrderByObject<TColumns extends FieldSelection> = {\n\t[K in keyof TColumns]?: 'asc' | 'desc' | undefined;\n};\n\nexport type DBQueryConfigOrderBy<TTable extends SchemaEntry, TColumns extends FieldSelection> =\n\t| DBQueryConfigOrderByCallback<TTable>\n\t| DBQueryConfigOrderByObject<TColumns>;\n\nexport type DBQueryConfigWith<TSchema extends TablesRelationalConfig, TRelations extends RelationsRecord> = {\n\t[K in keyof TRelations]?:\n\t\t| boolean\n\t\t| (DBQueryConfig<\n\t\t\tTRelations[K]['relationType'],\n\t\t\tTSchema,\n\t\t\tFindTargetTableInRelationalConfig<TSchema, TRelations[K]>\n\t\t>)\n\t\t| undefined;\n};\n\nexport type DBQueryConfig<\n\tTRelationType extends 'one' | 'many' = 'one' | 'many',\n\tTSchema extends TablesRelationalConfig = TablesRelationalConfig,\n\tTTableConfig extends TableRelationalConfig = TableRelationalConfig,\n> =\n\t& (TTableConfig['relations'] extends Record<string, never> ? {}\n\t\t: {\n\t\t\twith?:\n\t\t\t\t| DBQueryConfigWith<TSchema, TTableConfig['relations']>\n\t\t\t\t| undefined;\n\t\t})\n\t& {\n\t\tcolumns?: DBQueryConfigColumns<GetTableViewFieldSelection<TTableConfig['table']>> | undefined;\n\t\twhere?: RelationsFilter<TTableConfig, TSchema> | undefined;\n\t\textras?:\n\t\t\t| DBQueryConfigExtras<TTableConfig['table']>\n\t\t\t| undefined;\n\t\torderBy?:\n\t\t\t| DBQueryConfigOrderBy<TTableConfig['table'], GetTableViewFieldSelection<TTableConfig['table']>>\n\t\t\t| undefined;\n\t\toffset?: number | Placeholder | undefined;\n\t}\n\t& (TRelationType extends 'many' ? {\n\t\t\tlimit?: number | Placeholder | undefined;\n\t\t}\n\t\t: {});\n\nexport type AnyDBQueryConfig = {\n\tcolumns?:\n\t\t| DBQueryConfigColumns<GetTableViewFieldSelection<TableRelationalConfig['table']>>\n\t\t| undefined;\n\twhere?: RelationsFilter<TableRelationalConfig, TablesRelationalConfig> | undefined;\n\textras?:\n\t\t| DBQueryConfigExtras<TableRelationalConfig['table']>\n\t\t| undefined;\n\twith?:\n\t\t| Record<string, AnyDBQueryConfig>\n\t\t| undefined;\n\torderBy?:\n\t\t| DBQueryConfigOrderBy<TableRelationalConfig['table'], GetTableViewFieldSelection<TableRelationalConfig['table']>>\n\t\t| undefined;\n\toffset?: number | Placeholder | undefined;\n\tlimit?: number | Placeholder | undefined;\n};\n\nexport interface TableRelationalConfig {\n\ttable: SchemaEntry;\n\tname: string;\n\trelations: RelationsRecord;\n}\n\nexport type TablesRelationalConfig = Record<string, TableRelationalConfig>;\n\nexport type ExtractTablesWithRelations<\n\tTConfig extends AnyRelationsBuilderConfig,\n\tTTables extends Schema,\n> = {\n\t[K in keyof TTables]: {\n\t\ttable: TTables[K];\n\t\tname: K & string;\n\t\trelations: TConfig extends { [CK in K]: Record<string, any> } ? TConfig[K] : {};\n\t};\n};\n\nexport type ExtractTablesWithRelationsParts<\n\tTConfig extends AnyRelationsBuilderConfig,\n\tTTables extends Schema,\n> = {\n\t[K in NonUndefinedKeysOnly<TConfig> & keyof TTables]: {\n\t\ttable: TTables[K & string];\n\t\tname: K & string;\n\t\trelations: TConfig[K] extends Record<string, any> ? TConfig[K] : {};\n\t};\n};\n\nexport type ReturnTypeOrValue<T> = T extends (...args: any[]) => infer R ? R\n\t: T;\n\nexport type RelationResultKind<TResult, TInclude, TRelation extends AnyRelation> = TRelation extends AnyOne ? (\n\t\t| TResult\n\t\t| (Equal<TRelation['optional'], true> extends true ? null\n\t\t\t: TInclude extends Record<string, unknown> ? TInclude['where'] extends Record<string, any> ? null\n\t\t\t\t: never\n\t\t\t: never)\n\t)\n\t: TResult[];\n\nexport type BuildRelationResult<\n\tTConfig extends TablesRelationalConfig,\n\tTInclude,\n\tTRelations extends RelationsRecord,\n> = {\n\t[\n\t\tK in\n\t\t\t& TruthyKeysOnly<TInclude>\n\t\t\t& keyof TRelations\n\t]: TRelations[K] extends infer TRel extends AnyRelation ? RelationResultKind<\n\t\t\tBuildQueryResult<\n\t\t\t\tTConfig,\n\t\t\t\tFindTargetTableInRelationalConfig<TConfig, TRel>,\n\t\t\t\tAssume<TInclude[K], true | Record<string, unknown>>\n\t\t\t>,\n\t\t\tTInclude[K],\n\t\t\tTRel\n\t\t>\n\t\t: TRelations[K] extends AggregatedField<infer TData> ? TData\n\t\t: never;\n};\n\nexport type NonUndefinedKeysOnly<T> = {\n\t[K in keyof T]: T[K] extends undefined ? never : K;\n}[keyof T];\n\nexport type TruthyKeysOnly<T> = {\n\t[K in keyof T]: T[K] extends undefined | false ? never : K;\n}[keyof T];\n\nexport type InferRelationalQueryTableResult<\n\tTRawSelection extends Record<string, unknown>,\n\tTSelectedFields extends Record<string, unknown> | 'Full' = 'Full',\n> = TSelectedFields extends 'Full' ? TRawSelection : {\n\t[\n\t\tK in Equal<\n\t\t\tExclude<\n\t\t\t\tTSelectedFields[\n\t\t\t\t\t& keyof TSelectedFields\n\t\t\t\t\t& keyof TRawSelection\n\t\t\t\t],\n\t\t\t\tundefined\n\t\t\t>,\n\t\t\tfalse\n\t\t> extends true ? Exclude<\n\t\t\t\tkeyof TRawSelection,\n\t\t\t\tNonUndefinedKeysOnly<TSelectedFields>\n\t\t\t>\n\t\t\t:\n\t\t\t\t& {\n\t\t\t\t\t[K in keyof TSelectedFields]: Equal<\n\t\t\t\t\t\tTSelectedFields[K],\n\t\t\t\t\t\ttrue\n\t\t\t\t\t> extends true ? K\n\t\t\t\t\t\t: never;\n\t\t\t\t}[keyof TSelectedFields]\n\t\t\t\t& keyof TRawSelection\n\t]: TRawSelection[K];\n};\n\nexport type BuildQueryResult<\n\tTSchema extends TablesRelationalConfig,\n\tTTableConfig extends TableRelationalConfig,\n\tTFullSelection extends true | Record<string, unknown>,\n\tTModel extends Record<string, unknown> = Assume<\n\t\tTTableConfig['table'],\n\t\t{ $inferSelect: Record<string, unknown> }\n\t>['$inferSelect'],\n> = Equal<TFullSelection, true> extends true ? Simplify<InferRelationalQueryTableResult<TModel>>\n\t: TFullSelection extends Record<string, unknown> ? Simplify<\n\t\t\t& (InferRelationalQueryTableResult<\n\t\t\t\tTModel,\n\t\t\t\tTFullSelection['columns'] extends Record<string, unknown> ? TFullSelection['columns'] : 'Full'\n\t\t\t>)\n\t\t\t& (TFullSelection['extras'] extends Record<string, SQLWrapper | ((...args: any[]) => SQLWrapper)> ? {\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]: ReturnType<\n\t\t\t\t\t\tAssume<\n\t\t\t\t\t\t\tReturnTypeOrValue<TFullSelection['extras'][K & string]>,\n\t\t\t\t\t\t\tSQLWrapper\n\t\t\t\t\t\t>['getSQL']\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 BuildRelationalQueryResult {\n\tselection: {\n\t\tkey: string;\n\t\tfield: Column<any> | Table | SQL | SQL.Aliased | SQLWrapper | AggregatedField;\n\t\tisArray?: boolean;\n\t\tselection?: BuildRelationalQueryResult['selection'];\n\t\tisOptional?: boolean;\n\t}[];\n\tsql: SQL;\n}\n\nexport function mapRelationalRow(\n\trow: Record<string, unknown>,\n\tbuildQueryResultSelection: BuildRelationalQueryResult['selection'],\n\tmapColumnValue: (value: unknown) => unknown = (value) => value,\n\t/** Needed for SQLite as it returns JSON values as strings */\n\tparseJson: boolean = false,\n\t/** Needed for SingleStore as it returns JSON arrays as strings */\n\tparseJsonIfString: boolean = false,\n\tpath?: string,\n): Record<string, unknown> {\n\tfor (\n\t\tconst selectionItem of buildQueryResultSelection\n\t) {\n\t\tif (selectionItem.selection) {\n\t\t\tconst currentPath = `${path ? `${path}.` : ''}${selectionItem.key}`;\n\n\t\t\tif (row[selectionItem.key] === null) continue;\n\n\t\t\tif (parseJson) row[selectionItem.key] = JSON.parse(row[selectionItem.key] as string);\n\t\t\tif (parseJsonIfString && typeof row[selectionItem.key] === 'string') {\n\t\t\t\trow[selectionItem.key] = JSON.parse(row[selectionItem.key] as string);\n\t\t\t}\n\n\t\t\tif (selectionItem.isArray) {\n\t\t\t\tfor (const item of (row[selectionItem.key] as Array<Record<string, unknown>>)) {\n\t\t\t\t\tmapRelationalRow(\n\t\t\t\t\t\titem,\n\t\t\t\t\t\tselectionItem.selection!,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t\tfalse,\n\t\t\t\t\t\tparseJsonIfString,\n\t\t\t\t\t\tcurrentPath,\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tmapRelationalRow(\n\t\t\t\trow[selectionItem.key] as Record<string, unknown>,\n\t\t\t\tselectionItem.selection!,\n\t\t\t\tmapColumnValue,\n\t\t\t\tfalse,\n\t\t\t\tparseJsonIfString,\n\t\t\t\tcurrentPath,\n\t\t\t);\n\n\t\t\tcontinue;\n\t\t}\n\n\t\tconst field = selectionItem.field!;\n\t\tconst value = mapColumnValue(row[selectionItem.key]);\n\t\tif (value === null) continue;\n\n\t\tlet decoder;\n\t\tif (is(field, Column)) {\n\t\t\tdecoder = field;\n\t\t} else if (is(field, SQL)) {\n\t\t\tdecoder = field.decoder;\n\t\t} else if (is(field, SQL.Aliased)) {\n\t\t\tdecoder = field.sql.decoder;\n\t\t} else {\n\t\t\tdecoder = field.getSQL().decoder;\n\t\t}\n\n\t\trow[selectionItem.key] = 'mapFromJsonValue' in decoder\n\t\t\t? (<(value: unknown) => unknown> decoder.mapFromJsonValue)(value)\n\t\t\t: decoder.mapFromDriverValue(value);\n\t}\n\n\treturn row;\n}\n\nexport class RelationsBuilderTable<TTableName extends string = string> {\n\tstatic readonly [entityKind]: string = 'RelationsBuilderTable';\n\n\tprotected readonly _: {\n\t\treadonly name: TTableName;\n\t\treadonly table: SchemaEntry;\n\t};\n\n\tconstructor(table: SchemaEntry, name: TTableName) {\n\t\tthis._ = {\n\t\t\tname,\n\t\t\ttable,\n\t\t};\n\t}\n}\n\nexport interface RelationsBuilderColumnConfig<\n\tTTableName extends string = string,\n> {\n\treadonly tableName: TTableName;\n\treadonly column: FieldValue;\n\treadonly through?: RelationsBuilderColumnBase;\n\treadonly key: string;\n}\n\nexport interface RelationsBuilderColumnBase<\n\tTTableName extends string = string,\n> {\n\t_: RelationsBuilderColumnConfig<TTableName>;\n}\n\nexport class RelationsBuilderColumn<\n\tTTableName extends string = string,\n> implements RelationsBuilderColumnBase<TTableName> {\n\tstatic readonly [entityKind]: string = 'RelationsBuilderColumn';\n\n\treadonly _: {\n\t\treadonly tableName: TTableName;\n\t\treadonly column: FieldValue;\n\t\treadonly key: string;\n\t};\n\n\tconstructor(\n\t\tcolumn: FieldValue,\n\t\ttableName: TTableName,\n\t\tkey: string,\n\t) {\n\t\tthis._ = {\n\t\t\ttableName: tableName,\n\t\t\tcolumn,\n\t\t\tkey,\n\t\t};\n\t}\n\n\tthrough(column: RelationsBuilderColumn): RelationsBuilderJunctionColumn<TTableName> {\n\t\treturn new RelationsBuilderJunctionColumn(\n\t\t\tthis._.column,\n\t\t\tthis._.tableName,\n\t\t\tthis._.key,\n\t\t\tcolumn,\n\t\t);\n\t}\n}\n\nexport class RelationsBuilderJunctionColumn<\n\tTTableName extends string = string,\n> implements RelationsBuilderColumnBase<TTableName> {\n\tstatic readonly [entityKind]: string = 'RelationsBuilderColumn';\n\n\treadonly _: {\n\t\treadonly tableName: TTableName;\n\t\treadonly column: FieldValue;\n\t\treadonly through: RelationsBuilderColumnBase;\n\t\treadonly key: string;\n\t};\n\n\tconstructor(\n\t\tcolumn: FieldValue,\n\t\ttableName: TTableName,\n\t\tkey: string,\n\t\tthrough: RelationsBuilderColumnBase,\n\t) {\n\t\tthis._ = {\n\t\t\ttableName: tableName,\n\t\t\tcolumn,\n\t\t\tthrough,\n\t\t\tkey,\n\t\t};\n\t}\n}\n\nexport interface RelationFieldsFilterInternals<T> {\n\teq?: T | Placeholder | undefined;\n\tne?: T | Placeholder | undefined;\n\tgt?: T | Placeholder | undefined;\n\tgte?: T | Placeholder | undefined;\n\tlt?: T | Placeholder | undefined;\n\tlte?: T | Placeholder | undefined;\n\tin?: (T | Placeholder)[] | Placeholder | undefined;\n\tnotIn?: (T | Placeholder)[] | Placeholder | undefined;\n\tarrayContains?: (T extends Array<infer E> ? (E | Placeholder)[] : (T | Placeholder)[]) | Placeholder | undefined;\n\tarrayContained?: (T extends Array<infer E> ? (E | Placeholder)[] : (T | Placeholder)[]) | Placeholder | undefined;\n\tarrayOverlaps?: (T extends Array<infer E> ? (E | Placeholder)[] : (T | Placeholder)[]) | Placeholder | undefined;\n\tlike?: string | Placeholder | undefined;\n\tilike?: string | Placeholder | undefined;\n\tnotLike?: string | Placeholder | undefined;\n\tnotIlike?: string | Placeholder | undefined;\n\tisNull?: true | undefined;\n\tisNotNull?: true | undefined;\n\tNOT?: RelationsFieldFilter<T> | undefined;\n\tOR?: RelationsFieldFilter<T>[] | undefined;\n\tAND?: RelationsFieldFilter<T>[] | undefined;\n}\n\nexport type RelationsFieldFilter<T = unknown> =\n\t| RelationFieldsFilterInternals<T>\n\t| (\n\t\tunknown extends T ? never : T extends object ? never : T\n\t)\n\t// Bleeds into filters - discuss removal\n\t| Placeholder;\n\nexport interface RelationsFilterCommons<\n\tTTable extends TableRelationalConfig = TableRelationalConfig,\n\tTSchema extends TablesRelationalConfig = TablesRelationalConfig,\n> {\n\tOR?: RelationsFilter<TTable, TSchema>[] | undefined;\n\tNOT?: RelationsFilter<TTable, TSchema> | undefined;\n\tAND?: RelationsFilter<TTable, TSchema>[] | undefined;\n\tRAW?:\n\t\t| SQLWrapper\n\t\t| ((\n\t\t\ttable: TTable['table'],\n\t\t\toperators: Operators,\n\t\t) => SQL)\n\t\t| undefined;\n}\n\nexport type RelationsFilterColumns<\n\tTColumns extends Record<string, unknown>,\n> = {\n\t[K in keyof TColumns]?:\n\t\t| (TColumns[K] extends { _: { data: infer Data } } ? RelationsFieldFilter<Data>\n\t\t\t: RelationsFieldFilter<unknown>)\n\t\t| undefined;\n};\n\nexport type RelationsFilterRelations<\n\tTTable extends TableRelationalConfig,\n\tTSchema extends TablesRelationalConfig,\n\tTRelations extends RelationsRecord = TTable['relations'],\n> = {\n\t[K in keyof TRelations]?:\n\t\t| boolean\n\t\t| RelationsFilter<FindTargetTableInRelationalConfig<TSchema, TRelations[K]>, TSchema>\n\t\t| undefined;\n};\n\nexport type RelationsFilter<\n\tTTable extends TableRelationalConfig,\n\tTSchema extends TablesRelationalConfig,\n\tTColumns extends FieldSelection = GetTableViewFieldSelection<TTable['table']>,\n> = TTable['relations'] extends Record<string, never> ? TableFilter<TTable['table']>\n\t:\n\t\t& RelationsFilterColumns<TColumns>\n\t\t& RelationsFilterRelations<TTable, TSchema>\n\t\t& RelationsFilterCommons<TTable, TSchema>;\n\nexport interface TableFilterCommons<\n\tTTable extends SchemaEntry = SchemaEntry,\n\tTColumns extends Record<string, unknown> = GetTableViewColumns<TTable>,\n> {\n\tOR?: TableFilter<TTable, TColumns>[] | undefined;\n\tNOT?: TableFilter<TTable, TColumns> | undefined;\n\tAND?: TableFilter<TTable, TColumns>[] | undefined;\n\tRAW?:\n\t\t| SQLWrapper\n\t\t| ((\n\t\t\ttable: TTable,\n\t\t\toperators: Operators,\n\t\t) => SQL)\n\t\t| undefined;\n}\n\nexport type TableFilterColumns<\n\tTColumns extends Record<string, unknown>,\n> = {\n\t[K in keyof TColumns]?:\n\t\t| (TColumns[K] extends { _: { data: infer Data } } ? RelationsFieldFilter<Data>\n\t\t\t: RelationsFieldFilter<unknown>)\n\t\t| undefined;\n};\n\nexport type TableFilter<\n\tTTable extends SchemaEntry = SchemaEntry,\n\tTColumns extends Record<string, unknown> = GetTableViewColumns<TTable>,\n> =\n\t& TableFilterColumns<TColumns>\n\t& TableFilterCommons<TTable, TColumns>;\n\nexport type AnyRelationsFilter = RelationsFilter<\n\tTableRelationalConfig,\n\tTablesRelationalConfig,\n\tFieldSelection\n>;\n\nexport type AnyTableFilter = TableFilter<\n\tSchemaEntry,\n\tFieldSelection\n>;\n\nexport interface OneConfig<TTargetTable extends SchemaEntry, TOptional extends boolean> {\n\tfrom?: RelationsBuilderColumnBase | [RelationsBuilderColumnBase, ...RelationsBuilderColumnBase[]];\n\tto?: RelationsBuilderColumnBase | [RelationsBuilderColumnBase, ...RelationsBuilderColumnBase[]];\n\twhere?: TableFilter<TTargetTable>;\n\toptional?: TOptional;\n\talias?: string;\n}\n\nexport type AnyOneConfig = OneConfig<\n\tSchemaEntry,\n\tboolean\n>;\n\nexport interface ManyConfig<TTargetTable extends SchemaEntry> {\n\tfrom?: RelationsBuilderColumnBase | [RelationsBuilderColumnBase, ...RelationsBuilderColumnBase[]];\n\tto?: RelationsBuilderColumnBase | [RelationsBuilderColumnBase, ...RelationsBuilderColumnBase[]];\n\twhere?: TableFilter<TTargetTable>;\n\talias?: string;\n}\n\nexport type AnyManyConfig = ManyConfig<SchemaEntry>;\n\nexport interface OneFn<TTargetTable extends SchemaEntry, TTargetTableName extends string> {\n\t<TOptional extends boolean = true>(config?: OneConfig<TTargetTable, TOptional>): One<TTargetTableName, TOptional>;\n}\n\nexport interface ManyFn<TTargetTable extends SchemaEntry, TTargetTableName extends string> {\n\t(config?: ManyConfig<TTargetTable>): Many<TTargetTableName>;\n}\n\nexport class RelationsHelperStatic<TTables extends Schema> {\n\tstatic readonly [entityKind]: string = 'RelationsHelperStatic';\n\t// declare readonly $brand: 'RelationsHelperStatic';\n\n\tprivate readonly _: {\n\t\treadonly tables: TTables;\n\t};\n\n\tconstructor(tables: TTables) {\n\t\tthis._ = {\n\t\t\ttables,\n\t\t};\n\n\t\tconst one: Record<string, OneFn<TTables[string], string>> = {};\n\t\tconst many: Record<string, ManyFn<TTables[string], string>> = {};\n\n\t\tfor (const [tableName, table] of Object.entries(tables)) {\n\t\t\tone[tableName] = (config) => {\n\t\t\t\treturn new One(tables, table, tableName, config as unknown as AnyOneConfig);\n\t\t\t};\n\n\t\t\tmany[tableName] = (config) => {\n\t\t\t\treturn new Many(tables, table, tableName, config as AnyManyConfig);\n\t\t\t};\n\t\t}\n\n\t\tthis.one = one as any as this['one'];\n\t\tthis.many = many as any as this['many'];\n\t}\n\n\tone: {\n\t\t[K in keyof TTables]: TTables[K] extends FilteredSchemaEntry ? OneFn<TTables[K], K & string>\n\t\t\t: DrizzleTypeError<'Views with nested selections are not supported by the relational query builder'>;\n\t};\n\n\tmany: {\n\t\t[K in keyof TTables]: TTables[K] extends FilteredSchemaEntry ? ManyFn<TTables[K], K & string>\n\t\t\t: DrizzleTypeError<'Views with nested selections are not supported by the relational query builder'>;\n\t};\n\n\t/** @internal - to be reworked */\n\taggs = {\n\t\tcount(): Count {\n\t\t\treturn new Count();\n\t\t},\n\t};\n}\n\nexport type RelationsBuilderColumns<TTable extends SchemaEntry, TTableName extends string> = {\n\t[\n\t\tTColumnName in keyof GetTableViewColumns<TTable>\n\t]: RelationsBuilderColumn<\n\t\tTTableName\n\t>;\n};\n\nexport type RelationsBuilderTables<TSchema extends Schema> = {\n\t[TTableName in keyof TSchema]: TSchema[TTableName] extends FilteredSchemaEntry ? (\n\t\t\t& RelationsBuilderColumns<TSchema[TTableName], TTableName & string>\n\t\t\t& RelationsBuilderTable<TTableName & string>\n\t\t)\n\t\t: DrizzleTypeError<'Views with nested selections are not supported by the relational query builder'>;\n};\n\nexport type RelationsBuilder<TSchema extends Schema> =\n\t& RelationsBuilderTables<TSchema>\n\t& RelationsHelperStatic<TSchema>;\n\nexport type RelationsBuilderConfigValue =\n\t| RelationsRecord\n\t| undefined;\n\nexport type RelationsBuilderConfig<TTables extends Schema> = {\n\t[TTableName in keyof TTables]?: RelationsBuilderConfigValue;\n};\n\nexport type AnyRelationsBuilderConfig = Record<string, RelationsBuilderConfigValue>;\n\nexport type ExtractTablesFromSchema<TSchema extends Record<string, unknown>> = Assume<\n\t{\n\t\t[K in keyof TSchema as TSchema[K] extends SchemaEntry ? K extends string ? K : never : never]: TSchema[K];\n\t},\n\tSchema\n>;\n\nexport function createRelationsHelper<\n\tTTables extends Schema,\n>(tables: TTables): RelationsBuilder<TTables> {\n\tconst helperStatic = new RelationsHelperStatic(tables);\n\tconst relationsTables = Object.entries(tables).reduce<Record<string, RelationsBuilderTable>>((acc, [tKey, value]) => {\n\t\tconst rTable = new RelationsBuilderTable(value, tKey);\n\t\tconst columns = Object.entries(value[TableColumns]).reduce<\n\t\t\tRecord<string, RelationsBuilderColumnBase>\n\t\t>(\n\t\t\t(acc, [cKey, column]) => {\n\t\t\t\tconst rbColumn = new RelationsBuilderColumn(column as FieldValue, tKey, cKey);\n\t\t\t\tacc[cKey] = rbColumn;\n\t\t\t\treturn acc;\n\t\t\t},\n\t\t\t{},\n\t\t);\n\n\t\tacc[tKey] = Object.assign(rTable, columns);\n\n\t\treturn acc;\n\t}, {});\n\n\treturn Object.assign(helperStatic, relationsTables) as any;\n}\n\nexport function extractTablesFromSchema<TSchema extends Record<string, unknown>>(\n\tschema: TSchema,\n): ExtractTablesFromSchema<TSchema> {\n\treturn Object.fromEntries(\n\t\tObject.entries(schema).filter(([_, e]) => is(e, Table) || is(e, View)),\n\t) as ExtractTablesFromSchema<TSchema>;\n}\n\nexport type IncludeEveryTable<TTables extends Schema> = { [K in keyof TTables]: {} };\n\n/** Builds relational config for every table in schema */\nexport function defineRelations<\n\tTSchema extends Record<string, unknown>,\n\tTTables extends Schema = ExtractTablesFromSchema<TSchema>,\n>(\n\tschema: TSchema,\n): ExtractTablesWithRelations<{}, TTables>;\n/** Builds relational config for every table in schema */\nexport function defineRelations<\n\tTSchema extends Record<string, unknown>,\n\tTConfig extends RelationsBuilderConfig<TTables>,\n\tTTables extends Schema = ExtractTablesFromSchema<TSchema>,\n>(\n\tschema: TSchema,\n\trelations: (helpers: RelationsBuilder<TTables>) => TConfig,\n): ExtractTablesWithRelations<TConfig, TTables>;\nexport function defineRelations(\n\tschema: Record<string, unknown>,\n\trelations?: (helpers: RelationsBuilder<Schema>) => AnyRelationsBuilderConfig,\n): TablesRelationalConfig {\n\tconst tables = extractTablesFromSchema(schema);\n\tconst config = relations\n\t\t? relations(\n\t\t\tcreateRelationsHelper(tables) as RelationsBuilder<Schema>,\n\t\t)\n\t\t: {};\n\n\treturn buildRelations(tables, config);\n}\n\n/** Builds relational config for every table in schema */\nexport function defineRelationsPart<\n\tTSchema extends Record<string, unknown>,\n\tTTables extends Schema = ExtractTablesFromSchema<TSchema>,\n>(\n\tschema: TSchema,\n): ExtractTablesWithRelationsParts<IncludeEveryTable<TTables>, TTables>;\n/** Builds relational config only for tables present in relational config */\nexport function defineRelationsPart<\n\tTSchema extends Record<string, unknown>,\n\tTConfig extends RelationsBuilderConfig<TTables>,\n\tTTables extends Schema = ExtractTablesFromSchema<TSchema>,\n>(\n\tschema: TSchema,\n\trelations: (helpers: RelationsBuilder<TTables>) => TConfig,\n): ExtractTablesWithRelationsParts<TConfig, TTables>;\nexport function defineRelationsPart(\n\tschema: Record<string, unknown>,\n\trelations?: (helpers: RelationsBuilder<Schema>) => AnyRelationsBuilderConfig,\n): TablesRelationalConfig {\n\tconst tables = extractTablesFromSchema(schema);\n\tconst config = relations\n\t\t? relations(\n\t\t\tcreateRelationsHelper(tables) as RelationsBuilder<Schema>,\n\t\t)\n\t\t: Object.fromEntries(Object.keys(tables).map((k) => [k, {}])) as AnyRelationsBuilderConfig;\n\n\treturn buildRelationsParts(tables, config);\n}\n\nexport interface WithContainer {\n\twith?: Record<string, boolean | AnyDBQueryConfig | undefined>;\n}\n\nexport interface ColumnWithTSName {\n\tcolumn: Column<any> | SQL | SQLWrapper | SQL.Aliased;\n\ttsName: string;\n}\n\nexport type RelationsOrder<TColumns extends FieldSelection> = {\n\t[K in keyof TColumns]?: 'asc' | 'desc';\n};\n\nexport type OrderBy = Exclude<AnyDBQueryConfig['orderBy'], undefined>;\n\nexport type Extras = Exclude<AnyDBQueryConfig['extras'], undefined>;\n\n/** @internal */\nexport function fieldSelectionToSQL(table: SchemaEntry, target: string) {\n\tconst field = table[TableColumns][target];\n\n\treturn field\n\t\t? is(field, Column)\n\t\t\t? field\n\t\t\t: is(field, SQL.Aliased)\n\t\t\t? sql`${table}.${sql.identifier(field.fieldAlias)}`\n\t\t\t: sql`${table}.${sql.identifier(target)}`\n\t\t: sql`${table}.${sql.identifier(target)}`;\n}\n\nfunction relationsFieldFilterToSQL(column: SQLWrapper, filter: RelationsFieldFilter<unknown>): SQL | undefined {\n\tif (typeof filter !== 'object' || is(filter, Placeholder)) return eq(column, filter);\n\n\tconst entries = Object.entries(filter as RelationFieldsFilterInternals<unknown>);\n\tif (!entries.length) return undefined;\n\n\tconst parts: (SQL)[] = [];\n\tfor (const [target, value] of entries) {\n\t\tif (value === undefined) continue;\n\n\t\tswitch (target as keyof RelationFieldsFilterInternals<unknown>) {\n\t\t\tcase 'NOT': {\n\t\t\t\tconst res = relationsFieldFilterToSQL(column, value as RelationsFieldFilter<unknown>);\n\t\t\t\tif (!res) continue;\n\n\t\t\t\tparts.push(not(res));\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tcase 'OR': {\n\t\t\t\tif (!(value as RelationsFieldFilter<unknown>[]).length) continue;\n\n\t\t\t\tparts.push(\n\t\t\t\t\tor(\n\t\t\t\t\t\t...(value as AnyRelationsFilter[]).map((subFilter) => relationsFieldFilterToSQL(column, subFilter)),\n\t\t\t\t\t)!,\n\t\t\t\t);\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tcase 'AND': {\n\t\t\t\tif (!(value as RelationsFieldFilter<unknown>[]).length) continue;\n\n\t\t\t\tparts.push(\n\t\t\t\t\tand(\n\t\t\t\t\t\t...(value as AnyRelationsFilter[]).map((subFilter) => relationsFieldFilterToSQL(column, subFilter)),\n\t\t\t\t\t)!,\n\t\t\t\t);\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tcase 'isNotNull':\n\t\t\tcase 'isNull': {\n\t\t\t\tif (!value) continue;\n\n\t\t\t\tparts.push(operators[target as 'isNull' | 'isNotNull'](column));\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tcase 'in': {\n\t\t\t\tparts.push(operators.inArray(column, value as any[] | Placeholder));\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tcase 'notIn': {\n\t\t\t\tparts.push(operators.notInArray(column, value as any[] | Placeholder));\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tdefault: {\n\t\t\t\tparts.push(\n\t\t\t\t\t(operators[target as keyof typeof operators] as ((col: SQLWrapper, data: any) => SQL | undefined))(\n\t\t\t\t\t\tcolumn,\n\t\t\t\t\t\tvalue,\n\t\t\t\t\t)!,\n\t\t\t\t);\n\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t}\n\t}\n\n\tif (!parts.length) return undefined;\n\n\treturn and(...parts);\n}\n\nexport function relationsFilterToSQL(\n\ttable: SchemaEntry,\n\tfilter: AnyRelationsFilter | AnyTableFilter,\n): SQL | undefined;\nexport function relationsFilterToSQL(\n\ttable: SchemaEntry,\n\tfilter: AnyRelationsFilter | AnyTableFilter,\n\ttableRelations: RelationsRecord,\n\ttablesRelations: TablesRelationalConfig,\n\tcasing: CasingCache,\n\tdepth?: number,\n): SQL | undefined;\nexport function relationsFilterToSQL(\n\ttable: SchemaEntry,\n\tfilter: AnyRelationsFilter | AnyTableFilter,\n\ttableRelations: RelationsRecord = {},\n\ttablesRelations: TablesRelationalConfig = {},\n\tcasing?: CasingCache,\n\tdepth: number = 0,\n): SQL | undefined {\n\tconst entries = Object.entries(filter);\n\tif (!entries.length) return undefined;\n\n\tconst parts: SQL[] = [];\n\tfor (const [target, value] of entries) {\n\t\tif (value === undefined) continue;\n\n\t\tswitch (target) {\n\t\t\tcase 'RAW': {\n\t\t\t\tconst processed = typeof value === 'function'\n\t\t\t\t\t? (value as unknown as (table: FieldSelection, operators: Operators) => SQL)(table as any, operators)\n\t\t\t\t\t: (value as SQLWrapper).getSQL();\n\n\t\t\t\tparts.push(processed);\n\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\tcase 'OR': {\n\t\t\t\tif (!(value as AnyRelationsFilter[] | undefined)?.length) continue;\n\n\t\t\t\tparts.push(\n\t\t\t\t\tor(\n\t\t\t\t\t\t...(value as AnyRelationsFilter[]).map((subFilter) =>\n\t\t\t\t\t\t\trelationsFilterToSQL(table, subFilter, tableRelations, tablesRelations, casing!, depth)\n\t\t\t\t\t\t),\n\t\t\t\t\t)!,\n\t\t\t\t);\n\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\tcase 'AND': {\n\t\t\t\tif (!(value as AnyRelationsFilter[] | undefined)?.length) continue;\n\n\t\t\t\tparts.push(\n\t\t\t\t\tand(\n\t\t\t\t\t\t...(value as AnyRelationsFilter[]).map((subFilter) =>\n\t\t\t\t\t\t\trelationsFilterToSQL(table, subFilter, tableRelations, tablesRelations, casing!, depth)\n\t\t\t\t\t\t),\n\t\t\t\t\t)!,\n\t\t\t\t);\n\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\tcase 'NOT': {\n\t\t\t\tif (value === undefined) continue;\n\n\t\t\t\tconst built = relationsFilterToSQL(\n\t\t\t\t\ttable,\n\t\t\t\t\tvalue as AnyRelationsFilter,\n\t\t\t\t\ttableRelations,\n\t\t\t\t\ttablesRelations,\n\t\t\t\t\tcasing!,\n\t\t\t\t\tdepth,\n\t\t\t\t);\n\t\t\t\tif (!built) continue;\n\n\t\t\t\tparts.push(not(built));\n\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\tdefault: {\n\t\t\t\tif (table[TableColumns][target]) {\n\t\t\t\t\tconst column = fieldSelectionToSQL(table, target);\n\n\t\t\t\t\tconst colFilter = relationsFieldFilterToSQL(\n\t\t\t\t\t\tcolumn,\n\t\t\t\t\t\tvalue as RelationsFieldFilter,\n\t\t\t\t\t);\n\t\t\t\t\tif (colFilter) parts.push(colFilter);\n\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst relation = tableRelations[target];\n\t\t\t\tif (!relation) {\n\t\t\t\t\t// Should never trigger unless the types've been violated\n\t\t\t\t\tthrow new DrizzleError({\n\t\t\t\t\t\tmessage: `Unknown relational filter field: \"${target}\"`,\n\t\t\t\t\t});\n\t\t\t\t}\n\n\t\t\t\tconst targetTable = aliasedTable(relation.targetTable, `f${depth}`);\n\t\t\t\tconst throughTable = relation.throughTable ? aliasedTable(relation.throughTable, `ft${depth}`) : undefined;\n\t\t\t\tconst targetConfig = tablesRelations[relation.targetTableName]!;\n\n\t\t\t\tconst {\n\t\t\t\t\tfilter: relationFilter,\n\t\t\t\t\tjoinCondition,\n\t\t\t\t} = relationToSQL(casing!, relation, table, targetTable, throughTable);\n\t\t\t\tconst subfilter = typeof value === 'boolean' ? undefined : relationsFilterToSQL(\n\t\t\t\t\ttargetTable,\n\t\t\t\t\tvalue as AnyRelationsFilter,\n\t\t\t\t\ttargetConfig.relations,\n\t\t\t\t\ttablesRelations,\n\t\t\t\t\tcasing!,\n\t\t\t\t\tdepth + 1,\n\t\t\t\t);\n\t\t\t\tconst filter = and(\n\t\t\t\t\trelationFilter,\n\t\t\t\t\tsubfilter,\n\t\t\t\t);\n\n\t\t\t\tconst subquery = throughTable\n\t\t\t\t\t? sql`(select * from ${getTableAsAliasSQL(targetTable)} inner join ${\n\t\t\t\t\t\tgetTableAsAliasSQL(throughTable)\n\t\t\t\t\t} on ${joinCondition}${sql` where ${filter}`.if(filter)} limit 1)`\n\t\t\t\t\t: sql`(select * from ${getTableAsAliasSQL(targetTable)}${sql` where ${filter}`.if(filter)} limit 1)`;\n\t\t\t\tif (filter) parts.push((value ? exists : notExists)(subquery));\n\t\t\t}\n\t\t}\n\t}\n\n\treturn and(...parts)!;\n}\n\nexport function relationsOrderToSQL(\n\ttable: SchemaEntry,\n\torders: OrderBy,\n): SQL | undefined {\n\tif (typeof orders === 'function') {\n\t\tconst data = orders(table as any, orderByOperators);\n\n\t\treturn is(data, SQL)\n\t\t\t? data\n\t\t\t: Array.isArray(data)\n\t\t\t? data.length\n\t\t\t\t? sql.join(data.map((o) => is(o, SQL) ? o : asc(o)), sql`, `)\n\t\t\t\t: undefined\n\t\t\t: is(data, Column)\n\t\t\t? asc(data)\n\t\t\t: undefined;\n\t}\n\n\tconst entries = Object.entries(orders).filter(([_, value]) => value);\n\tif (!entries.length) return undefined;\n\n\treturn sql.join(\n\t\tentries.map(([target, value]) => (value === 'asc' ? asc : desc)(fieldSelectionToSQL(table, target))),\n\t\tsql`, `,\n\t);\n}\n\nexport function relationExtrasToSQL(\n\ttable: SchemaEntry,\n\textras: Extras,\n) {\n\tconst subqueries: SQL[] = [];\n\tconst selection: BuildRelationalQueryResult['selection'] = [];\n\n\tfor (\n\t\tconst [key, field] of Object.entries(extras)\n\t) {\n\t\tif (!field) continue;\n\t\tconst extra = typeof field === 'function' ? field(table as any, { sql: operators.sql }) : field;\n\n\t\tconst query = sql`(${extra.getSQL()}) as ${sql.identifier(key)}`;\n\n\t\tquery.decoder = extra.getSQL().decoder;\n\n\t\tsubqueries.push(query);\n\t\tselection.push({\n\t\t\tkey,\n\t\t\tfield: query,\n\t\t});\n\t}\n\n\treturn {\n\t\tsql: subqueries.length ? sql.join(subqueries, sql`, `) : undefined,\n\t\tselection,\n\t};\n}\n\nexport interface BuiltRelationFilters {\n\tfilter?: SQL;\n\tjoinCondition?: SQL;\n}\n\nexport function relationToSQL(\n\tcasing: CasingCache,\n\trelation: Relation,\n\tsourceTable: SchemaEntry,\n\ttargetTable: SchemaEntry,\n\tthroughTable?: SchemaEntry,\n): BuiltRelationFilters {\n\tif (relation.through) {\n\t\tconst outerColumnWhere = relation.sourceColumns.map((s, i) => {\n\t\t\tconst t = relation.through!.source[i]!;\n\n\t\t\treturn eq(\n\t\t\t\tsql`${sourceTable}.${sql.identifier(casing.getColumnCasing(s))}`,\n\t\t\t\tsql`${throughTable!}.${sql.identifier(is(t._.column, Column) ? casing.getColumnCasing(t._.column) : t._.key)}`,\n\t\t\t);\n\t\t});\n\n\t\tconst innerColumnWhere = relation.targetColumns.map((s, i) => {\n\t\t\tconst t = relation.through!.target[i]!;\n\n\t\t\treturn eq(\n\t\t\t\tsql`${throughTable!}.${sql.identifier(is(t._.column, Column) ? casing.getColumnCasing(t._.column) : t._.key)}`,\n\t\t\t\tsql`${targetTable}.${sql.identifier(casing.getColumnCasing(s))}`,\n\t\t\t);\n\t\t});\n\n\t\treturn {\n\t\t\tfilter: and(\n\t\t\t\trelation.where\n\t\t\t\t\t? relationsFilterToSQL(relation.isReversed ? sourceTable : targetTable, relation.where)\n\t\t\t\t\t: undefined,\n\t\t\t\t...outerColumnWhere,\n\t\t\t),\n\t\t\tjoinCondition: and(...innerColumnWhere),\n\t\t};\n\t}\n\n\tconst columnWhere = relation.sourceColumns.map((s, i) => {\n\t\tconst t = relation.targetColumns[i]!;\n\n\t\treturn eq(\n\t\t\tsql`${sourceTable}.${sql.identifier(casing.getColumnCasing(s))}`,\n\t\t\tsql`${targetTable}.${sql.identifier(casing.getColumnCasing(t))}`,\n\t\t);\n\t});\n\n\tconst fullWhere = and(\n\t\t...columnWhere,\n\t\trelation.where\n\t\t\t? relationsFilterToSQL(relation.isReversed ? sourceTable : targetTable, relation.where)\n\t\t\t: undefined,\n\t)!;\n\n\treturn { filter: fullWhere };\n}\n\nexport function getTableAsAliasSQL(table: SchemaEntry) {\n\treturn sql`${\n\t\ttable[IsAlias]\n\t\t\t? sql`${sql`${sql.identifier(table[TableSchema] ?? '')}.`.if(table[TableSchema])}${\n\t\t\t\tsql.identifier(table[OriginalName])\n\t\t\t} as ${table}`\n\t\t\t: table\n\t}`;\n}\n"],"mappings":"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","names":["acc","filter"]}
1
+ {"version":3,"sources":["../src/relations.ts"],"sourcesContent":["import { IsAlias, OriginalName, Table, TableColumns, TableSchema } from '~/table.ts';\nimport { aliasedTable } from './alias.ts';\nimport type { CasingCache } from './casing.ts';\nimport { type AnyColumn, Column } from './column.ts';\nimport { entityKind, is } from './entity.ts';\nimport { DrizzleError } from './errors.ts';\nimport {\n\tand,\n\tarrayContained,\n\tarrayContains,\n\tarrayOverlaps,\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 { Placeholder, SQL, sql, type SQLWrapper, View } from './sql/sql.ts';\nimport type { Assume, DrizzleTypeError, Equal, Simplify, ValueOrArray } from './utils.ts';\n\nexport type FilteredSchemaEntry = Table<any> | View<string, boolean, FieldSelection>;\n\nexport type SchemaEntry = Table<any> | View<string, boolean, any>;\n\nexport type Schema = Record<string, SchemaEntry>;\n\nexport type GetTableViewColumns<T extends SchemaEntry> = T extends View<string, boolean, any> ? T['_']['selectedFields']\n\t: T extends Table<any> ? T['_']['columns']\n\t: never;\n\nexport type GetTableViewFieldSelection<T extends SchemaEntry> = T extends View<string, boolean, FieldSelection>\n\t? T['_']['selectedFields']\n\t: T extends Table<any> ? T['_']['columns']\n\t: never;\n\nexport type FieldValue =\n\t| Column<any>\n\t| SQLWrapper\n\t| SQL.Aliased\n\t| SQL;\n\nexport type FieldSelection = Record<string, FieldValue>;\n\nexport function processRelations(tablesConfig: TablesRelationalConfig, tables: Schema) {\n\tfor (const tableConfig of Object.values(tablesConfig)) {\n\t\tfor (const [relationFieldName, relation] of Object.entries(tableConfig.relations)) {\n\t\t\tif (!is(relation, Relation)) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\trelation.sourceTable = tableConfig.table;\n\t\t\trelation.fieldName = relationFieldName;\n\t\t}\n\t}\n\n\tfor (const [sourceTableName, tableConfig] of Object.entries(tablesConfig)) {\n\t\tfor (const [relationFieldName, relation] of Object.entries(tableConfig.relations)) {\n\t\t\tif (!is(relation, Relation)) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tlet reverseRelation: Relation | undefined;\n\t\t\tconst {\n\t\t\t\ttargetTableName,\n\t\t\t\talias,\n\t\t\t\tsourceColumns,\n\t\t\t\ttargetColumns,\n\t\t\t\tthroughTable,\n\t\t\t\tsourceTable,\n\t\t\t\tthrough,\n\t\t\t\ttargetTable,\n\t\t\t\twhere,\n\t\t\t\tsourceColumnTableNames,\n\t\t\t\ttargetColumnTableNames,\n\t\t\t} = relation;\n\t\t\tconst relationPrintName = `relations -> ${tableConfig.name}: { ${relationFieldName}: r.${\n\t\t\t\tis(relation, One) ? 'one' : 'many'\n\t\t\t}.${targetTableName}(...) }`;\n\n\t\t\tif (relationFieldName in tableConfig.table[TableColumns]) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`${relationPrintName}: relation name collides with column \"${relationFieldName}\" of table \"${tableConfig.name}\"`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tif (typeof alias === 'string' && !alias) {\n\t\t\t\tthrow new Error(`${relationPrintName}: \"alias\" cannot be an empty string - omit it if you don't need it`);\n\t\t\t}\n\n\t\t\tif (sourceColumns?.length === 0) {\n\t\t\t\tthrow new Error(`${relationPrintName}: \"from\" cannot be empty`);\n\t\t\t}\n\n\t\t\tif (targetColumns?.length === 0) {\n\t\t\t\tthrow new Error(`${relationPrintName}: \"to\" cannot be empty`);\n\t\t\t}\n\n\t\t\tif (sourceColumns && targetColumns) {\n\t\t\t\tif (sourceColumns.length !== targetColumns.length && !throughTable) {\n\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t`${relationPrintName}: \"from\" and \"to\" fields without \"through\" must have the same length`,\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\tfor (const sName of sourceColumnTableNames) {\n\t\t\t\t\tif (sName !== sourceTableName) {\n\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t`${relationPrintName}: all \"from\" columns must belong to table \"${sourceTableName}\", found column of table \"${sName}\"`,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tfor (const tName of targetColumnTableNames) {\n\t\t\t\t\tif (tName !== targetTableName) {\n\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t`${relationPrintName}: all \"to\" columns must belong to table \"${targetTable}\", found column of table \"${tName}\"`,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (through) {\n\t\t\t\t\tif (\n\t\t\t\t\t\tthrough.source.length !== sourceColumns.length\n\t\t\t\t\t\t|| through.target.length !== targetColumns.length\n\t\t\t\t\t) {\n\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t`${relationPrintName}: \".through(column)\" must be used either on all columns in \"from\" and \"to\" or not defined on any of them`,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\tfor (const column of through.source) {\n\t\t\t\t\t\tif (tables[column._.tableName] !== throughTable) {\n\t\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t\t`${relationPrintName}: \".through(column)\" must be used on the same table by all columns of the relation`,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tfor (const column of through.target) {\n\t\t\t\t\t\tif (tables[column._.tableName] !== throughTable) {\n\t\t\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t\t\t`${relationPrintName}: \".through(column)\" must be used on the same table by all columns of the relation`,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (sourceColumns || targetColumns) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`${relationPrintName}: relation must have either both \"from\" and \"to\" defined, or none of them`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tconst reverseTableConfig = tablesConfig[targetTableName];\n\t\t\tif (!reverseTableConfig) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`${relationPrintName}: not enough data provided to build the relation - \"from\"/\"to\" are not defined, and no reverse relations of table \"${targetTableName}\" were found\"`,\n\t\t\t\t);\n\t\t\t}\n\t\t\tif (alias) {\n\t\t\t\tconst reverseRelations = Object.values(reverseTableConfig.relations).filter((it): it is Relation =>\n\t\t\t\t\tis(it, Relation) && it.alias === alias && it !== relation\n\t\t\t\t);\n\t\t\t\tif (reverseRelations.length > 1) {\n\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t`${relationPrintName}: not enough data provided to build the relation - \"from\"/\"to\" are not defined, and multiple relations with alias \"${alias}\" found in table \"${targetTableName}\": ${\n\t\t\t\t\t\t\treverseRelations.map((it) => `\"${it.fieldName}\"`).join(', ')\n\t\t\t\t\t\t}`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\treverseRelation = reverseRelations[0];\n\t\t\t\tif (!reverseRelation) {\n\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t`${relationPrintName}: not enough data provided to build the relation - \"from\"/\"to\" are not defined, and there is no reverse relation of table \"${targetTableName}\" with alias \"${alias}\"`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tconst reverseRelations = Object.values(reverseTableConfig.relations).filter((it): it is Relation =>\n\t\t\t\t\tis(it, Relation) && it.targetTable === sourceTable && !it.alias && it !== relation\n\t\t\t\t);\n\t\t\t\tif (reverseRelations.length > 1) {\n\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t`${relationPrintName}: not enough data provided to build the relation - \"from\"/\"to\" are not defined, and multiple relations between \"${targetTableName}\" and \"${sourceTableName}\" were found.\\nHint: you can specify \"alias\" on both sides of the relation with the same value`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\treverseRelation = reverseRelations[0];\n\t\t\t\tif (!reverseRelation) {\n\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t`${relationPrintName}: not enough data provided to build the relation - \"from\"/\"to\" are not defined, and no reverse relation of table \"${targetTableName}\" with target table \"${sourceTableName}\" was found`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (!reverseRelation.sourceColumns || !reverseRelation.targetColumns) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`${relationPrintName}: not enough data provided to build the relation - \"from\"/\"to\" are not defined, and reverse relation \"${targetTableName}.${reverseRelation.fieldName}\" does not have \"from\"/\"to\" defined`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\trelation.sourceColumns = reverseRelation.targetColumns;\n\t\t\trelation.targetColumns = reverseRelation.sourceColumns;\n\t\t\trelation.through = reverseRelation.through\n\t\t\t\t? {\n\t\t\t\t\tsource: reverseRelation.through.target,\n\t\t\t\t\ttarget: reverseRelation.through.source,\n\t\t\t\t}\n\t\t\t\t: undefined;\n\t\t\trelation.throughTable = reverseRelation.throughTable;\n\t\t\trelation.isReversed = !where;\n\t\t\trelation.where = where ?? reverseRelation.where;\n\t\t}\n\t}\n\n\treturn tablesConfig;\n}\n\n/** Builds relational config for every table in schema */\nexport function buildRelations<TTables extends Schema, TConfig extends AnyRelationsBuilderConfig>(\n\ttables: TTables,\n\tconfig: TConfig,\n): ExtractTablesWithRelations<TConfig, TTables> {\n\tconst tablesConfig = {} as TablesRelationalConfig;\n\n\tfor (const [tsName, table] of Object.entries(tables)) {\n\t\ttablesConfig[tsName] = {\n\t\t\ttable,\n\t\t\tname: tsName,\n\t\t\trelations: config[tsName] ?? {},\n\t\t};\n\t}\n\n\treturn processRelations(tablesConfig, tables) as any;\n}\n\n/** Builds relational config only for tables present in relational config */\nexport function buildRelationsParts<TTables extends Schema, TConfig extends AnyRelationsBuilderConfig>(\n\ttables: TTables,\n\tconfig: TConfig,\n): ExtractTablesWithRelationsParts<TConfig, TTables> {\n\tconst tablesConfig = {} as TablesRelationalConfig;\n\n\tfor (const [tsName, relations] of Object.entries(config)) {\n\t\tif (!relations || !tables[tsName]) continue;\n\t\ttablesConfig[tsName] = {\n\t\t\ttable: tables[tsName],\n\t\t\tname: tsName,\n\t\t\trelations,\n\t\t};\n\t}\n\n\treturn processRelations(tablesConfig, tables) as any;\n}\n\nexport type RelationsRecord = Record<string, AnyRelation>;\nexport type EmptyRelations = {};\nexport type AnyRelations = TablesRelationalConfig;\n\nexport abstract class Relation<\n\tTTargetTableName extends string = string,\n> {\n\tstatic readonly [entityKind]: string = 'RelationV2';\n\tdeclare readonly $brand: 'RelationV2';\n\tdeclare public readonly relationType: 'many' | 'one';\n\n\tfieldName!: string;\n\tsourceColumns!: Column<any>[];\n\ttargetColumns!: Column<any>[];\n\talias: string | undefined;\n\twhere: AnyTableFilter | undefined;\n\tsourceTable!: SchemaEntry;\n\ttargetTable: SchemaEntry;\n\tthrough?: {\n\t\tsource: RelationsBuilderColumnBase[];\n\t\ttarget: RelationsBuilderColumnBase[];\n\t};\n\tthroughTable?: SchemaEntry;\n\tisReversed?: boolean;\n\n\t/** @internal */\n\tsourceColumnTableNames: string[] = [];\n\t/** @internal */\n\ttargetColumnTableNames: string[] = [];\n\n\tconstructor(\n\t\ttargetTable: SchemaEntry,\n\t\treadonly targetTableName: TTargetTableName,\n\t) {\n\t\tthis.targetTable = targetTable;\n\t}\n}\n\nexport type AnyRelation = Relation<string>;\n\nexport class One<\n\tTTargetTableName extends string,\n\tTOptional extends boolean = boolean,\n> extends Relation<TTargetTableName> {\n\tstatic override readonly [entityKind]: string = 'OneV2';\n\tdeclare protected $relationBrand: 'OneV2';\n\n\tpublic override readonly relationType = 'one' as const;\n\n\treadonly optional: TOptional;\n\n\tconstructor(\n\t\ttables: Schema,\n\t\ttargetTable: SchemaEntry,\n\t\ttargetTableName: TTargetTableName,\n\t\tconfig: AnyOneConfig | undefined,\n\t) {\n\t\tsuper(targetTable, targetTableName);\n\t\tthis.alias = config?.alias;\n\t\tthis.where = config?.where;\n\t\tif (config?.from) {\n\t\t\tthis.sourceColumns = ((Array.isArray(config.from)\n\t\t\t\t? config.from\n\t\t\t\t: [config.from]) as RelationsBuilderColumnBase[]).map((it: RelationsBuilderColumnBase) => {\n\t\t\t\t\tthis.throughTable ??= it._.through ? tables[it._.through._.tableName]! as SchemaEntry : undefined;\n\t\t\t\t\tthis.sourceColumnTableNames.push(it._.tableName);\n\t\t\t\t\treturn it._.column as Column;\n\t\t\t\t});\n\t\t}\n\t\tif (config?.to) {\n\t\t\tthis.targetColumns = (Array.isArray(config.to)\n\t\t\t\t? config.to\n\t\t\t\t: [config.to]).map((it: RelationsBuilderColumnBase) => {\n\t\t\t\t\tthis.throughTable ??= it._.through ? tables[it._.through._.tableName]! as SchemaEntry : undefined;\n\t\t\t\t\tthis.targetColumnTableNames.push(it._.tableName);\n\t\t\t\t\treturn it._.column as Column;\n\t\t\t\t});\n\t\t}\n\n\t\tif (this.throughTable) {\n\t\t\tthis.through = {\n\t\t\t\tsource: (Array.isArray(config?.from) ? config.from : config?.from ? [config.from] : []).map((\n\t\t\t\t\tc,\n\t\t\t\t) => c._.through!),\n\t\t\t\ttarget: (Array.isArray(config?.to) ? config.to : config?.to ? [config.to] : []).map((c) => c._.through!),\n\t\t\t};\n\t\t}\n\t\tthis.optional = (config?.optional ?? true) as TOptional;\n\t}\n}\n\nexport type AnyOne = One<string, boolean>;\n\nexport class Many<TTargetTableName extends string> extends Relation<TTargetTableName> {\n\tstatic override readonly [entityKind]: string = 'ManyV2';\n\tdeclare protected $relationBrand: 'ManyV2';\n\n\tpublic override readonly relationType = 'many' as const;\n\n\tconstructor(\n\t\ttables: Schema,\n\t\ttargetTable: SchemaEntry,\n\t\ttargetTableName: TTargetTableName,\n\t\treadonly config: AnyManyConfig | undefined,\n\t) {\n\t\tsuper(targetTable, targetTableName);\n\t\tthis.alias = config?.alias;\n\t\tthis.where = config?.where;\n\t\tif (config?.from) {\n\t\t\tthis.sourceColumns = ((Array.isArray(config.from)\n\t\t\t\t? config.from\n\t\t\t\t: [config.from]) as RelationsBuilderColumnBase[]).map((it: RelationsBuilderColumnBase) => {\n\t\t\t\t\tthis.throughTable ??= it._.through ? tables[it._.through._.tableName]! as SchemaEntry : undefined;\n\t\t\t\t\tthis.sourceColumnTableNames.push(it._.tableName);\n\t\t\t\t\treturn it._.column as Column;\n\t\t\t\t});\n\t\t}\n\t\tif (config?.to) {\n\t\t\tthis.targetColumns = (Array.isArray(config.to)\n\t\t\t\t? config.to\n\t\t\t\t: [config.to]).map((it: RelationsBuilderColumnBase) => {\n\t\t\t\t\tthis.throughTable ??= it._.through ? tables[it._.through._.tableName]! as SchemaEntry : undefined;\n\t\t\t\t\tthis.targetColumnTableNames.push(it._.tableName);\n\t\t\t\t\treturn it._.column as Column;\n\t\t\t\t});\n\t\t}\n\t\tif (this.throughTable) {\n\t\t\tthis.through = {\n\t\t\t\tsource: (Array.isArray(config?.from) ? config.from : config?.from ? [config.from] : []).map((\n\t\t\t\t\tc,\n\t\t\t\t) => c._.through!),\n\t\t\t\ttarget: (Array.isArray(config?.to) ? config.to : config?.to ? [config.to] : []).map((c) => c._.through!),\n\t\t\t};\n\t\t}\n\t}\n}\n\nexport type AnyMany = Many<string>;\n\nexport abstract class AggregatedField<T = unknown> implements SQLWrapper<T> {\n\tstatic readonly [entityKind]: string = 'AggregatedField';\n\n\tdeclare readonly $brand: 'AggregatedField';\n\n\tdeclare readonly _: {\n\t\treadonly data: T;\n\t};\n\n\tprotected table: SchemaEntry | undefined;\n\n\tonTable(table: SchemaEntry) {\n\t\tthis.table = table;\n\n\t\treturn this;\n\t}\n\n\tabstract getSQL(): SQL<T>;\n}\n\nexport class Count extends AggregatedField<number> {\n\tstatic override readonly [entityKind]: string = 'AggregatedFieldCount';\n\n\tdeclare protected $aggregatedFieldBrand: 'Count';\n\n\tprivate query: SQL<number> | undefined;\n\n\tgetSQL(): SQL<number> {\n\t\tif (!this.query) {\n\t\t\tif (!this.table) throw new Error('Table must be set before building aggregate field');\n\t\t\tthis.query = sql`select count(*) as ${sql.identifier('r')} from ${getTableAsAliasSQL(this.table)}`\n\t\t\t\t.mapWith(Number);\n\t\t}\n\n\t\treturn this.query;\n\t}\n}\n\nexport type ExtractObjectValues<T> = T[keyof T];\n\nexport const operators = {\n\tand,\n\tbetween,\n\teq,\n\texists,\n\tgt,\n\tgte,\n\tilike,\n\tinArray,\n\tarrayContains,\n\tarrayContained,\n\tarrayOverlaps,\n\tisNull,\n\tisNotNull,\n\tlike,\n\tlt,\n\tlte,\n\tne,\n\tnot,\n\tnotBetween,\n\tnotExists,\n\tnotLike,\n\tnotIlike,\n\tnotInArray,\n\tor,\n\tsql,\n};\n\nexport type Operators = typeof operators;\n\nexport const orderByOperators = {\n\tsql,\n\tasc,\n\tdesc,\n};\n\nexport type OrderByOperators = typeof orderByOperators;\n\nexport function getOrderByOperators(): OrderByOperators {\n\treturn orderByOperators;\n}\n\nexport type FindTargetTableInRelationalConfig<\n\tTConfig extends TablesRelationalConfig,\n\tTRelation extends AnyRelation,\n> = TConfig[TRelation['targetTableName']];\n\nexport interface SQLOperator {\n\tsql: Operators['sql'];\n}\n\nexport type DBQueryConfigColumns<TColumns extends FieldSelection> = {\n\t[K in keyof TColumns]?: boolean | undefined;\n};\n\nexport type DBQueryConfigExtras<TTable extends SchemaEntry> = Record<\n\tstring,\n\t| SQLWrapper\n\t| ((\n\t\ttable: TTable,\n\t\toperators: SQLOperator,\n\t) => SQLWrapper)\n>;\n\nexport type DBQueryConfigOrderByCallback<TTable extends SchemaEntry> = (\n\ttable: TTable,\n\toperators: OrderByOperators,\n) => ValueOrArray<AnyColumn | SQL>;\n\nexport type DBQueryConfigOrderByObject<TColumns extends FieldSelection> = {\n\t[K in keyof TColumns]?: 'asc' | 'desc' | undefined;\n};\n\nexport type DBQueryConfigOrderBy<TTable extends SchemaEntry, TColumns extends FieldSelection> =\n\t| DBQueryConfigOrderByCallback<TTable>\n\t| DBQueryConfigOrderByObject<TColumns>;\n\nexport type DBQueryConfigWith<TSchema extends TablesRelationalConfig, TRelations extends RelationsRecord> = {\n\t[K in keyof TRelations]?:\n\t\t| boolean\n\t\t| (DBQueryConfig<\n\t\t\tTRelations[K]['relationType'],\n\t\t\tTSchema,\n\t\t\tFindTargetTableInRelationalConfig<TSchema, TRelations[K]>\n\t\t>)\n\t\t| undefined;\n};\n\nexport type DBQueryConfig<\n\tTRelationType extends 'one' | 'many' = 'one' | 'many',\n\tTSchema extends TablesRelationalConfig = TablesRelationalConfig,\n\tTTableConfig extends TableRelationalConfig = TableRelationalConfig,\n> =\n\t& (TTableConfig['relations'] extends Record<string, never> ? {}\n\t\t: {\n\t\t\twith?:\n\t\t\t\t| DBQueryConfigWith<TSchema, TTableConfig['relations']>\n\t\t\t\t| undefined;\n\t\t})\n\t& {\n\t\tcolumns?: DBQueryConfigColumns<GetTableViewFieldSelection<TTableConfig['table']>> | undefined;\n\t\twhere?: RelationsFilter<TTableConfig, TSchema> | undefined;\n\t\textras?:\n\t\t\t| DBQueryConfigExtras<TTableConfig['table']>\n\t\t\t| undefined;\n\t\torderBy?:\n\t\t\t| DBQueryConfigOrderBy<TTableConfig['table'], GetTableViewFieldSelection<TTableConfig['table']>>\n\t\t\t| undefined;\n\t\toffset?: number | Placeholder | undefined;\n\t}\n\t& (TRelationType extends 'many' ? {\n\t\t\tlimit?: number | Placeholder | undefined;\n\t\t}\n\t\t: {});\n\nexport type AnyDBQueryConfig = {\n\tcolumns?:\n\t\t| DBQueryConfigColumns<GetTableViewFieldSelection<TableRelationalConfig['table']>>\n\t\t| undefined;\n\twhere?: RelationsFilter<TableRelationalConfig, TablesRelationalConfig> | undefined;\n\textras?:\n\t\t| DBQueryConfigExtras<TableRelationalConfig['table']>\n\t\t| undefined;\n\twith?:\n\t\t| Record<string, AnyDBQueryConfig>\n\t\t| undefined;\n\torderBy?:\n\t\t| DBQueryConfigOrderBy<TableRelationalConfig['table'], GetTableViewFieldSelection<TableRelationalConfig['table']>>\n\t\t| undefined;\n\toffset?: number | Placeholder | undefined;\n\tlimit?: number | Placeholder | undefined;\n};\n\nexport interface TableRelationalConfig {\n\ttable: SchemaEntry;\n\tname: string;\n\trelations: RelationsRecord;\n}\n\nexport type TablesRelationalConfig = Record<string, TableRelationalConfig>;\n\nexport type ExtractTablesWithRelations<\n\tTConfig extends AnyRelationsBuilderConfig,\n\tTTables extends Schema,\n> = {\n\t[K in keyof TTables]: {\n\t\ttable: TTables[K];\n\t\tname: K & string;\n\t\trelations: TConfig extends { [CK in K]: Record<string, any> } ? TConfig[K] : {};\n\t};\n};\n\nexport type ExtractTablesWithRelationsParts<\n\tTConfig extends AnyRelationsBuilderConfig,\n\tTTables extends Schema,\n> = {\n\t[K in NonUndefinedKeysOnly<TConfig> & keyof TTables]: {\n\t\ttable: TTables[K & string];\n\t\tname: K & string;\n\t\trelations: TConfig[K] extends Record<string, any> ? TConfig[K] : {};\n\t};\n};\n\nexport type ReturnTypeOrValue<T> = T extends (...args: any[]) => infer R ? R\n\t: T;\n\nexport type RelationResultKind<TResult, TInclude, TRelation extends AnyRelation> = TRelation extends AnyOne ? (\n\t\t| TResult\n\t\t| (Equal<TRelation['optional'], true> extends true ? null\n\t\t\t: TInclude extends Record<string, unknown> ? TInclude['where'] extends Record<string, any> ? null\n\t\t\t\t: never\n\t\t\t: never)\n\t)\n\t: TResult[];\n\nexport type BuildRelationResult<\n\tTConfig extends TablesRelationalConfig,\n\tTInclude,\n\tTRelations extends RelationsRecord,\n> = {\n\t[\n\t\tK in\n\t\t\t& TruthyKeysOnly<TInclude>\n\t\t\t& keyof TRelations\n\t]: TRelations[K] extends infer TRel extends AnyRelation ? RelationResultKind<\n\t\t\tBuildQueryResult<\n\t\t\t\tTConfig,\n\t\t\t\tFindTargetTableInRelationalConfig<TConfig, TRel>,\n\t\t\t\tAssume<TInclude[K], true | Record<string, unknown>>\n\t\t\t>,\n\t\t\tTInclude[K],\n\t\t\tTRel\n\t\t>\n\t\t: TRelations[K] extends AggregatedField<infer TData> ? TData\n\t\t: never;\n};\n\nexport type NonUndefinedKeysOnly<T> = {\n\t[K in keyof T]: T[K] extends undefined ? never : K;\n}[keyof T];\n\nexport type TruthyKeysOnly<T> = {\n\t[K in keyof T]: T[K] extends undefined | false ? never : K;\n}[keyof T];\n\nexport type InferRelationalQueryTableResult<\n\tTRawSelection extends Record<string, unknown>,\n\tTSelectedFields extends Record<string, unknown> | 'Full' = 'Full',\n> = TSelectedFields extends 'Full' ? TRawSelection : {\n\t[\n\t\tK in Equal<\n\t\t\tExclude<\n\t\t\t\tTSelectedFields[\n\t\t\t\t\t& keyof TSelectedFields\n\t\t\t\t\t& keyof TRawSelection\n\t\t\t\t],\n\t\t\t\tundefined\n\t\t\t>,\n\t\t\tfalse\n\t\t> extends true ? Exclude<\n\t\t\t\tkeyof TRawSelection,\n\t\t\t\tNonUndefinedKeysOnly<TSelectedFields>\n\t\t\t>\n\t\t\t:\n\t\t\t\t& {\n\t\t\t\t\t[K in keyof TSelectedFields]: Equal<\n\t\t\t\t\t\tTSelectedFields[K],\n\t\t\t\t\t\ttrue\n\t\t\t\t\t> extends true ? K\n\t\t\t\t\t\t: never;\n\t\t\t\t}[keyof TSelectedFields]\n\t\t\t\t& keyof TRawSelection\n\t]: TRawSelection[K];\n};\n\nexport type BuildQueryResult<\n\tTSchema extends TablesRelationalConfig,\n\tTTableConfig extends TableRelationalConfig,\n\tTFullSelection extends true | Record<string, unknown>,\n\tTModel extends Record<string, unknown> = Assume<\n\t\tTTableConfig['table'],\n\t\t{ $inferSelect: Record<string, unknown> }\n\t>['$inferSelect'],\n> = Equal<TFullSelection, true> extends true ? Simplify<InferRelationalQueryTableResult<TModel>>\n\t: TFullSelection extends Record<string, unknown> ? Simplify<\n\t\t\t& (InferRelationalQueryTableResult<\n\t\t\t\tTModel,\n\t\t\t\tTFullSelection['columns'] extends Record<string, unknown> ? TFullSelection['columns'] : 'Full'\n\t\t\t>)\n\t\t\t& (TFullSelection['extras'] extends Record<string, SQLWrapper | ((...args: any[]) => SQLWrapper)> ? {\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]: ReturnType<\n\t\t\t\t\t\tAssume<\n\t\t\t\t\t\t\tReturnTypeOrValue<TFullSelection['extras'][K & string]>,\n\t\t\t\t\t\t\tSQLWrapper\n\t\t\t\t\t\t>['getSQL']\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 BuildRelationalQueryResult {\n\tselection: {\n\t\tkey: string;\n\t\tfield: Column<any> | Table | SQL | SQL.Aliased | SQLWrapper | AggregatedField;\n\t\tisArray?: boolean;\n\t\tselection?: BuildRelationalQueryResult['selection'];\n\t\tisOptional?: boolean;\n\t}[];\n\tsql: SQL;\n}\n\nexport function mapRelationalRow(\n\trow: Record<string, unknown>,\n\tbuildQueryResultSelection: BuildRelationalQueryResult['selection'],\n\tmapColumnValue: (value: unknown) => unknown = (value) => value,\n\t/** Needed for SQLite as it returns JSON values as strings */\n\tparseJson: boolean = false,\n\t/** Needed for SingleStore as it returns JSON arrays as strings */\n\tparseJsonIfString: boolean = false,\n\tpath?: string,\n): Record<string, unknown> {\n\tfor (\n\t\tconst selectionItem of buildQueryResultSelection\n\t) {\n\t\tif (selectionItem.selection) {\n\t\t\tconst currentPath = `${path ? `${path}.` : ''}${selectionItem.key}`;\n\n\t\t\tif (row[selectionItem.key] === null) continue;\n\n\t\t\tif (parseJson) row[selectionItem.key] = JSON.parse(row[selectionItem.key] as string);\n\t\t\tif (parseJsonIfString && typeof row[selectionItem.key] === 'string') {\n\t\t\t\trow[selectionItem.key] = JSON.parse(row[selectionItem.key] as string);\n\t\t\t}\n\n\t\t\tif (selectionItem.isArray) {\n\t\t\t\tfor (const item of (row[selectionItem.key] as Array<Record<string, unknown>>)) {\n\t\t\t\t\tmapRelationalRow(\n\t\t\t\t\t\titem,\n\t\t\t\t\t\tselectionItem.selection!,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t\tfalse,\n\t\t\t\t\t\tparseJsonIfString,\n\t\t\t\t\t\tcurrentPath,\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tmapRelationalRow(\n\t\t\t\trow[selectionItem.key] as Record<string, unknown>,\n\t\t\t\tselectionItem.selection!,\n\t\t\t\tmapColumnValue,\n\t\t\t\tfalse,\n\t\t\t\tparseJsonIfString,\n\t\t\t\tcurrentPath,\n\t\t\t);\n\n\t\t\tcontinue;\n\t\t}\n\n\t\tconst field = selectionItem.field!;\n\t\tconst value = mapColumnValue(row[selectionItem.key]);\n\t\tif (value === null) continue;\n\n\t\tlet decoder;\n\t\tif (is(field, Column)) {\n\t\t\tdecoder = field;\n\t\t} else if (is(field, SQL)) {\n\t\t\tdecoder = field.decoder;\n\t\t} else if (is(field, SQL.Aliased)) {\n\t\t\tdecoder = field.sql.decoder;\n\t\t} else {\n\t\t\tdecoder = field.getSQL().decoder;\n\t\t}\n\n\t\trow[selectionItem.key] = 'mapFromJsonValue' in decoder\n\t\t\t? (<(value: unknown) => unknown> decoder.mapFromJsonValue)(value)\n\t\t\t: decoder.mapFromDriverValue(value);\n\t}\n\n\treturn row;\n}\n\nexport class RelationsBuilderTable<TTableName extends string = string> {\n\tstatic readonly [entityKind]: string = 'RelationsBuilderTable';\n\n\tprotected readonly _: {\n\t\treadonly name: TTableName;\n\t\treadonly table: SchemaEntry;\n\t};\n\n\tconstructor(table: SchemaEntry, name: TTableName) {\n\t\tthis._ = {\n\t\t\tname,\n\t\t\ttable,\n\t\t};\n\t}\n}\n\nexport interface RelationsBuilderColumnConfig<\n\tTTableName extends string = string,\n> {\n\treadonly tableName: TTableName;\n\treadonly column: FieldValue;\n\treadonly through?: RelationsBuilderColumnBase;\n\treadonly key: string;\n}\n\nexport interface RelationsBuilderColumnBase<\n\tTTableName extends string = string,\n> {\n\t_: RelationsBuilderColumnConfig<TTableName>;\n}\n\nexport class RelationsBuilderColumn<\n\tTTableName extends string = string,\n> implements RelationsBuilderColumnBase<TTableName> {\n\tstatic readonly [entityKind]: string = 'RelationsBuilderColumn';\n\n\treadonly _: {\n\t\treadonly tableName: TTableName;\n\t\treadonly column: FieldValue;\n\t\treadonly key: string;\n\t};\n\n\tconstructor(\n\t\tcolumn: FieldValue,\n\t\ttableName: TTableName,\n\t\tkey: string,\n\t) {\n\t\tthis._ = {\n\t\t\ttableName: tableName,\n\t\t\tcolumn,\n\t\t\tkey,\n\t\t};\n\t}\n\n\tthrough(column: RelationsBuilderColumn): RelationsBuilderJunctionColumn<TTableName> {\n\t\treturn new RelationsBuilderJunctionColumn(\n\t\t\tthis._.column,\n\t\t\tthis._.tableName,\n\t\t\tthis._.key,\n\t\t\tcolumn,\n\t\t);\n\t}\n}\n\nexport class RelationsBuilderJunctionColumn<\n\tTTableName extends string = string,\n> implements RelationsBuilderColumnBase<TTableName> {\n\tstatic readonly [entityKind]: string = 'RelationsBuilderColumn';\n\n\treadonly _: {\n\t\treadonly tableName: TTableName;\n\t\treadonly column: FieldValue;\n\t\treadonly through: RelationsBuilderColumnBase;\n\t\treadonly key: string;\n\t};\n\n\tconstructor(\n\t\tcolumn: FieldValue,\n\t\ttableName: TTableName,\n\t\tkey: string,\n\t\tthrough: RelationsBuilderColumnBase,\n\t) {\n\t\tthis._ = {\n\t\t\ttableName: tableName,\n\t\t\tcolumn,\n\t\t\tthrough,\n\t\t\tkey,\n\t\t};\n\t}\n}\n\nexport interface RelationFieldsFilterInternals<T> {\n\teq?: T | Placeholder | undefined;\n\tne?: T | Placeholder | undefined;\n\tgt?: T | Placeholder | undefined;\n\tgte?: T | Placeholder | undefined;\n\tlt?: T | Placeholder | undefined;\n\tlte?: T | Placeholder | undefined;\n\tin?: (T | Placeholder)[] | Placeholder | undefined;\n\tnotIn?: (T | Placeholder)[] | Placeholder | undefined;\n\tarrayContains?: (T extends Array<infer E> ? (E | Placeholder)[] : (T | Placeholder)[]) | Placeholder | undefined;\n\tarrayContained?: (T extends Array<infer E> ? (E | Placeholder)[] : (T | Placeholder)[]) | Placeholder | undefined;\n\tarrayOverlaps?: (T extends Array<infer E> ? (E | Placeholder)[] : (T | Placeholder)[]) | Placeholder | undefined;\n\tlike?: string | Placeholder | undefined;\n\tilike?: string | Placeholder | undefined;\n\tnotLike?: string | Placeholder | undefined;\n\tnotIlike?: string | Placeholder | undefined;\n\tisNull?: true | undefined;\n\tisNotNull?: true | undefined;\n\tNOT?: RelationsFieldFilter<T> | undefined;\n\tOR?: RelationsFieldFilter<T>[] | undefined;\n\tAND?: RelationsFieldFilter<T>[] | undefined;\n}\n\nexport type RelationsFieldFilter<T = unknown> =\n\t| RelationFieldsFilterInternals<T>\n\t| (\n\t\tunknown extends T ? never : T extends object ? never : T\n\t)\n\t// Bleeds into filters - discuss removal\n\t| Placeholder;\n\nexport interface RelationsFilterCommons<\n\tTTable extends TableRelationalConfig = TableRelationalConfig,\n\tTSchema extends TablesRelationalConfig = TablesRelationalConfig,\n> {\n\tOR?: RelationsFilter<TTable, TSchema>[] | undefined;\n\tNOT?: RelationsFilter<TTable, TSchema> | undefined;\n\tAND?: RelationsFilter<TTable, TSchema>[] | undefined;\n\tRAW?:\n\t\t| SQLWrapper\n\t\t| ((\n\t\t\ttable: TTable['table'],\n\t\t\toperators: Operators,\n\t\t) => SQL)\n\t\t| undefined;\n}\n\nexport type RelationsFilterColumns<\n\tTColumns extends Record<string, unknown>,\n> = {\n\t[K in keyof TColumns]?:\n\t\t| (TColumns[K] extends { _: { data: infer Data } } ? RelationsFieldFilter<Data>\n\t\t\t: RelationsFieldFilter<unknown>)\n\t\t| undefined;\n};\n\nexport type RelationsFilterRelations<\n\tTTable extends TableRelationalConfig,\n\tTSchema extends TablesRelationalConfig,\n\tTRelations extends RelationsRecord = TTable['relations'],\n> = {\n\t[K in keyof TRelations]?:\n\t\t| boolean\n\t\t| RelationsFilter<FindTargetTableInRelationalConfig<TSchema, TRelations[K]>, TSchema>\n\t\t| undefined;\n};\n\nexport type RelationsFilter<\n\tTTable extends TableRelationalConfig,\n\tTSchema extends TablesRelationalConfig,\n\tTColumns extends FieldSelection = GetTableViewFieldSelection<TTable['table']>,\n> = TTable['relations'] extends Record<string, never> ? TableFilter<TTable['table']>\n\t:\n\t\t& RelationsFilterColumns<TColumns>\n\t\t& RelationsFilterRelations<TTable, TSchema>\n\t\t& RelationsFilterCommons<TTable, TSchema>;\n\nexport interface TableFilterCommons<\n\tTTable extends SchemaEntry = SchemaEntry,\n\tTColumns extends Record<string, unknown> = GetTableViewColumns<TTable>,\n> {\n\tOR?: TableFilter<TTable, TColumns>[] | undefined;\n\tNOT?: TableFilter<TTable, TColumns> | undefined;\n\tAND?: TableFilter<TTable, TColumns>[] | undefined;\n\tRAW?:\n\t\t| SQLWrapper\n\t\t| ((\n\t\t\ttable: TTable,\n\t\t\toperators: Operators,\n\t\t) => SQL)\n\t\t| undefined;\n}\n\nexport type TableFilterColumns<\n\tTColumns extends Record<string, unknown>,\n> = {\n\t[K in keyof TColumns]?:\n\t\t| (TColumns[K] extends { _: { data: infer Data } } ? RelationsFieldFilter<Data>\n\t\t\t: RelationsFieldFilter<unknown>)\n\t\t| undefined;\n};\n\nexport type TableFilter<\n\tTTable extends SchemaEntry = SchemaEntry,\n\tTColumns extends Record<string, unknown> = GetTableViewColumns<TTable>,\n> =\n\t& TableFilterColumns<TColumns>\n\t& TableFilterCommons<TTable, TColumns>;\n\nexport type AnyRelationsFilter = RelationsFilter<\n\tTableRelationalConfig,\n\tTablesRelationalConfig,\n\tFieldSelection\n>;\n\nexport type AnyTableFilter = TableFilter<\n\tSchemaEntry,\n\tFieldSelection\n>;\n\nexport interface OneConfig<TTargetTable extends SchemaEntry, TOptional extends boolean> {\n\tfrom?: RelationsBuilderColumnBase | [RelationsBuilderColumnBase, ...RelationsBuilderColumnBase[]];\n\tto?: RelationsBuilderColumnBase | [RelationsBuilderColumnBase, ...RelationsBuilderColumnBase[]];\n\twhere?: TableFilter<TTargetTable>;\n\toptional?: TOptional;\n\talias?: string;\n}\n\nexport type AnyOneConfig = OneConfig<\n\tSchemaEntry,\n\tboolean\n>;\n\nexport interface ManyConfig<TTargetTable extends SchemaEntry> {\n\tfrom?: RelationsBuilderColumnBase | [RelationsBuilderColumnBase, ...RelationsBuilderColumnBase[]];\n\tto?: RelationsBuilderColumnBase | [RelationsBuilderColumnBase, ...RelationsBuilderColumnBase[]];\n\twhere?: TableFilter<TTargetTable>;\n\talias?: string;\n}\n\nexport type AnyManyConfig = ManyConfig<SchemaEntry>;\n\nexport interface OneFn<TTargetTable extends SchemaEntry, TTargetTableName extends string> {\n\t<TOptional extends boolean = true>(config?: OneConfig<TTargetTable, TOptional>): One<TTargetTableName, TOptional>;\n}\n\nexport interface ManyFn<TTargetTable extends SchemaEntry, TTargetTableName extends string> {\n\t(config?: ManyConfig<TTargetTable>): Many<TTargetTableName>;\n}\n\nexport class RelationsHelperStatic<TTables extends Schema> {\n\tstatic readonly [entityKind]: string = 'RelationsHelperStatic';\n\t// declare readonly $brand: 'RelationsHelperStatic';\n\n\tprivate readonly _: {\n\t\treadonly tables: TTables;\n\t};\n\n\tconstructor(tables: TTables) {\n\t\tthis._ = {\n\t\t\ttables,\n\t\t};\n\n\t\tconst one: Record<string, OneFn<TTables[string], string>> = {};\n\t\tconst many: Record<string, ManyFn<TTables[string], string>> = {};\n\n\t\tfor (const [tableName, table] of Object.entries(tables)) {\n\t\t\tone[tableName] = (config) => {\n\t\t\t\treturn new One(tables, table, tableName, config as unknown as AnyOneConfig);\n\t\t\t};\n\n\t\t\tmany[tableName] = (config) => {\n\t\t\t\treturn new Many(tables, table, tableName, config as AnyManyConfig);\n\t\t\t};\n\t\t}\n\n\t\tthis.one = one as any as this['one'];\n\t\tthis.many = many as any as this['many'];\n\t}\n\n\tone: {\n\t\t[K in keyof TTables]: TTables[K] extends FilteredSchemaEntry ? OneFn<TTables[K], K & string>\n\t\t\t: DrizzleTypeError<'Views with nested selections are not supported by the relational query builder'>;\n\t};\n\n\tmany: {\n\t\t[K in keyof TTables]: TTables[K] extends FilteredSchemaEntry ? ManyFn<TTables[K], K & string>\n\t\t\t: DrizzleTypeError<'Views with nested selections are not supported by the relational query builder'>;\n\t};\n\n\t/** @internal - to be reworked */\n\taggs = {\n\t\tcount(): Count {\n\t\t\treturn new Count();\n\t\t},\n\t};\n}\n\nexport type RelationsBuilderColumns<TTable extends SchemaEntry, TTableName extends string> = {\n\t[\n\t\tTColumnName in keyof GetTableViewColumns<TTable>\n\t]: RelationsBuilderColumn<\n\t\tTTableName\n\t>;\n};\n\nexport type RelationsBuilderTables<TSchema extends Schema> = {\n\t[TTableName in keyof TSchema]: TSchema[TTableName] extends FilteredSchemaEntry ? (\n\t\t\t& RelationsBuilderColumns<TSchema[TTableName], TTableName & string>\n\t\t\t& RelationsBuilderTable<TTableName & string>\n\t\t)\n\t\t: DrizzleTypeError<'Views with nested selections are not supported by the relational query builder'>;\n};\n\nexport type RelationsBuilder<TSchema extends Schema> =\n\t& RelationsBuilderTables<TSchema>\n\t& RelationsHelperStatic<TSchema>;\n\nexport type RelationsBuilderConfigValue =\n\t| RelationsRecord\n\t| undefined;\n\nexport type RelationsBuilderConfig<TTables extends Schema> = {\n\t[TTableName in keyof TTables]?: RelationsBuilderConfigValue;\n};\n\nexport type AnyRelationsBuilderConfig = Record<string, RelationsBuilderConfigValue>;\n\nexport type ExtractTablesFromSchema<TSchema extends Record<string, unknown>> = Assume<\n\t{\n\t\t[K in keyof TSchema as TSchema[K] extends SchemaEntry ? K extends string ? K : never : never]: TSchema[K];\n\t},\n\tSchema\n>;\n\nexport function createRelationsHelper<\n\tTTables extends Schema,\n>(tables: TTables): RelationsBuilder<TTables> {\n\tconst helperStatic = new RelationsHelperStatic(tables);\n\tconst relationsTables = Object.entries(tables).reduce<Record<string, RelationsBuilderTable>>((acc, [tKey, value]) => {\n\t\tconst rTable = new RelationsBuilderTable(value, tKey);\n\t\tconst columns = Object.entries(value[TableColumns]).reduce<\n\t\t\tRecord<string, RelationsBuilderColumnBase>\n\t\t>(\n\t\t\t(acc, [cKey, column]) => {\n\t\t\t\tconst rbColumn = new RelationsBuilderColumn(column as FieldValue, tKey, cKey);\n\t\t\t\tacc[cKey] = rbColumn;\n\t\t\t\treturn acc;\n\t\t\t},\n\t\t\t{},\n\t\t);\n\n\t\tacc[tKey] = Object.assign(rTable, columns);\n\n\t\treturn acc;\n\t}, {});\n\n\treturn Object.assign(helperStatic, relationsTables) as any;\n}\n\nexport function extractTablesFromSchema<TSchema extends Record<string, unknown>>(\n\tschema: TSchema,\n): ExtractTablesFromSchema<TSchema> {\n\treturn Object.fromEntries(\n\t\tObject.entries(schema).filter(([_, e]) => is(e, Table) || is(e, View)),\n\t) as ExtractTablesFromSchema<TSchema>;\n}\n\nexport type IncludeEveryTable<TTables extends Schema> = { [K in keyof TTables]: {} };\n\n/** Builds relational config for every table in schema */\nexport function defineRelations<\n\tTSchema extends Record<string, unknown>,\n\tTTables extends Schema = ExtractTablesFromSchema<TSchema>,\n>(\n\tschema: TSchema,\n): ExtractTablesWithRelations<{}, TTables>;\n/** Builds relational config for every table in schema */\nexport function defineRelations<\n\tTSchema extends Record<string, unknown>,\n\tTConfig extends RelationsBuilderConfig<TTables>,\n\tTTables extends Schema = ExtractTablesFromSchema<TSchema>,\n>(\n\tschema: TSchema,\n\trelations: (helpers: RelationsBuilder<TTables>) => TConfig,\n): ExtractTablesWithRelations<TConfig, TTables>;\nexport function defineRelations(\n\tschema: Record<string, unknown>,\n\trelations?: (helpers: RelationsBuilder<Schema>) => AnyRelationsBuilderConfig,\n): TablesRelationalConfig {\n\tconst tables = extractTablesFromSchema(schema);\n\tconst config = relations\n\t\t? relations(\n\t\t\tcreateRelationsHelper(tables) as RelationsBuilder<Schema>,\n\t\t)\n\t\t: {};\n\n\treturn buildRelations(tables, config);\n}\n\n/** Builds relational config for every table in schema */\nexport function defineRelationsPart<\n\tTSchema extends Record<string, unknown>,\n\tTTables extends Schema = ExtractTablesFromSchema<TSchema>,\n>(\n\tschema: TSchema,\n): ExtractTablesWithRelationsParts<IncludeEveryTable<TTables>, TTables>;\n/** Builds relational config only for tables present in relational config */\nexport function defineRelationsPart<\n\tTSchema extends Record<string, unknown>,\n\tTConfig extends RelationsBuilderConfig<TTables>,\n\tTTables extends Schema = ExtractTablesFromSchema<TSchema>,\n>(\n\tschema: TSchema,\n\trelations: (helpers: RelationsBuilder<TTables>) => TConfig,\n): ExtractTablesWithRelationsParts<TConfig, TTables>;\nexport function defineRelationsPart(\n\tschema: Record<string, unknown>,\n\trelations?: (helpers: RelationsBuilder<Schema>) => AnyRelationsBuilderConfig,\n): TablesRelationalConfig {\n\tconst tables = extractTablesFromSchema(schema);\n\tconst config = relations\n\t\t? relations(\n\t\t\tcreateRelationsHelper(tables) as RelationsBuilder<Schema>,\n\t\t)\n\t\t: Object.fromEntries(Object.keys(tables).map((k) => [k, {}])) as AnyRelationsBuilderConfig;\n\n\treturn buildRelationsParts(tables, config);\n}\n\nexport interface WithContainer {\n\twith?: Record<string, boolean | AnyDBQueryConfig | undefined>;\n}\n\nexport interface ColumnWithTSName {\n\tcolumn: Column<any> | SQL | SQLWrapper | SQL.Aliased;\n\ttsName: string;\n}\n\nexport type RelationsOrder<TColumns extends FieldSelection> = {\n\t[K in keyof TColumns]?: 'asc' | 'desc';\n};\n\nexport type OrderBy = Exclude<AnyDBQueryConfig['orderBy'], undefined>;\n\nexport type Extras = Exclude<AnyDBQueryConfig['extras'], undefined>;\n\n/** @internal */\nexport function fieldSelectionToSQL(table: SchemaEntry, target: string) {\n\tconst field = table[TableColumns][target];\n\n\treturn field\n\t\t? is(field, Column)\n\t\t\t? field\n\t\t\t: is(field, SQL.Aliased)\n\t\t\t? sql`${table}.${sql.identifier(field.fieldAlias)}`\n\t\t\t: sql`${table}.${sql.identifier(target)}`\n\t\t: sql`${table}.${sql.identifier(target)}`;\n}\n\nfunction relationsFieldFilterToSQL(column: SQLWrapper, filter: RelationsFieldFilter<unknown>): SQL | undefined {\n\tif (typeof filter !== 'object' || is(filter, Placeholder)) return eq(column, filter);\n\n\tconst entries = Object.entries(filter as RelationFieldsFilterInternals<unknown>);\n\tif (!entries.length) return undefined;\n\n\tconst parts: (SQL)[] = [];\n\tfor (const [target, value] of entries) {\n\t\tif (value === undefined) continue;\n\n\t\tswitch (target as keyof RelationFieldsFilterInternals<unknown>) {\n\t\t\tcase 'NOT': {\n\t\t\t\tconst res = relationsFieldFilterToSQL(column, value as RelationsFieldFilter<unknown>);\n\t\t\t\tif (!res) continue;\n\n\t\t\t\tparts.push(not(res));\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tcase 'OR': {\n\t\t\t\tif (!(value as RelationsFieldFilter<unknown>[]).length) continue;\n\n\t\t\t\tparts.push(\n\t\t\t\t\tor(\n\t\t\t\t\t\t...(value as AnyRelationsFilter[]).map((subFilter) => relationsFieldFilterToSQL(column, subFilter)),\n\t\t\t\t\t)!,\n\t\t\t\t);\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tcase 'AND': {\n\t\t\t\tif (!(value as RelationsFieldFilter<unknown>[]).length) continue;\n\n\t\t\t\tparts.push(\n\t\t\t\t\tand(\n\t\t\t\t\t\t...(value as AnyRelationsFilter[]).map((subFilter) => relationsFieldFilterToSQL(column, subFilter)),\n\t\t\t\t\t)!,\n\t\t\t\t);\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tcase 'isNotNull':\n\t\t\tcase 'isNull': {\n\t\t\t\tif (!value) continue;\n\n\t\t\t\tparts.push(operators[target as 'isNull' | 'isNotNull'](column));\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tcase 'in': {\n\t\t\t\tparts.push(operators.inArray(column, value as any[] | Placeholder));\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tcase 'notIn': {\n\t\t\t\tparts.push(operators.notInArray(column, value as any[] | Placeholder));\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tdefault: {\n\t\t\t\tparts.push(\n\t\t\t\t\t(operators[target as keyof typeof operators] as ((col: SQLWrapper, data: any) => SQL | undefined))(\n\t\t\t\t\t\tcolumn,\n\t\t\t\t\t\tvalue,\n\t\t\t\t\t)!,\n\t\t\t\t);\n\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t}\n\t}\n\n\tif (!parts.length) return undefined;\n\n\treturn and(...parts);\n}\n\nexport function relationsFilterToSQL(\n\ttable: SchemaEntry,\n\tfilter: AnyRelationsFilter | AnyTableFilter,\n): SQL | undefined;\nexport function relationsFilterToSQL(\n\ttable: SchemaEntry,\n\tfilter: AnyRelationsFilter | AnyTableFilter,\n\ttableRelations: RelationsRecord,\n\ttablesRelations: TablesRelationalConfig,\n\tcasing: CasingCache,\n\tdepth?: number,\n): SQL | undefined;\nexport function relationsFilterToSQL(\n\ttable: SchemaEntry,\n\tfilter: AnyRelationsFilter | AnyTableFilter,\n\ttableRelations: RelationsRecord = {},\n\ttablesRelations: TablesRelationalConfig = {},\n\tcasing?: CasingCache,\n\tdepth: number = 0,\n): SQL | undefined {\n\tconst entries = Object.entries(filter);\n\tif (!entries.length) return undefined;\n\n\tconst parts: SQL[] = [];\n\tfor (const [target, value] of entries) {\n\t\tif (value === undefined) continue;\n\n\t\tswitch (target) {\n\t\t\tcase 'RAW': {\n\t\t\t\tconst processed = typeof value === 'function'\n\t\t\t\t\t? (value as unknown as (table: FieldSelection, operators: Operators) => SQL)(table as any, operators)\n\t\t\t\t\t: (value as SQLWrapper).getSQL();\n\n\t\t\t\tparts.push(processed);\n\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\tcase 'OR': {\n\t\t\t\tif (!(value as AnyRelationsFilter[] | undefined)?.length) continue;\n\n\t\t\t\tparts.push(\n\t\t\t\t\tor(\n\t\t\t\t\t\t...(value as AnyRelationsFilter[]).map((subFilter) =>\n\t\t\t\t\t\t\trelationsFilterToSQL(table, subFilter, tableRelations, tablesRelations, casing!, depth)\n\t\t\t\t\t\t),\n\t\t\t\t\t)!,\n\t\t\t\t);\n\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\tcase 'AND': {\n\t\t\t\tif (!(value as AnyRelationsFilter[] | undefined)?.length) continue;\n\n\t\t\t\tparts.push(\n\t\t\t\t\tand(\n\t\t\t\t\t\t...(value as AnyRelationsFilter[]).map((subFilter) =>\n\t\t\t\t\t\t\trelationsFilterToSQL(table, subFilter, tableRelations, tablesRelations, casing!, depth)\n\t\t\t\t\t\t),\n\t\t\t\t\t)!,\n\t\t\t\t);\n\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\tcase 'NOT': {\n\t\t\t\tif (value === undefined) continue;\n\n\t\t\t\tconst built = relationsFilterToSQL(\n\t\t\t\t\ttable,\n\t\t\t\t\tvalue as AnyRelationsFilter,\n\t\t\t\t\ttableRelations,\n\t\t\t\t\ttablesRelations,\n\t\t\t\t\tcasing!,\n\t\t\t\t\tdepth,\n\t\t\t\t);\n\t\t\t\tif (!built) continue;\n\n\t\t\t\tparts.push(not(built));\n\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\tdefault: {\n\t\t\t\tif (table[TableColumns][target]) {\n\t\t\t\t\tconst column = fieldSelectionToSQL(table, target);\n\n\t\t\t\t\tconst colFilter = relationsFieldFilterToSQL(\n\t\t\t\t\t\tcolumn,\n\t\t\t\t\t\tvalue as RelationsFieldFilter,\n\t\t\t\t\t);\n\t\t\t\t\tif (colFilter) parts.push(colFilter);\n\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst relation = tableRelations[target];\n\t\t\t\tif (!relation) {\n\t\t\t\t\t// Should never trigger unless the types've been violated\n\t\t\t\t\tthrow new DrizzleError({\n\t\t\t\t\t\tmessage: `Unknown relational filter field: \"${target}\"`,\n\t\t\t\t\t});\n\t\t\t\t}\n\n\t\t\t\tconst targetTable = aliasedTable(relation.targetTable, `f${depth}`);\n\t\t\t\tconst throughTable = relation.throughTable ? aliasedTable(relation.throughTable, `ft${depth}`) : undefined;\n\t\t\t\tconst targetConfig = tablesRelations[relation.targetTableName]!;\n\n\t\t\t\tconst {\n\t\t\t\t\tfilter: relationFilter,\n\t\t\t\t\tjoinCondition,\n\t\t\t\t} = relationToSQL(casing!, relation, table, targetTable, throughTable);\n\t\t\t\tconst subfilter = typeof value === 'boolean' ? undefined : relationsFilterToSQL(\n\t\t\t\t\ttargetTable,\n\t\t\t\t\tvalue as AnyRelationsFilter,\n\t\t\t\t\ttargetConfig.relations,\n\t\t\t\t\ttablesRelations,\n\t\t\t\t\tcasing!,\n\t\t\t\t\tdepth + 1,\n\t\t\t\t);\n\t\t\t\tconst filter = and(\n\t\t\t\t\trelationFilter,\n\t\t\t\t\tsubfilter,\n\t\t\t\t);\n\n\t\t\t\tconst subquery = throughTable\n\t\t\t\t\t? sql`(select * from ${getTableAsAliasSQL(targetTable)} inner join ${\n\t\t\t\t\t\tgetTableAsAliasSQL(throughTable)\n\t\t\t\t\t} on ${joinCondition}${sql` where ${filter}`.if(filter)} limit 1)`\n\t\t\t\t\t: sql`(select * from ${getTableAsAliasSQL(targetTable)}${sql` where ${filter}`.if(filter)} limit 1)`;\n\t\t\t\tif (filter) parts.push((value ? exists : notExists)(subquery));\n\t\t\t}\n\t\t}\n\t}\n\n\treturn and(...parts)!;\n}\n\nexport function relationsOrderToSQL(\n\ttable: SchemaEntry,\n\torders: OrderBy,\n): SQL | undefined {\n\tif (typeof orders === 'function') {\n\t\tconst data = orders(table as any, orderByOperators);\n\n\t\treturn is(data, SQL)\n\t\t\t? data\n\t\t\t: Array.isArray(data)\n\t\t\t? data.length\n\t\t\t\t? sql.join(data.map((o) => is(o, SQL) ? o : asc(o)), sql`, `)\n\t\t\t\t: undefined\n\t\t\t: is(data, Column)\n\t\t\t? asc(data)\n\t\t\t: undefined;\n\t}\n\n\tconst entries = Object.entries(orders).filter(([_, value]) => value);\n\tif (!entries.length) return undefined;\n\n\treturn sql.join(\n\t\tentries.map(([target, value]) => (value === 'asc' ? asc : desc)(fieldSelectionToSQL(table, target))),\n\t\tsql`, `,\n\t);\n}\n\nexport function relationExtrasToSQL(\n\ttable: SchemaEntry,\n\textras: Extras,\n) {\n\tconst subqueries: SQL[] = [];\n\tconst selection: BuildRelationalQueryResult['selection'] = [];\n\n\tfor (\n\t\tconst [key, field] of Object.entries(extras)\n\t) {\n\t\tif (!field) continue;\n\t\tconst extra = typeof field === 'function' ? field(table as any, { sql: operators.sql }) : field;\n\n\t\tconst query = sql`(${extra.getSQL()}) as ${sql.identifier(key)}`;\n\n\t\tquery.decoder = extra.getSQL().decoder;\n\n\t\tsubqueries.push(query);\n\t\tselection.push({\n\t\t\tkey,\n\t\t\tfield: query,\n\t\t});\n\t}\n\n\treturn {\n\t\tsql: subqueries.length ? sql.join(subqueries, sql`, `) : undefined,\n\t\tselection,\n\t};\n}\n\nexport interface BuiltRelationFilters {\n\tfilter?: SQL;\n\tjoinCondition?: SQL;\n}\n\nexport function relationToSQL(\n\tcasing: CasingCache,\n\trelation: Relation,\n\tsourceTable: SchemaEntry,\n\ttargetTable: SchemaEntry,\n\tthroughTable?: SchemaEntry,\n): BuiltRelationFilters {\n\tif (relation.through) {\n\t\tconst outerColumnWhere = relation.sourceColumns.map((s, i) => {\n\t\t\tconst t = relation.through!.source[i]!;\n\n\t\t\treturn eq(\n\t\t\t\tsql`${sourceTable}.${sql.identifier(casing.getColumnCasing(s))}`,\n\t\t\t\tsql`${throughTable!}.${sql.identifier(is(t._.column, Column) ? casing.getColumnCasing(t._.column) : t._.key)}`,\n\t\t\t);\n\t\t});\n\n\t\tconst innerColumnWhere = relation.targetColumns.map((s, i) => {\n\t\t\tconst t = relation.through!.target[i]!;\n\n\t\t\treturn eq(\n\t\t\t\tsql`${throughTable!}.${sql.identifier(is(t._.column, Column) ? casing.getColumnCasing(t._.column) : t._.key)}`,\n\t\t\t\tsql`${targetTable}.${sql.identifier(casing.getColumnCasing(s))}`,\n\t\t\t);\n\t\t});\n\n\t\treturn {\n\t\t\tfilter: and(\n\t\t\t\trelation.where\n\t\t\t\t\t? relationsFilterToSQL(relation.isReversed ? sourceTable : targetTable, relation.where)\n\t\t\t\t\t: undefined,\n\t\t\t\t...outerColumnWhere,\n\t\t\t),\n\t\t\tjoinCondition: and(...innerColumnWhere),\n\t\t};\n\t}\n\n\tconst columnWhere = relation.sourceColumns.map((s, i) => {\n\t\tconst t = relation.targetColumns[i]!;\n\n\t\treturn eq(\n\t\t\tsql`${sourceTable}.${sql.identifier(casing.getColumnCasing(s))}`,\n\t\t\tsql`${targetTable}.${sql.identifier(casing.getColumnCasing(t))}`,\n\t\t);\n\t});\n\n\tconst fullWhere = and(\n\t\t...columnWhere,\n\t\trelation.where\n\t\t\t? relationsFilterToSQL(relation.isReversed ? sourceTable : targetTable, relation.where)\n\t\t\t: undefined,\n\t)!;\n\n\treturn { filter: fullWhere };\n}\n\nexport function getTableAsAliasSQL(table: SchemaEntry) {\n\treturn sql`${\n\t\ttable[IsAlias]\n\t\t\t? sql`${sql`${sql.identifier(table[TableSchema] ?? '')}.`.if(table[TableSchema])}${\n\t\t\t\tsql.identifier(table[OriginalName])\n\t\t\t} as ${table}`\n\t\t\t: table\n\t}`;\n}\n"],"mappings":"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","names":["acc","filter"]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/singlestore-core/columns/bigint.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { SingleStoreColumnBuilderWithAutoIncrement, SingleStoreColumnWithAutoIncrement } from './common.ts';\n\nexport class SingleStoreBigInt53Builder<TUnsigned extends boolean | undefined>\n\textends SingleStoreColumnBuilderWithAutoIncrement<{\n\t\tdataType: Equal<TUnsigned, true> extends true ? 'number uint53' : 'number int53';\n\t\tdata: number;\n\t\tdriverParam: number | string;\n\t}, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt53Builder';\n\n\tconstructor(name: string, unsigned: boolean = false) {\n\t\tsuper(name, unsigned ? 'number uint53' : 'number int53' as any, 'SingleStoreBigInt53');\n\t\tthis.config.unsigned = unsigned;\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBigInt53(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBigInt53<T extends ColumnBaseConfig<'number int53' | 'number uint53'>>\n\textends SingleStoreColumnWithAutoIncrement<T, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt53';\n\n\tgetSQLType(): string {\n\t\treturn `bigint${this.config.unsigned ? ' unsigned' : ''}`;\n\t}\n\n\toverride mapFromDriverValue(value: number | string): number {\n\t\tif (typeof value === 'number') {\n\t\t\treturn value;\n\t\t}\n\t\treturn Number(value);\n\t}\n}\n\nexport class SingleStoreBigInt64Builder<TUnsigned extends boolean | undefined>\n\textends SingleStoreColumnBuilderWithAutoIncrement<{\n\t\tdataType: Equal<TUnsigned, true> extends true ? 'bigint uint64' : 'bigint int64';\n\t\tdata: bigint;\n\t\tdriverParam: string;\n\t}, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt64Builder';\n\n\tconstructor(name: string, unsigned: boolean = false) {\n\t\tsuper(name, unsigned ? 'bigint uint64' : 'bigint int64' as any, 'SingleStoreBigInt64');\n\t\tthis.config.unsigned = unsigned;\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBigInt64(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBigInt64<T extends ColumnBaseConfig<'bigint int64' | 'bigint uint64'>>\n\textends SingleStoreColumnWithAutoIncrement<T, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt64';\n\n\tgetSQLType(): string {\n\t\treturn `bigint${this.config.unsigned ? ' unsigned' : ''}`;\n\t}\n\n\t// eslint-disable-next-line unicorn/prefer-native-coercion-functions\n\toverride mapFromDriverValue(value: string): bigint {\n\t\treturn BigInt(value);\n\t}\n}\n\nexport interface SingleStoreBigIntConfig<\n\tT extends 'number' | 'bigint' = 'number' | 'bigint',\n\tTUnsigned extends boolean | undefined = boolean | undefined,\n> {\n\tmode: T;\n\tunsigned?: TUnsigned;\n}\n\nexport function bigint<TMode extends SingleStoreBigIntConfig['mode'], TUnsigned extends boolean | undefined>(\n\tconfig: SingleStoreBigIntConfig<TMode, TUnsigned>,\n): TMode extends 'number' ? SingleStoreBigInt53Builder<TUnsigned> : SingleStoreBigInt64Builder<TUnsigned>;\nexport function bigint<TMode extends SingleStoreBigIntConfig['mode'], TUnsigned extends boolean | undefined>(\n\tname: string,\n\tconfig: SingleStoreBigIntConfig<TMode, TUnsigned>,\n): TMode extends 'number' ? SingleStoreBigInt53Builder<TUnsigned> : SingleStoreBigInt64Builder<TUnsigned>;\nexport function bigint(a?: string | SingleStoreBigIntConfig, b?: SingleStoreBigIntConfig) {\n\tconst { name, config } = getColumnNameAndConfig<SingleStoreBigIntConfig>(a, b);\n\tif (config.mode === 'number') {\n\t\treturn new SingleStoreBigInt53Builder(name, config.unsigned);\n\t}\n\treturn new SingleStoreBigInt64Builder(name, config.unsigned);\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,mBAAmD;AACnD,oBAA8F;AAEvF,MAAM,mCACJ,wDAKT;AAAA,EACC,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,WAAoB,OAAO;AACpD,UAAM,MAAM,WAAW,kBAAkB,gBAAuB,qBAAqB;AACrF,SAAK,OAAO,WAAW;AAAA,EACxB;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,4BACJ,iDACT;AAAA,EACC,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO,SAAS,KAAK,OAAO,WAAW,cAAc,EAAE;AAAA,EACxD;AAAA,EAES,mBAAmB,OAAgC;AAC3D,QAAI,OAAO,UAAU,UAAU;AAC9B,aAAO;AAAA,IACR;AACA,WAAO,OAAO,KAAK;AAAA,EACpB;AACD;AAEO,MAAM,mCACJ,wDAKT;AAAA,EACC,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,WAAoB,OAAO;AACpD,UAAM,MAAM,WAAW,kBAAkB,gBAAuB,qBAAqB;AACrF,SAAK,OAAO,WAAW;AAAA,EACxB;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,4BACJ,iDACT;AAAA,EACC,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO,SAAS,KAAK,OAAO,WAAW,cAAc,EAAE;AAAA,EACxD;AAAA;AAAA,EAGS,mBAAmB,OAAuB;AAClD,WAAO,OAAO,KAAK;AAAA,EACpB;AACD;AAiBO,SAAS,OAAO,GAAsC,GAA6B;AACzF,QAAM,EAAE,MAAM,OAAO,QAAI,qCAAgD,GAAG,CAAC;AAC7E,MAAI,OAAO,SAAS,UAAU;AAC7B,WAAO,IAAI,2BAA2B,MAAM,OAAO,QAAQ;AAAA,EAC5D;AACA,SAAO,IAAI,2BAA2B,MAAM,OAAO,QAAQ;AAC5D;","names":[]}
1
+ {"version":3,"sources":["../../../src/singlestore-core/columns/bigint.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { SingleStoreColumnBuilderWithAutoIncrement, SingleStoreColumnWithAutoIncrement } from './common.ts';\n\nexport class SingleStoreBigInt53Builder<TUnsigned extends boolean | undefined>\n\textends SingleStoreColumnBuilderWithAutoIncrement<{\n\t\tname: string;\n\t\tdataType: Equal<TUnsigned, true> extends true ? 'number uint53' : 'number int53';\n\t\tdata: number;\n\t\tdriverParam: number | string;\n\t}, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt53Builder';\n\n\tconstructor(name: string, unsigned: boolean = false) {\n\t\tsuper(name, unsigned ? 'number uint53' : 'number int53' as any, 'SingleStoreBigInt53');\n\t\tthis.config.unsigned = unsigned;\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBigInt53(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBigInt53<T extends ColumnBaseConfig<'number int53' | 'number uint53'>>\n\textends SingleStoreColumnWithAutoIncrement<T, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt53';\n\n\tgetSQLType(): string {\n\t\treturn `bigint${this.config.unsigned ? ' unsigned' : ''}`;\n\t}\n\n\toverride mapFromDriverValue(value: number | string): number {\n\t\tif (typeof value === 'number') {\n\t\t\treturn value;\n\t\t}\n\t\treturn Number(value);\n\t}\n}\n\nexport class SingleStoreBigInt64Builder<TUnsigned extends boolean | undefined>\n\textends SingleStoreColumnBuilderWithAutoIncrement<{\n\t\tname: string;\n\t\tdataType: Equal<TUnsigned, true> extends true ? 'bigint uint64' : 'bigint int64';\n\t\tdata: bigint;\n\t\tdriverParam: string;\n\t}, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt64Builder';\n\n\tconstructor(name: string, unsigned: boolean = false) {\n\t\tsuper(name, unsigned ? 'bigint uint64' : 'bigint int64' as any, 'SingleStoreBigInt64');\n\t\tthis.config.unsigned = unsigned;\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBigInt64(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBigInt64<T extends ColumnBaseConfig<'bigint int64' | 'bigint uint64'>>\n\textends SingleStoreColumnWithAutoIncrement<T, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt64';\n\n\tgetSQLType(): string {\n\t\treturn `bigint${this.config.unsigned ? ' unsigned' : ''}`;\n\t}\n\n\t// eslint-disable-next-line unicorn/prefer-native-coercion-functions\n\toverride mapFromDriverValue(value: string): bigint {\n\t\treturn BigInt(value);\n\t}\n}\n\nexport interface SingleStoreBigIntConfig<\n\tT extends 'number' | 'bigint' = 'number' | 'bigint',\n\tTUnsigned extends boolean | undefined = boolean | undefined,\n> {\n\tmode: T;\n\tunsigned?: TUnsigned;\n}\n\nexport function bigint<TMode extends SingleStoreBigIntConfig['mode'], TUnsigned extends boolean | undefined>(\n\tconfig: SingleStoreBigIntConfig<TMode, TUnsigned>,\n): TMode extends 'number' ? SingleStoreBigInt53Builder<TUnsigned> : SingleStoreBigInt64Builder<TUnsigned>;\nexport function bigint<TMode extends SingleStoreBigIntConfig['mode'], TUnsigned extends boolean | undefined>(\n\tname: string,\n\tconfig: SingleStoreBigIntConfig<TMode, TUnsigned>,\n): TMode extends 'number' ? SingleStoreBigInt53Builder<TUnsigned> : SingleStoreBigInt64Builder<TUnsigned>;\nexport function bigint(a?: string | SingleStoreBigIntConfig, b?: SingleStoreBigIntConfig) {\n\tconst { name, config } = getColumnNameAndConfig<SingleStoreBigIntConfig>(a, b);\n\tif (config.mode === 'number') {\n\t\treturn new SingleStoreBigInt53Builder(name, config.unsigned);\n\t}\n\treturn new SingleStoreBigInt64Builder(name, config.unsigned);\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,mBAAmD;AACnD,oBAA8F;AAEvF,MAAM,mCACJ,wDAMT;AAAA,EACC,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,WAAoB,OAAO;AACpD,UAAM,MAAM,WAAW,kBAAkB,gBAAuB,qBAAqB;AACrF,SAAK,OAAO,WAAW;AAAA,EACxB;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,4BACJ,iDACT;AAAA,EACC,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO,SAAS,KAAK,OAAO,WAAW,cAAc,EAAE;AAAA,EACxD;AAAA,EAES,mBAAmB,OAAgC;AAC3D,QAAI,OAAO,UAAU,UAAU;AAC9B,aAAO;AAAA,IACR;AACA,WAAO,OAAO,KAAK;AAAA,EACpB;AACD;AAEO,MAAM,mCACJ,wDAMT;AAAA,EACC,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,WAAoB,OAAO;AACpD,UAAM,MAAM,WAAW,kBAAkB,gBAAuB,qBAAqB;AACrF,SAAK,OAAO,WAAW;AAAA,EACxB;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,4BACJ,iDACT;AAAA,EACC,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO,SAAS,KAAK,OAAO,WAAW,cAAc,EAAE;AAAA,EACxD;AAAA;AAAA,EAGS,mBAAmB,OAAuB;AAClD,WAAO,OAAO,KAAK;AAAA,EACpB;AACD;AAiBO,SAAS,OAAO,GAAsC,GAA6B;AACzF,QAAM,EAAE,MAAM,OAAO,QAAI,qCAAgD,GAAG,CAAC;AAC7E,MAAI,OAAO,SAAS,UAAU;AAC7B,WAAO,IAAI,2BAA2B,MAAM,OAAO,QAAQ;AAAA,EAC5D;AACA,SAAO,IAAI,2BAA2B,MAAM,OAAO,QAAQ;AAC5D;","names":[]}
@@ -3,6 +3,7 @@ import { entityKind } from "../../entity.cjs";
3
3
  import { type Equal } from "../../utils.cjs";
4
4
  import { SingleStoreColumnBuilderWithAutoIncrement, SingleStoreColumnWithAutoIncrement } from "./common.cjs";
5
5
  export declare class SingleStoreBigInt53Builder<TUnsigned extends boolean | undefined> extends SingleStoreColumnBuilderWithAutoIncrement<{
6
+ name: string;
6
7
  dataType: Equal<TUnsigned, true> extends true ? 'number uint53' : 'number int53';
7
8
  data: number;
8
9
  driverParam: number | string;
@@ -20,6 +21,7 @@ export declare class SingleStoreBigInt53<T extends ColumnBaseConfig<'number int5
20
21
  mapFromDriverValue(value: number | string): number;
21
22
  }
22
23
  export declare class SingleStoreBigInt64Builder<TUnsigned extends boolean | undefined> extends SingleStoreColumnBuilderWithAutoIncrement<{
24
+ name: string;
23
25
  dataType: Equal<TUnsigned, true> extends true ? 'bigint uint64' : 'bigint int64';
24
26
  data: bigint;
25
27
  driverParam: string;
@@ -3,6 +3,7 @@ import { entityKind } from "../../entity.js";
3
3
  import { type Equal } from "../../utils.js";
4
4
  import { SingleStoreColumnBuilderWithAutoIncrement, SingleStoreColumnWithAutoIncrement } from "./common.js";
5
5
  export declare class SingleStoreBigInt53Builder<TUnsigned extends boolean | undefined> extends SingleStoreColumnBuilderWithAutoIncrement<{
6
+ name: string;
6
7
  dataType: Equal<TUnsigned, true> extends true ? 'number uint53' : 'number int53';
7
8
  data: number;
8
9
  driverParam: number | string;
@@ -20,6 +21,7 @@ export declare class SingleStoreBigInt53<T extends ColumnBaseConfig<'number int5
20
21
  mapFromDriverValue(value: number | string): number;
21
22
  }
22
23
  export declare class SingleStoreBigInt64Builder<TUnsigned extends boolean | undefined> extends SingleStoreColumnBuilderWithAutoIncrement<{
24
+ name: string;
23
25
  dataType: Equal<TUnsigned, true> extends true ? 'bigint uint64' : 'bigint int64';
24
26
  data: bigint;
25
27
  driverParam: string;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/singlestore-core/columns/bigint.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { SingleStoreColumnBuilderWithAutoIncrement, SingleStoreColumnWithAutoIncrement } from './common.ts';\n\nexport class SingleStoreBigInt53Builder<TUnsigned extends boolean | undefined>\n\textends SingleStoreColumnBuilderWithAutoIncrement<{\n\t\tdataType: Equal<TUnsigned, true> extends true ? 'number uint53' : 'number int53';\n\t\tdata: number;\n\t\tdriverParam: number | string;\n\t}, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt53Builder';\n\n\tconstructor(name: string, unsigned: boolean = false) {\n\t\tsuper(name, unsigned ? 'number uint53' : 'number int53' as any, 'SingleStoreBigInt53');\n\t\tthis.config.unsigned = unsigned;\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBigInt53(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBigInt53<T extends ColumnBaseConfig<'number int53' | 'number uint53'>>\n\textends SingleStoreColumnWithAutoIncrement<T, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt53';\n\n\tgetSQLType(): string {\n\t\treturn `bigint${this.config.unsigned ? ' unsigned' : ''}`;\n\t}\n\n\toverride mapFromDriverValue(value: number | string): number {\n\t\tif (typeof value === 'number') {\n\t\t\treturn value;\n\t\t}\n\t\treturn Number(value);\n\t}\n}\n\nexport class SingleStoreBigInt64Builder<TUnsigned extends boolean | undefined>\n\textends SingleStoreColumnBuilderWithAutoIncrement<{\n\t\tdataType: Equal<TUnsigned, true> extends true ? 'bigint uint64' : 'bigint int64';\n\t\tdata: bigint;\n\t\tdriverParam: string;\n\t}, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt64Builder';\n\n\tconstructor(name: string, unsigned: boolean = false) {\n\t\tsuper(name, unsigned ? 'bigint uint64' : 'bigint int64' as any, 'SingleStoreBigInt64');\n\t\tthis.config.unsigned = unsigned;\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBigInt64(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBigInt64<T extends ColumnBaseConfig<'bigint int64' | 'bigint uint64'>>\n\textends SingleStoreColumnWithAutoIncrement<T, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt64';\n\n\tgetSQLType(): string {\n\t\treturn `bigint${this.config.unsigned ? ' unsigned' : ''}`;\n\t}\n\n\t// eslint-disable-next-line unicorn/prefer-native-coercion-functions\n\toverride mapFromDriverValue(value: string): bigint {\n\t\treturn BigInt(value);\n\t}\n}\n\nexport interface SingleStoreBigIntConfig<\n\tT extends 'number' | 'bigint' = 'number' | 'bigint',\n\tTUnsigned extends boolean | undefined = boolean | undefined,\n> {\n\tmode: T;\n\tunsigned?: TUnsigned;\n}\n\nexport function bigint<TMode extends SingleStoreBigIntConfig['mode'], TUnsigned extends boolean | undefined>(\n\tconfig: SingleStoreBigIntConfig<TMode, TUnsigned>,\n): TMode extends 'number' ? SingleStoreBigInt53Builder<TUnsigned> : SingleStoreBigInt64Builder<TUnsigned>;\nexport function bigint<TMode extends SingleStoreBigIntConfig['mode'], TUnsigned extends boolean | undefined>(\n\tname: string,\n\tconfig: SingleStoreBigIntConfig<TMode, TUnsigned>,\n): TMode extends 'number' ? SingleStoreBigInt53Builder<TUnsigned> : SingleStoreBigInt64Builder<TUnsigned>;\nexport function bigint(a?: string | SingleStoreBigIntConfig, b?: SingleStoreBigIntConfig) {\n\tconst { name, config } = getColumnNameAndConfig<SingleStoreBigIntConfig>(a, b);\n\tif (config.mode === 'number') {\n\t\treturn new SingleStoreBigInt53Builder(name, config.unsigned);\n\t}\n\treturn new SingleStoreBigInt64Builder(name, config.unsigned);\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAE3B,SAAqB,8BAA8B;AACnD,SAAS,2CAA2C,0CAA0C;AAEvF,MAAM,mCACJ,0CAKT;AAAA,EACC,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,WAAoB,OAAO;AACpD,UAAM,MAAM,WAAW,kBAAkB,gBAAuB,qBAAqB;AACrF,SAAK,OAAO,WAAW;AAAA,EACxB;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,4BACJ,mCACT;AAAA,EACC,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO,SAAS,KAAK,OAAO,WAAW,cAAc,EAAE;AAAA,EACxD;AAAA,EAES,mBAAmB,OAAgC;AAC3D,QAAI,OAAO,UAAU,UAAU;AAC9B,aAAO;AAAA,IACR;AACA,WAAO,OAAO,KAAK;AAAA,EACpB;AACD;AAEO,MAAM,mCACJ,0CAKT;AAAA,EACC,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,WAAoB,OAAO;AACpD,UAAM,MAAM,WAAW,kBAAkB,gBAAuB,qBAAqB;AACrF,SAAK,OAAO,WAAW;AAAA,EACxB;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,4BACJ,mCACT;AAAA,EACC,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO,SAAS,KAAK,OAAO,WAAW,cAAc,EAAE;AAAA,EACxD;AAAA;AAAA,EAGS,mBAAmB,OAAuB;AAClD,WAAO,OAAO,KAAK;AAAA,EACpB;AACD;AAiBO,SAAS,OAAO,GAAsC,GAA6B;AACzF,QAAM,EAAE,MAAM,OAAO,IAAI,uBAAgD,GAAG,CAAC;AAC7E,MAAI,OAAO,SAAS,UAAU;AAC7B,WAAO,IAAI,2BAA2B,MAAM,OAAO,QAAQ;AAAA,EAC5D;AACA,SAAO,IAAI,2BAA2B,MAAM,OAAO,QAAQ;AAC5D;","names":[]}
1
+ {"version":3,"sources":["../../../src/singlestore-core/columns/bigint.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { SingleStoreColumnBuilderWithAutoIncrement, SingleStoreColumnWithAutoIncrement } from './common.ts';\n\nexport class SingleStoreBigInt53Builder<TUnsigned extends boolean | undefined>\n\textends SingleStoreColumnBuilderWithAutoIncrement<{\n\t\tname: string;\n\t\tdataType: Equal<TUnsigned, true> extends true ? 'number uint53' : 'number int53';\n\t\tdata: number;\n\t\tdriverParam: number | string;\n\t}, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt53Builder';\n\n\tconstructor(name: string, unsigned: boolean = false) {\n\t\tsuper(name, unsigned ? 'number uint53' : 'number int53' as any, 'SingleStoreBigInt53');\n\t\tthis.config.unsigned = unsigned;\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBigInt53(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBigInt53<T extends ColumnBaseConfig<'number int53' | 'number uint53'>>\n\textends SingleStoreColumnWithAutoIncrement<T, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt53';\n\n\tgetSQLType(): string {\n\t\treturn `bigint${this.config.unsigned ? ' unsigned' : ''}`;\n\t}\n\n\toverride mapFromDriverValue(value: number | string): number {\n\t\tif (typeof value === 'number') {\n\t\t\treturn value;\n\t\t}\n\t\treturn Number(value);\n\t}\n}\n\nexport class SingleStoreBigInt64Builder<TUnsigned extends boolean | undefined>\n\textends SingleStoreColumnBuilderWithAutoIncrement<{\n\t\tname: string;\n\t\tdataType: Equal<TUnsigned, true> extends true ? 'bigint uint64' : 'bigint int64';\n\t\tdata: bigint;\n\t\tdriverParam: string;\n\t}, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt64Builder';\n\n\tconstructor(name: string, unsigned: boolean = false) {\n\t\tsuper(name, unsigned ? 'bigint uint64' : 'bigint int64' as any, 'SingleStoreBigInt64');\n\t\tthis.config.unsigned = unsigned;\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBigInt64(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBigInt64<T extends ColumnBaseConfig<'bigint int64' | 'bigint uint64'>>\n\textends SingleStoreColumnWithAutoIncrement<T, { unsigned: boolean }>\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreBigInt64';\n\n\tgetSQLType(): string {\n\t\treturn `bigint${this.config.unsigned ? ' unsigned' : ''}`;\n\t}\n\n\t// eslint-disable-next-line unicorn/prefer-native-coercion-functions\n\toverride mapFromDriverValue(value: string): bigint {\n\t\treturn BigInt(value);\n\t}\n}\n\nexport interface SingleStoreBigIntConfig<\n\tT extends 'number' | 'bigint' = 'number' | 'bigint',\n\tTUnsigned extends boolean | undefined = boolean | undefined,\n> {\n\tmode: T;\n\tunsigned?: TUnsigned;\n}\n\nexport function bigint<TMode extends SingleStoreBigIntConfig['mode'], TUnsigned extends boolean | undefined>(\n\tconfig: SingleStoreBigIntConfig<TMode, TUnsigned>,\n): TMode extends 'number' ? SingleStoreBigInt53Builder<TUnsigned> : SingleStoreBigInt64Builder<TUnsigned>;\nexport function bigint<TMode extends SingleStoreBigIntConfig['mode'], TUnsigned extends boolean | undefined>(\n\tname: string,\n\tconfig: SingleStoreBigIntConfig<TMode, TUnsigned>,\n): TMode extends 'number' ? SingleStoreBigInt53Builder<TUnsigned> : SingleStoreBigInt64Builder<TUnsigned>;\nexport function bigint(a?: string | SingleStoreBigIntConfig, b?: SingleStoreBigIntConfig) {\n\tconst { name, config } = getColumnNameAndConfig<SingleStoreBigIntConfig>(a, b);\n\tif (config.mode === 'number') {\n\t\treturn new SingleStoreBigInt53Builder(name, config.unsigned);\n\t}\n\treturn new SingleStoreBigInt64Builder(name, config.unsigned);\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAE3B,SAAqB,8BAA8B;AACnD,SAAS,2CAA2C,0CAA0C;AAEvF,MAAM,mCACJ,0CAMT;AAAA,EACC,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,WAAoB,OAAO;AACpD,UAAM,MAAM,WAAW,kBAAkB,gBAAuB,qBAAqB;AACrF,SAAK,OAAO,WAAW;AAAA,EACxB;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,4BACJ,mCACT;AAAA,EACC,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO,SAAS,KAAK,OAAO,WAAW,cAAc,EAAE;AAAA,EACxD;AAAA,EAES,mBAAmB,OAAgC;AAC3D,QAAI,OAAO,UAAU,UAAU;AAC9B,aAAO;AAAA,IACR;AACA,WAAO,OAAO,KAAK;AAAA,EACpB;AACD;AAEO,MAAM,mCACJ,0CAMT;AAAA,EACC,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,WAAoB,OAAO;AACpD,UAAM,MAAM,WAAW,kBAAkB,gBAAuB,qBAAqB;AACrF,SAAK,OAAO,WAAW;AAAA,EACxB;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,4BACJ,mCACT;AAAA,EACC,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO,SAAS,KAAK,OAAO,WAAW,cAAc,EAAE;AAAA,EACxD;AAAA;AAAA,EAGS,mBAAmB,OAAuB;AAClD,WAAO,OAAO,KAAK;AAAA,EACpB;AACD;AAiBO,SAAS,OAAO,GAAsC,GAA6B;AACzF,QAAM,EAAE,MAAM,OAAO,IAAI,uBAAgD,GAAG,CAAC;AAC7E,MAAI,OAAO,SAAS,UAAU;AAC7B,WAAO,IAAI,2BAA2B,MAAM,OAAO,QAAQ;AAAA,EAC5D;AACA,SAAO,IAAI,2BAA2B,MAAM,OAAO,QAAQ;AAC5D;","names":[]}
@@ -32,6 +32,7 @@ class SingleStoreBinaryBuilder extends import_common.SingleStoreColumnBuilder {
32
32
  super(name, "string binary", "SingleStoreBinary");
33
33
  this.config.length = length ?? 1;
34
34
  this.config.setLength = length !== void 0;
35
+ this.config.isLengthExact = true;
35
36
  }
36
37
  /** @internal */
37
38
  build(table) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/singlestore-core/columns/binary.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport { getColumnNameAndConfig } from '~/utils.ts';\nimport { SingleStoreColumn, SingleStoreColumnBuilder } from './common.ts';\n\nexport class SingleStoreBinaryBuilder extends SingleStoreColumnBuilder<\n\t{\n\t\tdataType: 'string binary';\n\t\tdata: string;\n\t\tdriverParam: string;\n\t},\n\tSingleStoreBinaryConfig & { setLength: boolean }\n> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBinaryBuilder';\n\n\tconstructor(name: string, length: number | undefined) {\n\t\tsuper(name, 'string binary', 'SingleStoreBinary');\n\t\tthis.config.length = length ?? 1;\n\t\tthis.config.setLength = length !== undefined;\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBinary(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBinary<T extends ColumnBaseConfig<'string binary'>> extends SingleStoreColumn<\n\tT,\n\tSingleStoreBinaryConfig & { setLength: boolean }\n> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBinary';\n\n\toverride mapFromDriverValue(value: string | Buffer | Uint8Array): string {\n\t\tif (typeof value === 'string') return value;\n\t\tif (Buffer.isBuffer(value)) return value.toString();\n\n\t\tconst str: string[] = [];\n\t\tfor (const v of value) {\n\t\t\tstr.push(v === 49 ? '1' : '0');\n\t\t}\n\n\t\treturn str.join('');\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.config.setLength ? `binary(${this.length})` : `binary`;\n\t}\n}\n\nexport interface SingleStoreBinaryConfig {\n\tlength?: number;\n}\n\nexport function binary(\n\tconfig?: SingleStoreBinaryConfig,\n): SingleStoreBinaryBuilder;\nexport function binary(\n\tname: string,\n\tconfig?: SingleStoreBinaryConfig,\n): SingleStoreBinaryBuilder;\nexport function binary(a?: string | SingleStoreBinaryConfig, b: SingleStoreBinaryConfig = {}) {\n\tconst { name, config } = getColumnNameAndConfig<SingleStoreBinaryConfig>(a, b);\n\treturn new SingleStoreBinaryBuilder(name, config.length);\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,mBAAuC;AACvC,oBAA4D;AAErD,MAAM,iCAAiC,uCAO5C;AAAA,EACD,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,QAA4B;AACrD,UAAM,MAAM,iBAAiB,mBAAmB;AAChD,SAAK,OAAO,SAAS,UAAU;AAC/B,SAAK,OAAO,YAAY,WAAW;AAAA,EACpC;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,0BAAuE,gCAGlF;AAAA,EACD,QAA0B,wBAAU,IAAY;AAAA,EAEvC,mBAAmB,OAA6C;AACxE,QAAI,OAAO,UAAU,SAAU,QAAO;AACtC,QAAI,OAAO,SAAS,KAAK,EAAG,QAAO,MAAM,SAAS;AAElD,UAAM,MAAgB,CAAC;AACvB,eAAW,KAAK,OAAO;AACtB,UAAI,KAAK,MAAM,KAAK,MAAM,GAAG;AAAA,IAC9B;AAEA,WAAO,IAAI,KAAK,EAAE;AAAA,EACnB;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK,OAAO,YAAY,UAAU,KAAK,MAAM,MAAM;AAAA,EAC3D;AACD;AAaO,SAAS,OAAO,GAAsC,IAA6B,CAAC,GAAG;AAC7F,QAAM,EAAE,MAAM,OAAO,QAAI,qCAAgD,GAAG,CAAC;AAC7E,SAAO,IAAI,yBAAyB,MAAM,OAAO,MAAM;AACxD;","names":[]}
1
+ {"version":3,"sources":["../../../src/singlestore-core/columns/binary.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport { getColumnNameAndConfig } from '~/utils.ts';\nimport { SingleStoreColumn, SingleStoreColumnBuilder } from './common.ts';\n\nexport class SingleStoreBinaryBuilder extends SingleStoreColumnBuilder<\n\t{\n\t\tname: string;\n\t\tdataType: 'string binary';\n\t\tdata: string;\n\t\tdriverParam: string;\n\t},\n\tSingleStoreBinaryConfig & { setLength: boolean; isLengthExact: true }\n> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBinaryBuilder';\n\n\tconstructor(name: string, length: number | undefined) {\n\t\tsuper(name, 'string binary', 'SingleStoreBinary');\n\t\tthis.config.length = length ?? 1;\n\t\tthis.config.setLength = length !== undefined;\n\t\tthis.config.isLengthExact = true;\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBinary(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBinary<T extends ColumnBaseConfig<'string binary'>> extends SingleStoreColumn<\n\tT,\n\tSingleStoreBinaryConfig & { setLength: boolean }\n> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBinary';\n\n\toverride mapFromDriverValue(value: string | Buffer | Uint8Array): string {\n\t\tif (typeof value === 'string') return value;\n\t\tif (Buffer.isBuffer(value)) return value.toString();\n\n\t\tconst str: string[] = [];\n\t\tfor (const v of value) {\n\t\t\tstr.push(v === 49 ? '1' : '0');\n\t\t}\n\n\t\treturn str.join('');\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.config.setLength ? `binary(${this.length})` : `binary`;\n\t}\n}\n\nexport interface SingleStoreBinaryConfig {\n\tlength?: number;\n}\n\nexport function binary(\n\tconfig?: SingleStoreBinaryConfig,\n): SingleStoreBinaryBuilder;\nexport function binary(\n\tname: string,\n\tconfig?: SingleStoreBinaryConfig,\n): SingleStoreBinaryBuilder;\nexport function binary(a?: string | SingleStoreBinaryConfig, b: SingleStoreBinaryConfig = {}) {\n\tconst { name, config } = getColumnNameAndConfig<SingleStoreBinaryConfig>(a, b);\n\treturn new SingleStoreBinaryBuilder(name, config.length);\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,mBAAuC;AACvC,oBAA4D;AAErD,MAAM,iCAAiC,uCAQ5C;AAAA,EACD,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,QAA4B;AACrD,UAAM,MAAM,iBAAiB,mBAAmB;AAChD,SAAK,OAAO,SAAS,UAAU;AAC/B,SAAK,OAAO,YAAY,WAAW;AACnC,SAAK,OAAO,gBAAgB;AAAA,EAC7B;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,0BAAuE,gCAGlF;AAAA,EACD,QAA0B,wBAAU,IAAY;AAAA,EAEvC,mBAAmB,OAA6C;AACxE,QAAI,OAAO,UAAU,SAAU,QAAO;AACtC,QAAI,OAAO,SAAS,KAAK,EAAG,QAAO,MAAM,SAAS;AAElD,UAAM,MAAgB,CAAC;AACvB,eAAW,KAAK,OAAO;AACtB,UAAI,KAAK,MAAM,KAAK,MAAM,GAAG;AAAA,IAC9B;AAEA,WAAO,IAAI,KAAK,EAAE;AAAA,EACnB;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK,OAAO,YAAY,UAAU,KAAK,MAAM,MAAM;AAAA,EAC3D;AACD;AAaO,SAAS,OAAO,GAAsC,IAA6B,CAAC,GAAG;AAC7F,QAAM,EAAE,MAAM,OAAO,QAAI,qCAAgD,GAAG,CAAC;AAC7E,SAAO,IAAI,yBAAyB,MAAM,OAAO,MAAM;AACxD;","names":[]}
@@ -2,11 +2,13 @@ import type { ColumnBaseConfig } from "../../column.cjs";
2
2
  import { entityKind } from "../../entity.cjs";
3
3
  import { SingleStoreColumn, SingleStoreColumnBuilder } from "./common.cjs";
4
4
  export declare class SingleStoreBinaryBuilder extends SingleStoreColumnBuilder<{
5
+ name: string;
5
6
  dataType: 'string binary';
6
7
  data: string;
7
8
  driverParam: string;
8
9
  }, SingleStoreBinaryConfig & {
9
10
  setLength: boolean;
11
+ isLengthExact: true;
10
12
  }> {
11
13
  static readonly [entityKind]: string;
12
14
  constructor(name: string, length: number | undefined);
@@ -2,11 +2,13 @@ import type { ColumnBaseConfig } from "../../column.js";
2
2
  import { entityKind } from "../../entity.js";
3
3
  import { SingleStoreColumn, SingleStoreColumnBuilder } from "./common.js";
4
4
  export declare class SingleStoreBinaryBuilder extends SingleStoreColumnBuilder<{
5
+ name: string;
5
6
  dataType: 'string binary';
6
7
  data: string;
7
8
  driverParam: string;
8
9
  }, SingleStoreBinaryConfig & {
9
10
  setLength: boolean;
11
+ isLengthExact: true;
10
12
  }> {
11
13
  static readonly [entityKind]: string;
12
14
  constructor(name: string, length: number | undefined);
@@ -7,6 +7,7 @@ class SingleStoreBinaryBuilder extends SingleStoreColumnBuilder {
7
7
  super(name, "string binary", "SingleStoreBinary");
8
8
  this.config.length = length ?? 1;
9
9
  this.config.setLength = length !== void 0;
10
+ this.config.isLengthExact = true;
10
11
  }
11
12
  /** @internal */
12
13
  build(table) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/singlestore-core/columns/binary.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport { getColumnNameAndConfig } from '~/utils.ts';\nimport { SingleStoreColumn, SingleStoreColumnBuilder } from './common.ts';\n\nexport class SingleStoreBinaryBuilder extends SingleStoreColumnBuilder<\n\t{\n\t\tdataType: 'string binary';\n\t\tdata: string;\n\t\tdriverParam: string;\n\t},\n\tSingleStoreBinaryConfig & { setLength: boolean }\n> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBinaryBuilder';\n\n\tconstructor(name: string, length: number | undefined) {\n\t\tsuper(name, 'string binary', 'SingleStoreBinary');\n\t\tthis.config.length = length ?? 1;\n\t\tthis.config.setLength = length !== undefined;\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBinary(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBinary<T extends ColumnBaseConfig<'string binary'>> extends SingleStoreColumn<\n\tT,\n\tSingleStoreBinaryConfig & { setLength: boolean }\n> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBinary';\n\n\toverride mapFromDriverValue(value: string | Buffer | Uint8Array): string {\n\t\tif (typeof value === 'string') return value;\n\t\tif (Buffer.isBuffer(value)) return value.toString();\n\n\t\tconst str: string[] = [];\n\t\tfor (const v of value) {\n\t\t\tstr.push(v === 49 ? '1' : '0');\n\t\t}\n\n\t\treturn str.join('');\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.config.setLength ? `binary(${this.length})` : `binary`;\n\t}\n}\n\nexport interface SingleStoreBinaryConfig {\n\tlength?: number;\n}\n\nexport function binary(\n\tconfig?: SingleStoreBinaryConfig,\n): SingleStoreBinaryBuilder;\nexport function binary(\n\tname: string,\n\tconfig?: SingleStoreBinaryConfig,\n): SingleStoreBinaryBuilder;\nexport function binary(a?: string | SingleStoreBinaryConfig, b: SingleStoreBinaryConfig = {}) {\n\tconst { name, config } = getColumnNameAndConfig<SingleStoreBinaryConfig>(a, b);\n\treturn new SingleStoreBinaryBuilder(name, config.length);\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAE3B,SAAS,8BAA8B;AACvC,SAAS,mBAAmB,gCAAgC;AAErD,MAAM,iCAAiC,yBAO5C;AAAA,EACD,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,QAA4B;AACrD,UAAM,MAAM,iBAAiB,mBAAmB;AAChD,SAAK,OAAO,SAAS,UAAU;AAC/B,SAAK,OAAO,YAAY,WAAW;AAAA,EACpC;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,0BAAuE,kBAGlF;AAAA,EACD,QAA0B,UAAU,IAAY;AAAA,EAEvC,mBAAmB,OAA6C;AACxE,QAAI,OAAO,UAAU,SAAU,QAAO;AACtC,QAAI,OAAO,SAAS,KAAK,EAAG,QAAO,MAAM,SAAS;AAElD,UAAM,MAAgB,CAAC;AACvB,eAAW,KAAK,OAAO;AACtB,UAAI,KAAK,MAAM,KAAK,MAAM,GAAG;AAAA,IAC9B;AAEA,WAAO,IAAI,KAAK,EAAE;AAAA,EACnB;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK,OAAO,YAAY,UAAU,KAAK,MAAM,MAAM;AAAA,EAC3D;AACD;AAaO,SAAS,OAAO,GAAsC,IAA6B,CAAC,GAAG;AAC7F,QAAM,EAAE,MAAM,OAAO,IAAI,uBAAgD,GAAG,CAAC;AAC7E,SAAO,IAAI,yBAAyB,MAAM,OAAO,MAAM;AACxD;","names":[]}
1
+ {"version":3,"sources":["../../../src/singlestore-core/columns/binary.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport { getColumnNameAndConfig } from '~/utils.ts';\nimport { SingleStoreColumn, SingleStoreColumnBuilder } from './common.ts';\n\nexport class SingleStoreBinaryBuilder extends SingleStoreColumnBuilder<\n\t{\n\t\tname: string;\n\t\tdataType: 'string binary';\n\t\tdata: string;\n\t\tdriverParam: string;\n\t},\n\tSingleStoreBinaryConfig & { setLength: boolean; isLengthExact: true }\n> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBinaryBuilder';\n\n\tconstructor(name: string, length: number | undefined) {\n\t\tsuper(name, 'string binary', 'SingleStoreBinary');\n\t\tthis.config.length = length ?? 1;\n\t\tthis.config.setLength = length !== undefined;\n\t\tthis.config.isLengthExact = true;\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBinary(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBinary<T extends ColumnBaseConfig<'string binary'>> extends SingleStoreColumn<\n\tT,\n\tSingleStoreBinaryConfig & { setLength: boolean }\n> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBinary';\n\n\toverride mapFromDriverValue(value: string | Buffer | Uint8Array): string {\n\t\tif (typeof value === 'string') return value;\n\t\tif (Buffer.isBuffer(value)) return value.toString();\n\n\t\tconst str: string[] = [];\n\t\tfor (const v of value) {\n\t\t\tstr.push(v === 49 ? '1' : '0');\n\t\t}\n\n\t\treturn str.join('');\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.config.setLength ? `binary(${this.length})` : `binary`;\n\t}\n}\n\nexport interface SingleStoreBinaryConfig {\n\tlength?: number;\n}\n\nexport function binary(\n\tconfig?: SingleStoreBinaryConfig,\n): SingleStoreBinaryBuilder;\nexport function binary(\n\tname: string,\n\tconfig?: SingleStoreBinaryConfig,\n): SingleStoreBinaryBuilder;\nexport function binary(a?: string | SingleStoreBinaryConfig, b: SingleStoreBinaryConfig = {}) {\n\tconst { name, config } = getColumnNameAndConfig<SingleStoreBinaryConfig>(a, b);\n\treturn new SingleStoreBinaryBuilder(name, config.length);\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAE3B,SAAS,8BAA8B;AACvC,SAAS,mBAAmB,gCAAgC;AAErD,MAAM,iCAAiC,yBAQ5C;AAAA,EACD,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,QAA4B;AACrD,UAAM,MAAM,iBAAiB,mBAAmB;AAChD,SAAK,OAAO,SAAS,UAAU;AAC/B,SAAK,OAAO,YAAY,WAAW;AACnC,SAAK,OAAO,gBAAgB;AAAA,EAC7B;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,0BAAuE,kBAGlF;AAAA,EACD,QAA0B,UAAU,IAAY;AAAA,EAEvC,mBAAmB,OAA6C;AACxE,QAAI,OAAO,UAAU,SAAU,QAAO;AACtC,QAAI,OAAO,SAAS,KAAK,EAAG,QAAO,MAAM,SAAS;AAElD,UAAM,MAAgB,CAAC;AACvB,eAAW,KAAK,OAAO;AACtB,UAAI,KAAK,MAAM,KAAK,MAAM,GAAG;AAAA,IAC9B;AAEA,WAAO,IAAI,KAAK,EAAE;AAAA,EACnB;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK,OAAO,YAAY,UAAU,KAAK,MAAM,MAAM;AAAA,EAC3D;AACD;AAaO,SAAS,OAAO,GAAsC,IAA6B,CAAC,GAAG;AAC7F,QAAM,EAAE,MAAM,OAAO,IAAI,uBAAgD,GAAG,CAAC;AAC7E,SAAO,IAAI,yBAAyB,MAAM,OAAO,MAAM;AACxD;","names":[]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/singlestore-core/columns/boolean.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport { SingleStoreColumn, SingleStoreColumnBuilder } from './common.ts';\n\nexport class SingleStoreBooleanBuilder extends SingleStoreColumnBuilder<{\n\tdataType: 'boolean';\n\tdata: boolean;\n\tdriverParam: number | boolean;\n}> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBooleanBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'boolean', 'SingleStoreBoolean');\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBoolean(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBoolean<T extends ColumnBaseConfig<'boolean'>> extends SingleStoreColumn<T> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBoolean';\n\n\tgetSQLType(): string {\n\t\treturn 'boolean';\n\t}\n\n\toverride mapFromDriverValue(value: number | boolean): boolean {\n\t\tif (typeof value === 'boolean') {\n\t\t\treturn value;\n\t\t}\n\t\treturn value === 1;\n\t}\n}\n\nexport function boolean(name?: string): SingleStoreBooleanBuilder {\n\treturn new SingleStoreBooleanBuilder(name ?? '');\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,oBAA4D;AAErD,MAAM,kCAAkC,uCAI5C;AAAA,EACF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,WAAW,oBAAoB;AAAA,EAC5C;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,2BAAkE,gCAAqB;AAAA,EACnG,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAkC;AAC7D,QAAI,OAAO,UAAU,WAAW;AAC/B,aAAO;AAAA,IACR;AACA,WAAO,UAAU;AAAA,EAClB;AACD;AAEO,SAAS,QAAQ,MAA0C;AACjE,SAAO,IAAI,0BAA0B,QAAQ,EAAE;AAChD;","names":[]}
1
+ {"version":3,"sources":["../../../src/singlestore-core/columns/boolean.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport { SingleStoreColumn, SingleStoreColumnBuilder } from './common.ts';\n\nexport class SingleStoreBooleanBuilder extends SingleStoreColumnBuilder<{\n\tname: string;\n\tdataType: 'boolean';\n\tdata: boolean;\n\tdriverParam: number | boolean;\n}> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBooleanBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'boolean', 'SingleStoreBoolean');\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBoolean(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBoolean<T extends ColumnBaseConfig<'boolean'>> extends SingleStoreColumn<T> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBoolean';\n\n\tgetSQLType(): string {\n\t\treturn 'boolean';\n\t}\n\n\toverride mapFromDriverValue(value: number | boolean): boolean {\n\t\tif (typeof value === 'boolean') {\n\t\t\treturn value;\n\t\t}\n\t\treturn value === 1;\n\t}\n}\n\nexport function boolean(name?: string): SingleStoreBooleanBuilder {\n\treturn new SingleStoreBooleanBuilder(name ?? '');\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,oBAA4D;AAErD,MAAM,kCAAkC,uCAK5C;AAAA,EACF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,WAAW,oBAAoB;AAAA,EAC5C;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,2BAAkE,gCAAqB;AAAA,EACnG,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAkC;AAC7D,QAAI,OAAO,UAAU,WAAW;AAC/B,aAAO;AAAA,IACR;AACA,WAAO,UAAU;AAAA,EAClB;AACD;AAEO,SAAS,QAAQ,MAA0C;AACjE,SAAO,IAAI,0BAA0B,QAAQ,EAAE;AAChD;","names":[]}
@@ -2,6 +2,7 @@ import type { ColumnBaseConfig } from "../../column.cjs";
2
2
  import { entityKind } from "../../entity.cjs";
3
3
  import { SingleStoreColumn, SingleStoreColumnBuilder } from "./common.cjs";
4
4
  export declare class SingleStoreBooleanBuilder extends SingleStoreColumnBuilder<{
5
+ name: string;
5
6
  dataType: 'boolean';
6
7
  data: boolean;
7
8
  driverParam: number | boolean;
@@ -2,6 +2,7 @@ import type { ColumnBaseConfig } from "../../column.js";
2
2
  import { entityKind } from "../../entity.js";
3
3
  import { SingleStoreColumn, SingleStoreColumnBuilder } from "./common.js";
4
4
  export declare class SingleStoreBooleanBuilder extends SingleStoreColumnBuilder<{
5
+ name: string;
5
6
  dataType: 'boolean';
6
7
  data: boolean;
7
8
  driverParam: number | boolean;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/singlestore-core/columns/boolean.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport { SingleStoreColumn, SingleStoreColumnBuilder } from './common.ts';\n\nexport class SingleStoreBooleanBuilder extends SingleStoreColumnBuilder<{\n\tdataType: 'boolean';\n\tdata: boolean;\n\tdriverParam: number | boolean;\n}> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBooleanBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'boolean', 'SingleStoreBoolean');\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBoolean(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBoolean<T extends ColumnBaseConfig<'boolean'>> extends SingleStoreColumn<T> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBoolean';\n\n\tgetSQLType(): string {\n\t\treturn 'boolean';\n\t}\n\n\toverride mapFromDriverValue(value: number | boolean): boolean {\n\t\tif (typeof value === 'boolean') {\n\t\t\treturn value;\n\t\t}\n\t\treturn value === 1;\n\t}\n}\n\nexport function boolean(name?: string): SingleStoreBooleanBuilder {\n\treturn new SingleStoreBooleanBuilder(name ?? '');\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAE3B,SAAS,mBAAmB,gCAAgC;AAErD,MAAM,kCAAkC,yBAI5C;AAAA,EACF,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,WAAW,oBAAoB;AAAA,EAC5C;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,2BAAkE,kBAAqB;AAAA,EACnG,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAkC;AAC7D,QAAI,OAAO,UAAU,WAAW;AAC/B,aAAO;AAAA,IACR;AACA,WAAO,UAAU;AAAA,EAClB;AACD;AAEO,SAAS,QAAQ,MAA0C;AACjE,SAAO,IAAI,0BAA0B,QAAQ,EAAE;AAChD;","names":[]}
1
+ {"version":3,"sources":["../../../src/singlestore-core/columns/boolean.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport { SingleStoreColumn, SingleStoreColumnBuilder } from './common.ts';\n\nexport class SingleStoreBooleanBuilder extends SingleStoreColumnBuilder<{\n\tname: string;\n\tdataType: 'boolean';\n\tdata: boolean;\n\tdriverParam: number | boolean;\n}> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBooleanBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'boolean', 'SingleStoreBoolean');\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreBoolean(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreBoolean<T extends ColumnBaseConfig<'boolean'>> extends SingleStoreColumn<T> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreBoolean';\n\n\tgetSQLType(): string {\n\t\treturn 'boolean';\n\t}\n\n\toverride mapFromDriverValue(value: number | boolean): boolean {\n\t\tif (typeof value === 'boolean') {\n\t\t\treturn value;\n\t\t}\n\t\treturn value === 1;\n\t}\n}\n\nexport function boolean(name?: string): SingleStoreBooleanBuilder {\n\treturn new SingleStoreBooleanBuilder(name ?? '');\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAE3B,SAAS,mBAAmB,gCAAgC;AAErD,MAAM,kCAAkC,yBAK5C;AAAA,EACF,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,WAAW,oBAAoB;AAAA,EAC5C;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,2BAAkE,kBAAqB;AAAA,EACnG,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAkC;AAC7D,QAAI,OAAO,UAAU,WAAW;AAC/B,aAAO;AAAA,IACR;AACA,WAAO,UAAU;AAAA,EAClB;AACD;AAEO,SAAS,QAAQ,MAA0C;AACjE,SAAO,IAAI,0BAA0B,QAAQ,EAAE;AAChD;","names":[]}
@@ -33,6 +33,7 @@ class SingleStoreCharBuilder extends import_common.SingleStoreColumnBuilder {
33
33
  this.config.length = config.length ?? 1;
34
34
  this.config.setLength = config.length !== void 0;
35
35
  this.config.enum = config.enum;
36
+ this.config.isLengthExact = true;
36
37
  }
37
38
  /** @internal */
38
39
  build(table) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/singlestore-core/columns/char.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport { type Equal, getColumnNameAndConfig, type Writable } from '~/utils.ts';\nimport { SingleStoreColumn, SingleStoreColumnBuilder } from './common.ts';\n\nexport class SingleStoreCharBuilder<\n\tTEnum extends [string, ...string[]],\n> extends SingleStoreColumnBuilder<\n\t{\n\t\tdataType: Equal<TEnum, [string, ...string[]]> extends true ? 'string' : 'string enum';\n\t\tdata: TEnum[number];\n\t\tdriverParam: number | string;\n\t\tenumValues: TEnum;\n\t},\n\t{ enum?: TEnum; length: number; setLength: boolean }\n> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreCharBuilder';\n\n\tconstructor(name: string, config: SingleStoreCharConfig<TEnum>) {\n\t\tsuper(name, config.enum?.length ? 'string enum' : 'string', 'SingleStoreChar');\n\t\tthis.config.length = config.length ?? 1;\n\t\tthis.config.setLength = config.length !== undefined;\n\t\tthis.config.enum = config.enum;\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreChar(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreChar<\n\tT extends ColumnBaseConfig<'string' | 'string enum'>,\n> extends SingleStoreColumn<T, { enum?: T['enumValues']; length: number; setLength: boolean }> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreChar';\n\n\toverride readonly enumValues = this.config.enum;\n\n\tgetSQLType(): string {\n\t\treturn this.config.setLength ? `char(${this.length})` : `char`;\n\t}\n}\n\nexport interface SingleStoreCharConfig<\n\tTEnum extends readonly string[] | string[] | undefined = readonly string[] | string[] | undefined,\n> {\n\tenum?: TEnum;\n\tlength?: number;\n}\n\nexport function char<U extends string, T extends Readonly<[U, ...U[]]>>(\n\tconfig?: SingleStoreCharConfig<T | Writable<T>>,\n): SingleStoreCharBuilder<Writable<T>>;\nexport function char<\n\tU extends string,\n\tT extends Readonly<[U, ...U[]]>,\n>(\n\tname: string,\n\tconfig?: SingleStoreCharConfig<T | Writable<T>>,\n): SingleStoreCharBuilder<Writable<T>>;\nexport function char(a?: string | SingleStoreCharConfig, b: SingleStoreCharConfig = {}): any {\n\tconst { name, config } = getColumnNameAndConfig<SingleStoreCharConfig>(a, b);\n\treturn new SingleStoreCharBuilder(name, config as any);\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,mBAAkE;AAClE,oBAA4D;AAErD,MAAM,+BAEH,uCAQR;AAAA,EACD,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,QAAsC;AAC/D,UAAM,MAAM,OAAO,MAAM,SAAS,gBAAgB,UAAU,iBAAiB;AAC7E,SAAK,OAAO,SAAS,OAAO,UAAU;AACtC,SAAK,OAAO,YAAY,OAAO,WAAW;AAC1C,SAAK,OAAO,OAAO,OAAO;AAAA,EAC3B;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,wBAEH,gCAAqF;AAAA,EAC9F,QAA0B,wBAAU,IAAY;AAAA,EAE9B,aAAa,KAAK,OAAO;AAAA,EAE3C,aAAqB;AACpB,WAAO,KAAK,OAAO,YAAY,QAAQ,KAAK,MAAM,MAAM;AAAA,EACzD;AACD;AAmBO,SAAS,KAAK,GAAoC,IAA2B,CAAC,GAAQ;AAC5F,QAAM,EAAE,MAAM,OAAO,QAAI,qCAA8C,GAAG,CAAC;AAC3E,SAAO,IAAI,uBAAuB,MAAM,MAAa;AACtD;","names":[]}
1
+ {"version":3,"sources":["../../../src/singlestore-core/columns/char.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport { type Equal, getColumnNameAndConfig, type Writable } from '~/utils.ts';\nimport { SingleStoreColumn, SingleStoreColumnBuilder } from './common.ts';\n\nexport class SingleStoreCharBuilder<\n\tTEnum extends [string, ...string[]],\n> extends SingleStoreColumnBuilder<\n\t{\n\t\tname: string;\n\t\tdataType: Equal<TEnum, [string, ...string[]]> extends true ? 'string' : 'string enum';\n\t\tdata: TEnum[number];\n\t\tdriverParam: number | string;\n\t\tenumValues: TEnum;\n\t},\n\t{ enum?: TEnum; length: number; setLength: boolean; isLengthExact: true }\n> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreCharBuilder';\n\n\tconstructor(name: string, config: SingleStoreCharConfig<TEnum>) {\n\t\tsuper(name, config.enum?.length ? 'string enum' : 'string', 'SingleStoreChar');\n\t\tthis.config.length = config.length ?? 1;\n\t\tthis.config.setLength = config.length !== undefined;\n\t\tthis.config.enum = config.enum;\n\t\tthis.config.isLengthExact = true;\n\t}\n\n\t/** @internal */\n\toverride build(table: SingleStoreTable) {\n\t\treturn new SingleStoreChar(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class SingleStoreChar<\n\tT extends ColumnBaseConfig<'string' | 'string enum'>,\n> extends SingleStoreColumn<T, { enum?: T['enumValues']; length: number; setLength: boolean }> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreChar';\n\n\toverride readonly enumValues = this.config.enum;\n\n\tgetSQLType(): string {\n\t\treturn this.config.setLength ? `char(${this.length})` : `char`;\n\t}\n}\n\nexport interface SingleStoreCharConfig<\n\tTEnum extends readonly string[] | string[] | undefined = readonly string[] | string[] | undefined,\n> {\n\tenum?: TEnum;\n\tlength?: number;\n}\n\nexport function char<U extends string, T extends Readonly<[U, ...U[]]>>(\n\tconfig?: SingleStoreCharConfig<T | Writable<T>>,\n): SingleStoreCharBuilder<Writable<T>>;\nexport function char<\n\tU extends string,\n\tT extends Readonly<[U, ...U[]]>,\n>(\n\tname: string,\n\tconfig?: SingleStoreCharConfig<T | Writable<T>>,\n): SingleStoreCharBuilder<Writable<T>>;\nexport function char(a?: string | SingleStoreCharConfig, b: SingleStoreCharConfig = {}): any {\n\tconst { name, config } = getColumnNameAndConfig<SingleStoreCharConfig>(a, b);\n\treturn new SingleStoreCharBuilder(name, config as any);\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,mBAAkE;AAClE,oBAA4D;AAErD,MAAM,+BAEH,uCASR;AAAA,EACD,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,QAAsC;AAC/D,UAAM,MAAM,OAAO,MAAM,SAAS,gBAAgB,UAAU,iBAAiB;AAC7E,SAAK,OAAO,SAAS,OAAO,UAAU;AACtC,SAAK,OAAO,YAAY,OAAO,WAAW;AAC1C,SAAK,OAAO,OAAO,OAAO;AAC1B,SAAK,OAAO,gBAAgB;AAAA,EAC7B;AAAA;AAAA,EAGS,MAAM,OAAyB;AACvC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,wBAEH,gCAAqF;AAAA,EAC9F,QAA0B,wBAAU,IAAY;AAAA,EAE9B,aAAa,KAAK,OAAO;AAAA,EAE3C,aAAqB;AACpB,WAAO,KAAK,OAAO,YAAY,QAAQ,KAAK,MAAM,MAAM;AAAA,EACzD;AACD;AAmBO,SAAS,KAAK,GAAoC,IAA2B,CAAC,GAAQ;AAC5F,QAAM,EAAE,MAAM,OAAO,QAAI,qCAA8C,GAAG,CAAC;AAC3E,SAAO,IAAI,uBAAuB,MAAM,MAAa;AACtD;","names":[]}