drizzle-orm 1.0.0-beta.1 → 1.0.0-beta.1-dfa4db3

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 (1709) hide show
  1. package/_relations.cjs +6 -50
  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 +6 -49
  6. package/_relations.js.map +1 -1
  7. package/aws-data-api/common/index.cjs.map +1 -1
  8. package/aws-data-api/common/index.js.map +1 -1
  9. package/aws-data-api/pg/driver.cjs +4 -1
  10. package/aws-data-api/pg/driver.cjs.map +1 -1
  11. package/aws-data-api/pg/driver.d.cts +3 -0
  12. package/aws-data-api/pg/driver.d.ts +3 -0
  13. package/aws-data-api/pg/driver.js +4 -1
  14. package/aws-data-api/pg/driver.js.map +1 -1
  15. package/aws-data-api/pg/session.cjs +9 -2
  16. package/aws-data-api/pg/session.cjs.map +1 -1
  17. package/aws-data-api/pg/session.d.cts +1 -0
  18. package/aws-data-api/pg/session.d.ts +1 -0
  19. package/aws-data-api/pg/session.js +9 -2
  20. package/aws-data-api/pg/session.js.map +1 -1
  21. package/better-sqlite3/driver.cjs +14 -10
  22. package/better-sqlite3/driver.cjs.map +1 -1
  23. package/better-sqlite3/driver.d.cts +3 -3
  24. package/better-sqlite3/driver.d.ts +3 -3
  25. package/better-sqlite3/driver.js +14 -10
  26. package/better-sqlite3/driver.js.map +1 -1
  27. package/bun-sql/driver.cjs.map +1 -1
  28. package/bun-sql/driver.d.cts +8 -8
  29. package/bun-sql/driver.d.ts +8 -8
  30. package/bun-sql/driver.js.map +1 -1
  31. package/bun-sql/mysql/driver.cjs +14 -10
  32. package/bun-sql/mysql/driver.cjs.map +1 -1
  33. package/bun-sql/mysql/driver.d.cts +3 -3
  34. package/bun-sql/mysql/driver.d.ts +3 -3
  35. package/bun-sql/mysql/driver.js +14 -10
  36. package/bun-sql/mysql/driver.js.map +1 -1
  37. package/bun-sql/postgres/driver.cjs +14 -10
  38. package/bun-sql/postgres/driver.cjs.map +1 -1
  39. package/bun-sql/postgres/driver.d.cts +3 -3
  40. package/bun-sql/postgres/driver.d.ts +3 -3
  41. package/bun-sql/postgres/driver.js +14 -10
  42. package/bun-sql/postgres/driver.js.map +1 -1
  43. package/bun-sql/sqlite/driver.cjs +14 -10
  44. package/bun-sql/sqlite/driver.cjs.map +1 -1
  45. package/bun-sql/sqlite/driver.d.cts +3 -3
  46. package/bun-sql/sqlite/driver.d.ts +3 -3
  47. package/bun-sql/sqlite/driver.js +14 -10
  48. package/bun-sql/sqlite/driver.js.map +1 -1
  49. package/bun-sqlite/driver.cjs +15 -11
  50. package/bun-sqlite/driver.cjs.map +1 -1
  51. package/bun-sqlite/driver.d.cts +3 -3
  52. package/bun-sqlite/driver.d.ts +3 -3
  53. package/bun-sqlite/driver.js +15 -11
  54. package/bun-sqlite/driver.js.map +1 -1
  55. package/column-builder.cjs.map +1 -1
  56. package/column-builder.d.cts +8 -9
  57. package/column-builder.d.ts +8 -9
  58. package/column-builder.js.map +1 -1
  59. package/durable-sqlite/session.cjs +3 -6
  60. package/durable-sqlite/session.cjs.map +1 -1
  61. package/durable-sqlite/session.d.cts +2 -1
  62. package/durable-sqlite/session.d.ts +2 -1
  63. package/durable-sqlite/session.js +2 -6
  64. package/durable-sqlite/session.js.map +1 -1
  65. package/entity.cjs.map +1 -1
  66. package/entity.js.map +1 -1
  67. package/gel/driver.cjs +10 -6
  68. package/gel/driver.cjs.map +1 -1
  69. package/gel/driver.d.cts +2 -2
  70. package/gel/driver.d.ts +2 -2
  71. package/gel/driver.js +10 -6
  72. package/gel/driver.js.map +1 -1
  73. package/gel-core/columns/bigint.cjs.map +1 -1
  74. package/gel-core/columns/bigint.d.cts +1 -0
  75. package/gel-core/columns/bigint.d.ts +1 -0
  76. package/gel-core/columns/bigint.js.map +1 -1
  77. package/gel-core/columns/bigintT.cjs.map +1 -1
  78. package/gel-core/columns/bigintT.d.cts +1 -0
  79. package/gel-core/columns/bigintT.d.ts +1 -0
  80. package/gel-core/columns/bigintT.js.map +1 -1
  81. package/gel-core/columns/boolean.cjs.map +1 -1
  82. package/gel-core/columns/boolean.d.cts +1 -0
  83. package/gel-core/columns/boolean.d.ts +1 -0
  84. package/gel-core/columns/boolean.js.map +1 -1
  85. package/gel-core/columns/bytes.cjs.map +1 -1
  86. package/gel-core/columns/bytes.d.cts +1 -0
  87. package/gel-core/columns/bytes.d.ts +1 -0
  88. package/gel-core/columns/bytes.js.map +1 -1
  89. package/gel-core/columns/common.cjs +4 -0
  90. package/gel-core/columns/common.cjs.map +1 -1
  91. package/gel-core/columns/common.d.cts +1 -1
  92. package/gel-core/columns/common.d.ts +1 -1
  93. package/gel-core/columns/common.js +4 -0
  94. package/gel-core/columns/common.js.map +1 -1
  95. package/gel-core/columns/custom.cjs.map +1 -1
  96. package/gel-core/columns/custom.d.cts +1 -0
  97. package/gel-core/columns/custom.d.ts +1 -0
  98. package/gel-core/columns/custom.js.map +1 -1
  99. package/gel-core/columns/date-duration.cjs.map +1 -1
  100. package/gel-core/columns/date-duration.d.cts +1 -0
  101. package/gel-core/columns/date-duration.d.ts +1 -0
  102. package/gel-core/columns/date-duration.js.map +1 -1
  103. package/gel-core/columns/decimal.cjs.map +1 -1
  104. package/gel-core/columns/decimal.d.cts +1 -0
  105. package/gel-core/columns/decimal.d.ts +1 -0
  106. package/gel-core/columns/decimal.js.map +1 -1
  107. package/gel-core/columns/double-precision.cjs.map +1 -1
  108. package/gel-core/columns/double-precision.d.cts +1 -0
  109. package/gel-core/columns/double-precision.d.ts +1 -0
  110. package/gel-core/columns/double-precision.js.map +1 -1
  111. package/gel-core/columns/duration.cjs.map +1 -1
  112. package/gel-core/columns/duration.d.cts +1 -0
  113. package/gel-core/columns/duration.d.ts +1 -0
  114. package/gel-core/columns/duration.js.map +1 -1
  115. package/gel-core/columns/integer.cjs.map +1 -1
  116. package/gel-core/columns/integer.d.cts +1 -0
  117. package/gel-core/columns/integer.d.ts +1 -0
  118. package/gel-core/columns/integer.js.map +1 -1
  119. package/gel-core/columns/json.cjs.map +1 -1
  120. package/gel-core/columns/json.d.cts +1 -0
  121. package/gel-core/columns/json.d.ts +1 -0
  122. package/gel-core/columns/json.js.map +1 -1
  123. package/gel-core/columns/localdate.cjs.map +1 -1
  124. package/gel-core/columns/localdate.d.cts +1 -0
  125. package/gel-core/columns/localdate.d.ts +1 -0
  126. package/gel-core/columns/localdate.js.map +1 -1
  127. package/gel-core/columns/localtime.cjs.map +1 -1
  128. package/gel-core/columns/localtime.d.cts +1 -0
  129. package/gel-core/columns/localtime.d.ts +1 -0
  130. package/gel-core/columns/localtime.js.map +1 -1
  131. package/gel-core/columns/real.cjs.map +1 -1
  132. package/gel-core/columns/real.d.cts +1 -0
  133. package/gel-core/columns/real.d.ts +1 -0
  134. package/gel-core/columns/real.js.map +1 -1
  135. package/gel-core/columns/relative-duration.cjs.map +1 -1
  136. package/gel-core/columns/relative-duration.d.cts +1 -0
  137. package/gel-core/columns/relative-duration.d.ts +1 -0
  138. package/gel-core/columns/relative-duration.js.map +1 -1
  139. package/gel-core/columns/smallint.cjs.map +1 -1
  140. package/gel-core/columns/smallint.d.cts +1 -0
  141. package/gel-core/columns/smallint.d.ts +1 -0
  142. package/gel-core/columns/smallint.js.map +1 -1
  143. package/gel-core/columns/text.cjs.map +1 -1
  144. package/gel-core/columns/text.d.cts +1 -0
  145. package/gel-core/columns/text.d.ts +1 -0
  146. package/gel-core/columns/text.js.map +1 -1
  147. package/gel-core/columns/timestamp.cjs.map +1 -1
  148. package/gel-core/columns/timestamp.d.cts +1 -0
  149. package/gel-core/columns/timestamp.d.ts +1 -0
  150. package/gel-core/columns/timestamp.js.map +1 -1
  151. package/gel-core/columns/timestamptz.cjs.map +1 -1
  152. package/gel-core/columns/timestamptz.d.cts +1 -0
  153. package/gel-core/columns/timestamptz.d.ts +1 -0
  154. package/gel-core/columns/timestamptz.js.map +1 -1
  155. package/gel-core/columns/uuid.cjs.map +1 -1
  156. package/gel-core/columns/uuid.d.cts +1 -0
  157. package/gel-core/columns/uuid.d.ts +1 -0
  158. package/gel-core/columns/uuid.js.map +1 -1
  159. package/gel-core/query-builders/count.cjs.map +1 -1
  160. package/gel-core/query-builders/count.d.cts +1 -1
  161. package/gel-core/query-builders/count.d.ts +1 -1
  162. package/gel-core/query-builders/count.js.map +1 -1
  163. package/gel-core/query-builders/insert.cjs.map +1 -1
  164. package/gel-core/query-builders/insert.d.cts +9 -6
  165. package/gel-core/query-builders/insert.d.ts +9 -6
  166. package/gel-core/query-builders/insert.js.map +1 -1
  167. package/gel-core/query-builders/select.cjs +9 -8
  168. package/gel-core/query-builders/select.cjs.map +1 -1
  169. package/gel-core/query-builders/select.js +4 -4
  170. package/gel-core/query-builders/select.js.map +1 -1
  171. package/gel-core/query-builders/update.cjs +2 -2
  172. package/gel-core/query-builders/update.cjs.map +1 -1
  173. package/gel-core/query-builders/update.d.cts +1 -1
  174. package/gel-core/query-builders/update.d.ts +1 -1
  175. package/gel-core/query-builders/update.js +2 -2
  176. package/gel-core/query-builders/update.js.map +1 -1
  177. package/gel-core/schema.cjs +4 -4
  178. package/gel-core/schema.cjs.map +1 -1
  179. package/gel-core/schema.js +4 -4
  180. package/gel-core/schema.js.map +1 -1
  181. package/gel-core/utils.cjs +2 -1
  182. package/gel-core/utils.cjs.map +1 -1
  183. package/gel-core/utils.d.cts +1 -1
  184. package/gel-core/utils.d.ts +1 -1
  185. package/gel-core/utils.js +2 -1
  186. package/gel-core/utils.js.map +1 -1
  187. package/gel-core/view-common.cjs +0 -3
  188. package/gel-core/view-common.cjs.map +1 -1
  189. package/gel-core/view-common.d.cts +0 -1
  190. package/gel-core/view-common.d.ts +0 -1
  191. package/gel-core/view-common.js +0 -2
  192. package/gel-core/view-common.js.map +1 -1
  193. package/gel-core/view.cjs +5 -2
  194. package/gel-core/view.cjs.map +1 -1
  195. package/gel-core/view.d.cts +2 -1
  196. package/gel-core/view.d.ts +2 -1
  197. package/gel-core/view.js +3 -1
  198. package/gel-core/view.js.map +1 -1
  199. package/libsql/driver.cjs +10 -6
  200. package/libsql/driver.cjs.map +1 -1
  201. package/libsql/driver.d.cts +3 -3
  202. package/libsql/driver.d.ts +3 -3
  203. package/libsql/driver.js +10 -6
  204. package/libsql/driver.js.map +1 -1
  205. package/libsql/http/index.cjs +10 -6
  206. package/libsql/http/index.cjs.map +1 -1
  207. package/libsql/http/index.d.cts +3 -3
  208. package/libsql/http/index.d.ts +3 -3
  209. package/libsql/http/index.js +10 -6
  210. package/libsql/http/index.js.map +1 -1
  211. package/libsql/node/index.cjs +10 -6
  212. package/libsql/node/index.cjs.map +1 -1
  213. package/libsql/node/index.d.cts +3 -3
  214. package/libsql/node/index.d.ts +3 -3
  215. package/libsql/node/index.js +10 -6
  216. package/libsql/node/index.js.map +1 -1
  217. package/libsql/session.cjs.map +1 -1
  218. package/libsql/session.d.cts +1 -1
  219. package/libsql/session.d.ts +1 -1
  220. package/libsql/session.js.map +1 -1
  221. package/libsql/sqlite3/index.cjs +10 -6
  222. package/libsql/sqlite3/index.cjs.map +1 -1
  223. package/libsql/sqlite3/index.d.cts +3 -3
  224. package/libsql/sqlite3/index.d.ts +3 -3
  225. package/libsql/sqlite3/index.js +10 -6
  226. package/libsql/sqlite3/index.js.map +1 -1
  227. package/libsql/wasm/index.cjs +10 -6
  228. package/libsql/wasm/index.cjs.map +1 -1
  229. package/libsql/wasm/index.d.cts +3 -3
  230. package/libsql/wasm/index.d.ts +3 -3
  231. package/libsql/wasm/index.js +10 -6
  232. package/libsql/wasm/index.js.map +1 -1
  233. package/libsql/web/index.cjs +10 -6
  234. package/libsql/web/index.cjs.map +1 -1
  235. package/libsql/web/index.d.cts +3 -3
  236. package/libsql/web/index.d.ts +3 -3
  237. package/libsql/web/index.js +10 -6
  238. package/libsql/web/index.js.map +1 -1
  239. package/libsql/ws/index.cjs +10 -6
  240. package/libsql/ws/index.cjs.map +1 -1
  241. package/libsql/ws/index.d.cts +3 -3
  242. package/libsql/ws/index.d.ts +3 -3
  243. package/libsql/ws/index.js +10 -6
  244. package/libsql/ws/index.js.map +1 -1
  245. package/mysql-core/columns/all.cjs +1 -6
  246. package/mysql-core/columns/all.cjs.map +1 -1
  247. package/mysql-core/columns/all.d.cts +0 -5
  248. package/mysql-core/columns/all.d.ts +0 -5
  249. package/mysql-core/columns/all.js +1 -6
  250. package/mysql-core/columns/all.js.map +1 -1
  251. package/mysql-core/columns/bigint.cjs.map +1 -1
  252. package/mysql-core/columns/bigint.d.cts +2 -0
  253. package/mysql-core/columns/bigint.d.ts +2 -0
  254. package/mysql-core/columns/bigint.js.map +1 -1
  255. package/mysql-core/columns/binary.cjs +1 -0
  256. package/mysql-core/columns/binary.cjs.map +1 -1
  257. package/mysql-core/columns/binary.d.cts +2 -0
  258. package/mysql-core/columns/binary.d.ts +2 -0
  259. package/mysql-core/columns/binary.js +1 -0
  260. package/mysql-core/columns/binary.js.map +1 -1
  261. package/mysql-core/columns/boolean.cjs.map +1 -1
  262. package/mysql-core/columns/boolean.d.cts +1 -0
  263. package/mysql-core/columns/boolean.d.ts +1 -0
  264. package/mysql-core/columns/boolean.js.map +1 -1
  265. package/mysql-core/columns/char.cjs +4 -3
  266. package/mysql-core/columns/char.cjs.map +1 -1
  267. package/mysql-core/columns/char.d.cts +5 -3
  268. package/mysql-core/columns/char.d.ts +5 -3
  269. package/mysql-core/columns/char.js +4 -3
  270. package/mysql-core/columns/char.js.map +1 -1
  271. package/mysql-core/columns/common.cjs +4 -0
  272. package/mysql-core/columns/common.cjs.map +1 -1
  273. package/mysql-core/columns/common.d.cts +1 -1
  274. package/mysql-core/columns/common.d.ts +1 -1
  275. package/mysql-core/columns/common.js +4 -0
  276. package/mysql-core/columns/common.js.map +1 -1
  277. package/mysql-core/columns/custom.cjs.map +1 -1
  278. package/mysql-core/columns/custom.d.cts +1 -0
  279. package/mysql-core/columns/custom.d.ts +1 -0
  280. package/mysql-core/columns/custom.js.map +1 -1
  281. package/mysql-core/columns/date.cjs.map +1 -1
  282. package/mysql-core/columns/date.common.cjs +1 -3
  283. package/mysql-core/columns/date.common.cjs.map +1 -1
  284. package/mysql-core/columns/date.common.d.cts +1 -6
  285. package/mysql-core/columns/date.common.d.ts +1 -6
  286. package/mysql-core/columns/date.common.js +1 -3
  287. package/mysql-core/columns/date.common.js.map +1 -1
  288. package/mysql-core/columns/date.d.cts +2 -0
  289. package/mysql-core/columns/date.d.ts +2 -0
  290. package/mysql-core/columns/date.js.map +1 -1
  291. package/mysql-core/columns/datetime.cjs.map +1 -1
  292. package/mysql-core/columns/datetime.d.cts +2 -0
  293. package/mysql-core/columns/datetime.d.ts +2 -0
  294. package/mysql-core/columns/datetime.js.map +1 -1
  295. package/mysql-core/columns/decimal.cjs.map +1 -1
  296. package/mysql-core/columns/decimal.d.cts +3 -0
  297. package/mysql-core/columns/decimal.d.ts +3 -0
  298. package/mysql-core/columns/decimal.js.map +1 -1
  299. package/mysql-core/columns/double.cjs.map +1 -1
  300. package/mysql-core/columns/double.d.cts +1 -0
  301. package/mysql-core/columns/double.d.ts +1 -0
  302. package/mysql-core/columns/double.js.map +1 -1
  303. package/mysql-core/columns/enum.cjs +5 -5
  304. package/mysql-core/columns/enum.cjs.map +1 -1
  305. package/mysql-core/columns/enum.d.cts +7 -5
  306. package/mysql-core/columns/enum.d.ts +7 -5
  307. package/mysql-core/columns/enum.js +5 -5
  308. package/mysql-core/columns/enum.js.map +1 -1
  309. package/mysql-core/columns/float.cjs.map +1 -1
  310. package/mysql-core/columns/float.d.cts +1 -0
  311. package/mysql-core/columns/float.d.ts +1 -0
  312. package/mysql-core/columns/float.js.map +1 -1
  313. package/mysql-core/columns/index.cjs +0 -2
  314. package/mysql-core/columns/index.cjs.map +1 -1
  315. package/mysql-core/columns/index.d.cts +0 -1
  316. package/mysql-core/columns/index.d.ts +0 -1
  317. package/mysql-core/columns/index.js +0 -1
  318. package/mysql-core/columns/index.js.map +1 -1
  319. package/mysql-core/columns/int.cjs.map +1 -1
  320. package/mysql-core/columns/int.d.cts +1 -0
  321. package/mysql-core/columns/int.d.ts +1 -0
  322. package/mysql-core/columns/int.js.map +1 -1
  323. package/mysql-core/columns/json.cjs.map +1 -1
  324. package/mysql-core/columns/json.d.cts +1 -0
  325. package/mysql-core/columns/json.d.ts +1 -0
  326. package/mysql-core/columns/json.js.map +1 -1
  327. package/mysql-core/columns/mediumint.cjs.map +1 -1
  328. package/mysql-core/columns/mediumint.d.cts +1 -0
  329. package/mysql-core/columns/mediumint.d.ts +1 -0
  330. package/mysql-core/columns/mediumint.js.map +1 -1
  331. package/mysql-core/columns/real.cjs.map +1 -1
  332. package/mysql-core/columns/real.d.cts +1 -0
  333. package/mysql-core/columns/real.d.ts +1 -0
  334. package/mysql-core/columns/real.js.map +1 -1
  335. package/mysql-core/columns/serial.cjs.map +1 -1
  336. package/mysql-core/columns/serial.d.cts +1 -0
  337. package/mysql-core/columns/serial.d.ts +1 -0
  338. package/mysql-core/columns/serial.js.map +1 -1
  339. package/mysql-core/columns/smallint.cjs.map +1 -1
  340. package/mysql-core/columns/smallint.d.cts +1 -0
  341. package/mysql-core/columns/smallint.d.ts +1 -0
  342. package/mysql-core/columns/smallint.js.map +1 -1
  343. package/mysql-core/columns/text.cjs +3 -3
  344. package/mysql-core/columns/text.cjs.map +1 -1
  345. package/mysql-core/columns/text.d.cts +4 -3
  346. package/mysql-core/columns/text.d.ts +4 -3
  347. package/mysql-core/columns/text.js +3 -3
  348. package/mysql-core/columns/text.js.map +1 -1
  349. package/mysql-core/columns/time.cjs.map +1 -1
  350. package/mysql-core/columns/time.d.cts +1 -0
  351. package/mysql-core/columns/time.d.ts +1 -0
  352. package/mysql-core/columns/time.js.map +1 -1
  353. package/mysql-core/columns/timestamp.cjs.map +1 -1
  354. package/mysql-core/columns/timestamp.d.cts +2 -0
  355. package/mysql-core/columns/timestamp.d.ts +2 -0
  356. package/mysql-core/columns/timestamp.js.map +1 -1
  357. package/mysql-core/columns/tinyint.cjs.map +1 -1
  358. package/mysql-core/columns/tinyint.d.cts +1 -0
  359. package/mysql-core/columns/tinyint.d.ts +1 -0
  360. package/mysql-core/columns/tinyint.js.map +1 -1
  361. package/mysql-core/columns/varbinary.cjs.map +1 -1
  362. package/mysql-core/columns/varbinary.d.cts +1 -0
  363. package/mysql-core/columns/varbinary.d.ts +1 -0
  364. package/mysql-core/columns/varbinary.js.map +1 -1
  365. package/mysql-core/columns/varchar.cjs +4 -4
  366. package/mysql-core/columns/varchar.cjs.map +1 -1
  367. package/mysql-core/columns/varchar.d.cts +5 -4
  368. package/mysql-core/columns/varchar.d.ts +5 -4
  369. package/mysql-core/columns/varchar.js +4 -4
  370. package/mysql-core/columns/varchar.js.map +1 -1
  371. package/mysql-core/columns/year.cjs.map +1 -1
  372. package/mysql-core/columns/year.d.cts +1 -0
  373. package/mysql-core/columns/year.d.ts +1 -0
  374. package/mysql-core/columns/year.js.map +1 -1
  375. package/mysql-core/dialect.cjs +0 -3
  376. package/mysql-core/dialect.cjs.map +1 -1
  377. package/mysql-core/dialect.d.cts +0 -1
  378. package/mysql-core/dialect.d.ts +0 -1
  379. package/mysql-core/dialect.js +0 -3
  380. package/mysql-core/dialect.js.map +1 -1
  381. package/mysql-core/foreign-keys.cjs +0 -3
  382. package/mysql-core/foreign-keys.cjs.map +1 -1
  383. package/mysql-core/foreign-keys.d.cts +0 -1
  384. package/mysql-core/foreign-keys.d.ts +0 -1
  385. package/mysql-core/foreign-keys.js +0 -3
  386. package/mysql-core/foreign-keys.js.map +1 -1
  387. package/mysql-core/indexes.cjs +0 -2
  388. package/mysql-core/indexes.cjs.map +1 -1
  389. package/mysql-core/indexes.d.cts +0 -1
  390. package/mysql-core/indexes.d.ts +0 -1
  391. package/mysql-core/indexes.js +0 -2
  392. package/mysql-core/indexes.js.map +1 -1
  393. package/mysql-core/primary-keys.cjs +13 -4
  394. package/mysql-core/primary-keys.cjs.map +1 -1
  395. package/mysql-core/primary-keys.d.cts +6 -3
  396. package/mysql-core/primary-keys.d.ts +6 -3
  397. package/mysql-core/primary-keys.js +13 -4
  398. package/mysql-core/primary-keys.js.map +1 -1
  399. package/mysql-core/query-builders/count.cjs.map +1 -1
  400. package/mysql-core/query-builders/count.d.cts +1 -1
  401. package/mysql-core/query-builders/count.d.ts +1 -1
  402. package/mysql-core/query-builders/count.js.map +1 -1
  403. package/mysql-core/query-builders/insert.cjs.map +1 -1
  404. package/mysql-core/query-builders/insert.d.cts +2 -2
  405. package/mysql-core/query-builders/insert.d.ts +2 -2
  406. package/mysql-core/query-builders/insert.js.map +1 -1
  407. package/mysql-core/query-builders/select.cjs +2 -2
  408. package/mysql-core/query-builders/select.cjs.map +1 -1
  409. package/mysql-core/query-builders/select.js +2 -2
  410. package/mysql-core/query-builders/select.js.map +1 -1
  411. package/mysql-core/query-builders/update.cjs.map +1 -1
  412. package/mysql-core/query-builders/update.d.cts +1 -1
  413. package/mysql-core/query-builders/update.d.ts +1 -1
  414. package/mysql-core/query-builders/update.js.map +1 -1
  415. package/mysql-core/schema.cjs +2 -2
  416. package/mysql-core/schema.cjs.map +1 -1
  417. package/mysql-core/schema.js +2 -2
  418. package/mysql-core/schema.js.map +1 -1
  419. package/mysql-core/unique-constraint.cjs +0 -2
  420. package/mysql-core/unique-constraint.cjs.map +1 -1
  421. package/mysql-core/unique-constraint.d.cts +2 -3
  422. package/mysql-core/unique-constraint.d.ts +2 -3
  423. package/mysql-core/unique-constraint.js +0 -2
  424. package/mysql-core/unique-constraint.js.map +1 -1
  425. package/mysql-proxy/driver.cjs +2 -2
  426. package/mysql-proxy/driver.cjs.map +1 -1
  427. package/mysql-proxy/driver.d.cts +1 -2
  428. package/mysql-proxy/driver.d.ts +1 -2
  429. package/mysql-proxy/driver.js +2 -2
  430. package/mysql-proxy/driver.js.map +1 -1
  431. package/mysql2/driver.cjs +14 -10
  432. package/mysql2/driver.cjs.map +1 -1
  433. package/mysql2/driver.d.cts +3 -3
  434. package/mysql2/driver.d.ts +3 -3
  435. package/mysql2/driver.js +14 -10
  436. package/mysql2/driver.js.map +1 -1
  437. package/mysql2/session.cjs.map +1 -1
  438. package/mysql2/session.js.map +1 -1
  439. package/neon-http/driver.cjs +14 -10
  440. package/neon-http/driver.cjs.map +1 -1
  441. package/neon-http/driver.d.cts +3 -3
  442. package/neon-http/driver.d.ts +3 -3
  443. package/neon-http/driver.js +14 -10
  444. package/neon-http/driver.js.map +1 -1
  445. package/neon-http/session.cjs.map +1 -1
  446. package/neon-http/session.d.cts +1 -1
  447. package/neon-http/session.d.ts +1 -1
  448. package/neon-http/session.js.map +1 -1
  449. package/neon-serverless/driver.cjs +14 -10
  450. package/neon-serverless/driver.cjs.map +1 -1
  451. package/neon-serverless/driver.d.cts +3 -3
  452. package/neon-serverless/driver.d.ts +3 -3
  453. package/neon-serverless/driver.js +14 -10
  454. package/neon-serverless/driver.js.map +1 -1
  455. package/neon-serverless/session.cjs.map +1 -1
  456. package/neon-serverless/session.js.map +1 -1
  457. package/node-postgres/driver.cjs +12 -8
  458. package/node-postgres/driver.cjs.map +1 -1
  459. package/node-postgres/driver.d.cts +3 -3
  460. package/node-postgres/driver.d.ts +3 -3
  461. package/node-postgres/driver.js +12 -8
  462. package/node-postgres/driver.js.map +1 -1
  463. package/node-postgres/session.cjs.map +1 -1
  464. package/node-postgres/session.js.map +1 -1
  465. package/package.json +37 -1503
  466. package/pg-core/columns/bigint.cjs.map +1 -1
  467. package/pg-core/columns/bigint.d.cts +2 -0
  468. package/pg-core/columns/bigint.d.ts +2 -0
  469. package/pg-core/columns/bigint.js.map +1 -1
  470. package/pg-core/columns/bigserial.cjs +0 -1
  471. package/pg-core/columns/bigserial.cjs.map +1 -1
  472. package/pg-core/columns/bigserial.d.cts +2 -0
  473. package/pg-core/columns/bigserial.d.ts +2 -0
  474. package/pg-core/columns/bigserial.js +0 -1
  475. package/pg-core/columns/bigserial.js.map +1 -1
  476. package/pg-core/columns/boolean.cjs.map +1 -1
  477. package/pg-core/columns/boolean.d.cts +1 -0
  478. package/pg-core/columns/boolean.d.ts +1 -0
  479. package/pg-core/columns/boolean.js.map +1 -1
  480. package/pg-core/columns/bytea.cjs.map +1 -1
  481. package/pg-core/columns/bytea.d.cts +1 -0
  482. package/pg-core/columns/bytea.d.ts +1 -0
  483. package/pg-core/columns/bytea.js.map +1 -1
  484. package/pg-core/columns/char.cjs +1 -0
  485. package/pg-core/columns/char.cjs.map +1 -1
  486. package/pg-core/columns/char.d.cts +2 -0
  487. package/pg-core/columns/char.d.ts +2 -0
  488. package/pg-core/columns/char.js +1 -0
  489. package/pg-core/columns/char.js.map +1 -1
  490. package/pg-core/columns/cidr.cjs.map +1 -1
  491. package/pg-core/columns/cidr.d.cts +1 -0
  492. package/pg-core/columns/cidr.d.ts +1 -0
  493. package/pg-core/columns/cidr.js.map +1 -1
  494. package/pg-core/columns/common.cjs +14 -10
  495. package/pg-core/columns/common.cjs.map +1 -1
  496. package/pg-core/columns/common.d.cts +3 -4
  497. package/pg-core/columns/common.d.ts +3 -4
  498. package/pg-core/columns/common.js +14 -10
  499. package/pg-core/columns/common.js.map +1 -1
  500. package/pg-core/columns/custom.cjs.map +1 -1
  501. package/pg-core/columns/custom.d.cts +1 -0
  502. package/pg-core/columns/custom.d.ts +1 -0
  503. package/pg-core/columns/custom.js.map +1 -1
  504. package/pg-core/columns/date.cjs.map +1 -1
  505. package/pg-core/columns/date.d.cts +2 -0
  506. package/pg-core/columns/date.d.ts +2 -0
  507. package/pg-core/columns/date.js.map +1 -1
  508. package/pg-core/columns/double-precision.cjs.map +1 -1
  509. package/pg-core/columns/double-precision.d.cts +1 -0
  510. package/pg-core/columns/double-precision.d.ts +1 -0
  511. package/pg-core/columns/double-precision.js.map +1 -1
  512. package/pg-core/columns/enum.cjs.map +1 -1
  513. package/pg-core/columns/enum.d.cts +2 -0
  514. package/pg-core/columns/enum.d.ts +2 -0
  515. package/pg-core/columns/enum.js.map +1 -1
  516. package/pg-core/columns/inet.cjs.map +1 -1
  517. package/pg-core/columns/inet.d.cts +1 -0
  518. package/pg-core/columns/inet.d.ts +1 -0
  519. package/pg-core/columns/inet.js.map +1 -1
  520. package/pg-core/columns/integer.cjs.map +1 -1
  521. package/pg-core/columns/integer.d.cts +1 -0
  522. package/pg-core/columns/integer.d.ts +1 -0
  523. package/pg-core/columns/integer.js.map +1 -1
  524. package/pg-core/columns/interval.cjs.map +1 -1
  525. package/pg-core/columns/interval.d.cts +1 -0
  526. package/pg-core/columns/interval.d.ts +1 -0
  527. package/pg-core/columns/interval.js.map +1 -1
  528. package/pg-core/columns/json.cjs.map +1 -1
  529. package/pg-core/columns/json.d.cts +1 -0
  530. package/pg-core/columns/json.d.ts +1 -0
  531. package/pg-core/columns/json.js.map +1 -1
  532. package/pg-core/columns/jsonb.cjs.map +1 -1
  533. package/pg-core/columns/jsonb.d.cts +1 -0
  534. package/pg-core/columns/jsonb.d.ts +1 -0
  535. package/pg-core/columns/jsonb.js.map +1 -1
  536. package/pg-core/columns/line.cjs +0 -2
  537. package/pg-core/columns/line.cjs.map +1 -1
  538. package/pg-core/columns/line.d.cts +2 -2
  539. package/pg-core/columns/line.d.ts +2 -2
  540. package/pg-core/columns/line.js +0 -2
  541. package/pg-core/columns/line.js.map +1 -1
  542. package/pg-core/columns/macaddr.cjs.map +1 -1
  543. package/pg-core/columns/macaddr.d.cts +1 -0
  544. package/pg-core/columns/macaddr.d.ts +1 -0
  545. package/pg-core/columns/macaddr.js.map +1 -1
  546. package/pg-core/columns/macaddr8.cjs.map +1 -1
  547. package/pg-core/columns/macaddr8.d.cts +1 -0
  548. package/pg-core/columns/macaddr8.d.ts +1 -0
  549. package/pg-core/columns/macaddr8.js.map +1 -1
  550. package/pg-core/columns/numeric.cjs.map +1 -1
  551. package/pg-core/columns/numeric.d.cts +3 -0
  552. package/pg-core/columns/numeric.d.ts +3 -0
  553. package/pg-core/columns/numeric.js.map +1 -1
  554. package/pg-core/columns/point.cjs +0 -2
  555. package/pg-core/columns/point.cjs.map +1 -1
  556. package/pg-core/columns/point.d.cts +2 -2
  557. package/pg-core/columns/point.d.ts +2 -2
  558. package/pg-core/columns/point.js +0 -2
  559. package/pg-core/columns/point.js.map +1 -1
  560. package/pg-core/columns/postgis_extension/geometry.cjs +8 -14
  561. package/pg-core/columns/postgis_extension/geometry.cjs.map +1 -1
  562. package/pg-core/columns/postgis_extension/geometry.d.cts +6 -16
  563. package/pg-core/columns/postgis_extension/geometry.d.ts +6 -16
  564. package/pg-core/columns/postgis_extension/geometry.js +8 -14
  565. package/pg-core/columns/postgis_extension/geometry.js.map +1 -1
  566. package/pg-core/columns/postgis_extension/utils.cjs +3 -3
  567. package/pg-core/columns/postgis_extension/utils.cjs.map +1 -1
  568. package/pg-core/columns/postgis_extension/utils.d.cts +1 -4
  569. package/pg-core/columns/postgis_extension/utils.d.ts +1 -4
  570. package/pg-core/columns/postgis_extension/utils.js +3 -3
  571. package/pg-core/columns/postgis_extension/utils.js.map +1 -1
  572. package/pg-core/columns/real.cjs.map +1 -1
  573. package/pg-core/columns/real.d.cts +1 -0
  574. package/pg-core/columns/real.d.ts +1 -0
  575. package/pg-core/columns/real.js.map +1 -1
  576. package/pg-core/columns/serial.cjs.map +1 -1
  577. package/pg-core/columns/serial.d.cts +1 -0
  578. package/pg-core/columns/serial.d.ts +1 -0
  579. package/pg-core/columns/serial.js.map +1 -1
  580. package/pg-core/columns/smallint.cjs.map +1 -1
  581. package/pg-core/columns/smallint.d.cts +1 -0
  582. package/pg-core/columns/smallint.d.ts +1 -0
  583. package/pg-core/columns/smallint.js.map +1 -1
  584. package/pg-core/columns/smallserial.cjs.map +1 -1
  585. package/pg-core/columns/smallserial.d.cts +1 -0
  586. package/pg-core/columns/smallserial.d.ts +1 -0
  587. package/pg-core/columns/smallserial.js.map +1 -1
  588. package/pg-core/columns/text.cjs.map +1 -1
  589. package/pg-core/columns/text.d.cts +1 -0
  590. package/pg-core/columns/text.d.ts +1 -0
  591. package/pg-core/columns/text.js.map +1 -1
  592. package/pg-core/columns/time.cjs.map +1 -1
  593. package/pg-core/columns/time.d.cts +1 -0
  594. package/pg-core/columns/time.d.ts +1 -0
  595. package/pg-core/columns/time.js.map +1 -1
  596. package/pg-core/columns/timestamp.cjs.map +1 -1
  597. package/pg-core/columns/timestamp.d.cts +2 -0
  598. package/pg-core/columns/timestamp.d.ts +2 -0
  599. package/pg-core/columns/timestamp.js.map +1 -1
  600. package/pg-core/columns/uuid.cjs.map +1 -1
  601. package/pg-core/columns/uuid.d.cts +1 -0
  602. package/pg-core/columns/uuid.d.ts +1 -0
  603. package/pg-core/columns/uuid.js.map +1 -1
  604. package/pg-core/columns/varchar.cjs.map +1 -1
  605. package/pg-core/columns/varchar.d.cts +1 -0
  606. package/pg-core/columns/varchar.d.ts +1 -0
  607. package/pg-core/columns/varchar.js.map +1 -1
  608. package/pg-core/columns/vector_extension/bit.cjs.map +1 -1
  609. package/pg-core/columns/vector_extension/bit.d.cts +1 -0
  610. package/pg-core/columns/vector_extension/bit.d.ts +1 -0
  611. package/pg-core/columns/vector_extension/bit.js.map +1 -1
  612. package/pg-core/columns/vector_extension/halfvec.cjs.map +1 -1
  613. package/pg-core/columns/vector_extension/halfvec.d.cts +1 -0
  614. package/pg-core/columns/vector_extension/halfvec.d.ts +1 -0
  615. package/pg-core/columns/vector_extension/halfvec.js.map +1 -1
  616. package/pg-core/columns/vector_extension/sparsevec.cjs.map +1 -1
  617. package/pg-core/columns/vector_extension/sparsevec.d.cts +1 -0
  618. package/pg-core/columns/vector_extension/sparsevec.d.ts +1 -0
  619. package/pg-core/columns/vector_extension/sparsevec.js.map +1 -1
  620. package/pg-core/columns/vector_extension/vector.cjs.map +1 -1
  621. package/pg-core/columns/vector_extension/vector.d.cts +1 -0
  622. package/pg-core/columns/vector_extension/vector.d.ts +1 -0
  623. package/pg-core/columns/vector_extension/vector.js.map +1 -1
  624. package/pg-core/db.cjs +3 -2
  625. package/pg-core/db.cjs.map +1 -1
  626. package/pg-core/db.d.cts +1 -1
  627. package/pg-core/db.d.ts +1 -1
  628. package/pg-core/db.js +3 -2
  629. package/pg-core/db.js.map +1 -1
  630. package/pg-core/foreign-keys.cjs +0 -4
  631. package/pg-core/foreign-keys.cjs.map +1 -1
  632. package/pg-core/foreign-keys.d.cts +0 -2
  633. package/pg-core/foreign-keys.d.ts +0 -2
  634. package/pg-core/foreign-keys.js +0 -4
  635. package/pg-core/foreign-keys.js.map +1 -1
  636. package/pg-core/indexes.cjs +0 -2
  637. package/pg-core/indexes.cjs.map +1 -1
  638. package/pg-core/indexes.d.cts +0 -1
  639. package/pg-core/indexes.d.ts +0 -1
  640. package/pg-core/indexes.js +0 -2
  641. package/pg-core/indexes.js.map +1 -1
  642. package/pg-core/primary-keys.cjs +0 -2
  643. package/pg-core/primary-keys.cjs.map +1 -1
  644. package/pg-core/primary-keys.d.cts +0 -1
  645. package/pg-core/primary-keys.d.ts +0 -1
  646. package/pg-core/primary-keys.js +0 -2
  647. package/pg-core/primary-keys.js.map +1 -1
  648. package/pg-core/query-builders/count.cjs.map +1 -1
  649. package/pg-core/query-builders/count.d.cts +1 -1
  650. package/pg-core/query-builders/count.d.ts +1 -1
  651. package/pg-core/query-builders/count.js.map +1 -1
  652. package/pg-core/query-builders/insert.cjs.map +1 -1
  653. package/pg-core/query-builders/insert.d.cts +9 -6
  654. package/pg-core/query-builders/insert.d.ts +9 -6
  655. package/pg-core/query-builders/insert.js.map +1 -1
  656. package/pg-core/query-builders/query.cjs +9 -5
  657. package/pg-core/query-builders/query.cjs.map +1 -1
  658. package/pg-core/query-builders/query.d.cts +4 -2
  659. package/pg-core/query-builders/query.d.ts +4 -2
  660. package/pg-core/query-builders/query.js +9 -5
  661. package/pg-core/query-builders/query.js.map +1 -1
  662. package/pg-core/query-builders/select.cjs +9 -8
  663. package/pg-core/query-builders/select.cjs.map +1 -1
  664. package/pg-core/query-builders/select.js +4 -4
  665. package/pg-core/query-builders/select.js.map +1 -1
  666. package/pg-core/query-builders/update.cjs +2 -2
  667. package/pg-core/query-builders/update.cjs.map +1 -1
  668. package/pg-core/query-builders/update.d.cts +1 -1
  669. package/pg-core/query-builders/update.d.ts +1 -1
  670. package/pg-core/query-builders/update.js +2 -2
  671. package/pg-core/query-builders/update.js.map +1 -1
  672. package/pg-core/schema.cjs +8 -8
  673. package/pg-core/schema.cjs.map +1 -1
  674. package/pg-core/schema.js +8 -8
  675. package/pg-core/schema.js.map +1 -1
  676. package/pg-core/unique-constraint.cjs +0 -2
  677. package/pg-core/unique-constraint.cjs.map +1 -1
  678. package/pg-core/unique-constraint.d.cts +0 -1
  679. package/pg-core/unique-constraint.d.ts +0 -1
  680. package/pg-core/unique-constraint.js +0 -2
  681. package/pg-core/unique-constraint.js.map +1 -1
  682. package/pg-core/utils.cjs +2 -1
  683. package/pg-core/utils.cjs.map +1 -1
  684. package/pg-core/utils.d.cts +1 -1
  685. package/pg-core/utils.d.ts +1 -1
  686. package/pg-core/utils.js +2 -1
  687. package/pg-core/utils.js.map +1 -1
  688. package/pg-core/view-common.cjs +0 -3
  689. package/pg-core/view-common.cjs.map +1 -1
  690. package/pg-core/view-common.d.cts +0 -1
  691. package/pg-core/view-common.d.ts +0 -1
  692. package/pg-core/view-common.js +0 -2
  693. package/pg-core/view-common.js.map +1 -1
  694. package/pg-core/view.cjs +5 -2
  695. package/pg-core/view.cjs.map +1 -1
  696. package/pg-core/view.d.cts +2 -1
  697. package/pg-core/view.d.ts +2 -1
  698. package/pg-core/view.js +3 -1
  699. package/pg-core/view.js.map +1 -1
  700. package/pglite/driver.cjs +14 -10
  701. package/pglite/driver.cjs.map +1 -1
  702. package/pglite/driver.d.cts +3 -3
  703. package/pglite/driver.d.ts +3 -3
  704. package/pglite/driver.js +14 -10
  705. package/pglite/driver.js.map +1 -1
  706. package/planetscale-serverless/driver.cjs +15 -11
  707. package/planetscale-serverless/driver.cjs.map +1 -1
  708. package/planetscale-serverless/driver.d.cts +3 -3
  709. package/planetscale-serverless/driver.d.ts +3 -3
  710. package/planetscale-serverless/driver.js +15 -11
  711. package/planetscale-serverless/driver.js.map +1 -1
  712. package/postgres-js/driver.cjs +14 -10
  713. package/postgres-js/driver.cjs.map +1 -1
  714. package/postgres-js/driver.d.cts +3 -3
  715. package/postgres-js/driver.d.ts +3 -3
  716. package/postgres-js/driver.js +14 -10
  717. package/postgres-js/driver.js.map +1 -1
  718. package/singlestore/driver.cjs +26 -19
  719. package/singlestore/driver.cjs.map +1 -1
  720. package/singlestore/driver.d.cts +3 -3
  721. package/singlestore/driver.d.ts +3 -3
  722. package/singlestore/driver.js +26 -19
  723. package/singlestore/driver.js.map +1 -1
  724. package/singlestore/session.cjs.map +1 -1
  725. package/singlestore/session.js.map +1 -1
  726. package/singlestore-core/columns/bigint.cjs.map +1 -1
  727. package/singlestore-core/columns/bigint.d.cts +2 -0
  728. package/singlestore-core/columns/bigint.d.ts +2 -0
  729. package/singlestore-core/columns/bigint.js.map +1 -1
  730. package/singlestore-core/columns/binary.cjs +1 -0
  731. package/singlestore-core/columns/binary.cjs.map +1 -1
  732. package/singlestore-core/columns/binary.d.cts +2 -0
  733. package/singlestore-core/columns/binary.d.ts +2 -0
  734. package/singlestore-core/columns/binary.js +1 -0
  735. package/singlestore-core/columns/binary.js.map +1 -1
  736. package/singlestore-core/columns/boolean.cjs.map +1 -1
  737. package/singlestore-core/columns/boolean.d.cts +1 -0
  738. package/singlestore-core/columns/boolean.d.ts +1 -0
  739. package/singlestore-core/columns/boolean.js.map +1 -1
  740. package/singlestore-core/columns/char.cjs +1 -0
  741. package/singlestore-core/columns/char.cjs.map +1 -1
  742. package/singlestore-core/columns/char.d.cts +2 -0
  743. package/singlestore-core/columns/char.d.ts +2 -0
  744. package/singlestore-core/columns/char.js +1 -0
  745. package/singlestore-core/columns/char.js.map +1 -1
  746. package/singlestore-core/columns/common.cjs +4 -0
  747. package/singlestore-core/columns/common.cjs.map +1 -1
  748. package/singlestore-core/columns/common.d.cts +1 -1
  749. package/singlestore-core/columns/common.d.ts +1 -1
  750. package/singlestore-core/columns/common.js +4 -0
  751. package/singlestore-core/columns/common.js.map +1 -1
  752. package/singlestore-core/columns/custom.cjs.map +1 -1
  753. package/singlestore-core/columns/custom.d.cts +1 -0
  754. package/singlestore-core/columns/custom.d.ts +1 -0
  755. package/singlestore-core/columns/custom.js.map +1 -1
  756. package/singlestore-core/columns/date.cjs.map +1 -1
  757. package/singlestore-core/columns/date.d.cts +2 -0
  758. package/singlestore-core/columns/date.d.ts +2 -0
  759. package/singlestore-core/columns/date.js.map +1 -1
  760. package/singlestore-core/columns/datetime.cjs.map +1 -1
  761. package/singlestore-core/columns/datetime.d.cts +2 -0
  762. package/singlestore-core/columns/datetime.d.ts +2 -0
  763. package/singlestore-core/columns/datetime.js.map +1 -1
  764. package/singlestore-core/columns/decimal.cjs.map +1 -1
  765. package/singlestore-core/columns/decimal.d.cts +3 -0
  766. package/singlestore-core/columns/decimal.d.ts +3 -0
  767. package/singlestore-core/columns/decimal.js.map +1 -1
  768. package/singlestore-core/columns/double.cjs.map +1 -1
  769. package/singlestore-core/columns/double.d.cts +1 -0
  770. package/singlestore-core/columns/double.d.ts +1 -0
  771. package/singlestore-core/columns/double.js.map +1 -1
  772. package/singlestore-core/columns/enum.cjs.map +1 -1
  773. package/singlestore-core/columns/enum.d.cts +1 -0
  774. package/singlestore-core/columns/enum.d.ts +1 -0
  775. package/singlestore-core/columns/enum.js.map +1 -1
  776. package/singlestore-core/columns/float.cjs.map +1 -1
  777. package/singlestore-core/columns/float.d.cts +1 -0
  778. package/singlestore-core/columns/float.d.ts +1 -0
  779. package/singlestore-core/columns/float.js.map +1 -1
  780. package/singlestore-core/columns/int.cjs.map +1 -1
  781. package/singlestore-core/columns/int.d.cts +1 -0
  782. package/singlestore-core/columns/int.d.ts +1 -0
  783. package/singlestore-core/columns/int.js.map +1 -1
  784. package/singlestore-core/columns/json.cjs.map +1 -1
  785. package/singlestore-core/columns/json.d.cts +1 -0
  786. package/singlestore-core/columns/json.d.ts +1 -0
  787. package/singlestore-core/columns/json.js.map +1 -1
  788. package/singlestore-core/columns/mediumint.cjs.map +1 -1
  789. package/singlestore-core/columns/mediumint.d.cts +1 -0
  790. package/singlestore-core/columns/mediumint.d.ts +1 -0
  791. package/singlestore-core/columns/mediumint.js.map +1 -1
  792. package/singlestore-core/columns/real.cjs.map +1 -1
  793. package/singlestore-core/columns/real.d.cts +1 -0
  794. package/singlestore-core/columns/real.d.ts +1 -0
  795. package/singlestore-core/columns/real.js.map +1 -1
  796. package/singlestore-core/columns/serial.cjs.map +1 -1
  797. package/singlestore-core/columns/serial.d.cts +1 -0
  798. package/singlestore-core/columns/serial.d.ts +1 -0
  799. package/singlestore-core/columns/serial.js.map +1 -1
  800. package/singlestore-core/columns/smallint.cjs.map +1 -1
  801. package/singlestore-core/columns/smallint.d.cts +1 -0
  802. package/singlestore-core/columns/smallint.d.ts +1 -0
  803. package/singlestore-core/columns/smallint.js.map +1 -1
  804. package/singlestore-core/columns/text.cjs.map +1 -1
  805. package/singlestore-core/columns/text.d.cts +1 -0
  806. package/singlestore-core/columns/text.d.ts +1 -0
  807. package/singlestore-core/columns/text.js.map +1 -1
  808. package/singlestore-core/columns/time.cjs.map +1 -1
  809. package/singlestore-core/columns/time.d.cts +1 -0
  810. package/singlestore-core/columns/time.d.ts +1 -0
  811. package/singlestore-core/columns/time.js.map +1 -1
  812. package/singlestore-core/columns/timestamp.cjs.map +1 -1
  813. package/singlestore-core/columns/timestamp.d.cts +2 -0
  814. package/singlestore-core/columns/timestamp.d.ts +2 -0
  815. package/singlestore-core/columns/timestamp.js.map +1 -1
  816. package/singlestore-core/columns/tinyint.cjs.map +1 -1
  817. package/singlestore-core/columns/tinyint.d.cts +1 -0
  818. package/singlestore-core/columns/tinyint.d.ts +1 -0
  819. package/singlestore-core/columns/tinyint.js.map +1 -1
  820. package/singlestore-core/columns/varbinary.cjs.map +1 -1
  821. package/singlestore-core/columns/varbinary.d.cts +1 -0
  822. package/singlestore-core/columns/varbinary.d.ts +1 -0
  823. package/singlestore-core/columns/varbinary.js.map +1 -1
  824. package/singlestore-core/columns/varchar.cjs.map +1 -1
  825. package/singlestore-core/columns/varchar.d.cts +1 -0
  826. package/singlestore-core/columns/varchar.d.ts +1 -0
  827. package/singlestore-core/columns/varchar.js.map +1 -1
  828. package/singlestore-core/columns/vector.cjs.map +1 -1
  829. package/singlestore-core/columns/vector.d.cts +2 -0
  830. package/singlestore-core/columns/vector.d.ts +2 -0
  831. package/singlestore-core/columns/vector.js.map +1 -1
  832. package/singlestore-core/columns/year.cjs.map +1 -1
  833. package/singlestore-core/columns/year.d.cts +1 -0
  834. package/singlestore-core/columns/year.d.ts +1 -0
  835. package/singlestore-core/columns/year.js.map +1 -1
  836. package/singlestore-core/indexes.cjs +0 -2
  837. package/singlestore-core/indexes.cjs.map +1 -1
  838. package/singlestore-core/indexes.d.cts +0 -1
  839. package/singlestore-core/indexes.d.ts +0 -1
  840. package/singlestore-core/indexes.js +0 -2
  841. package/singlestore-core/indexes.js.map +1 -1
  842. package/singlestore-core/primary-keys.cjs +0 -2
  843. package/singlestore-core/primary-keys.cjs.map +1 -1
  844. package/singlestore-core/primary-keys.d.cts +0 -1
  845. package/singlestore-core/primary-keys.d.ts +0 -1
  846. package/singlestore-core/primary-keys.js +0 -2
  847. package/singlestore-core/primary-keys.js.map +1 -1
  848. package/singlestore-core/query-builders/count.cjs.map +1 -1
  849. package/singlestore-core/query-builders/count.d.cts +1 -1
  850. package/singlestore-core/query-builders/count.d.ts +1 -1
  851. package/singlestore-core/query-builders/count.js.map +1 -1
  852. package/singlestore-core/query-builders/insert.cjs.map +1 -1
  853. package/singlestore-core/query-builders/insert.d.cts +1 -1
  854. package/singlestore-core/query-builders/insert.d.ts +1 -1
  855. package/singlestore-core/query-builders/insert.js.map +1 -1
  856. package/singlestore-core/query-builders/select.cjs +2 -2
  857. package/singlestore-core/query-builders/select.cjs.map +1 -1
  858. package/singlestore-core/query-builders/select.js +2 -2
  859. package/singlestore-core/query-builders/select.js.map +1 -1
  860. package/singlestore-core/query-builders/update.cjs.map +1 -1
  861. package/singlestore-core/query-builders/update.d.cts +1 -1
  862. package/singlestore-core/query-builders/update.d.ts +1 -1
  863. package/singlestore-core/query-builders/update.js.map +1 -1
  864. package/singlestore-core/unique-constraint.cjs +0 -2
  865. package/singlestore-core/unique-constraint.cjs.map +1 -1
  866. package/singlestore-core/unique-constraint.d.cts +2 -3
  867. package/singlestore-core/unique-constraint.d.ts +2 -3
  868. package/singlestore-core/unique-constraint.js +0 -2
  869. package/singlestore-core/unique-constraint.js.map +1 -1
  870. package/sql/sql.cjs +3 -10
  871. package/sql/sql.cjs.map +1 -1
  872. package/sql/sql.d.cts +1 -1
  873. package/sql/sql.d.ts +1 -1
  874. package/sql/sql.js +3 -10
  875. package/sql/sql.js.map +1 -1
  876. package/sql-js/session.cjs.map +1 -1
  877. package/sql-js/session.js.map +1 -1
  878. package/sqlite-core/columns/blob.cjs.map +1 -1
  879. package/sqlite-core/columns/blob.d.cts +3 -0
  880. package/sqlite-core/columns/blob.d.ts +3 -0
  881. package/sqlite-core/columns/blob.js.map +1 -1
  882. package/sqlite-core/columns/common.cjs +4 -0
  883. package/sqlite-core/columns/common.cjs.map +1 -1
  884. package/sqlite-core/columns/common.js +4 -0
  885. package/sqlite-core/columns/common.js.map +1 -1
  886. package/sqlite-core/columns/custom.cjs.map +1 -1
  887. package/sqlite-core/columns/custom.d.cts +1 -0
  888. package/sqlite-core/columns/custom.d.ts +1 -0
  889. package/sqlite-core/columns/custom.js.map +1 -1
  890. package/sqlite-core/columns/integer.cjs.map +1 -1
  891. package/sqlite-core/columns/integer.d.cts +3 -0
  892. package/sqlite-core/columns/integer.d.ts +3 -0
  893. package/sqlite-core/columns/integer.js.map +1 -1
  894. package/sqlite-core/columns/numeric.cjs.map +1 -1
  895. package/sqlite-core/columns/numeric.d.cts +3 -0
  896. package/sqlite-core/columns/numeric.d.ts +3 -0
  897. package/sqlite-core/columns/numeric.js.map +1 -1
  898. package/sqlite-core/columns/real.cjs.map +1 -1
  899. package/sqlite-core/columns/real.d.cts +1 -0
  900. package/sqlite-core/columns/real.d.ts +1 -0
  901. package/sqlite-core/columns/real.js.map +1 -1
  902. package/sqlite-core/columns/text.cjs.map +1 -1
  903. package/sqlite-core/columns/text.d.cts +2 -0
  904. package/sqlite-core/columns/text.d.ts +2 -0
  905. package/sqlite-core/columns/text.js.map +1 -1
  906. package/sqlite-core/foreign-keys.cjs +0 -3
  907. package/sqlite-core/foreign-keys.cjs.map +1 -1
  908. package/sqlite-core/foreign-keys.d.cts +14 -1
  909. package/sqlite-core/foreign-keys.d.ts +14 -1
  910. package/sqlite-core/foreign-keys.js +0 -3
  911. package/sqlite-core/foreign-keys.js.map +1 -1
  912. package/sqlite-core/indexes.cjs +0 -2
  913. package/sqlite-core/indexes.cjs.map +1 -1
  914. package/sqlite-core/indexes.d.cts +0 -1
  915. package/sqlite-core/indexes.d.ts +0 -1
  916. package/sqlite-core/indexes.js +0 -2
  917. package/sqlite-core/indexes.js.map +1 -1
  918. package/sqlite-core/primary-keys.cjs +0 -2
  919. package/sqlite-core/primary-keys.cjs.map +1 -1
  920. package/sqlite-core/primary-keys.d.cts +0 -1
  921. package/sqlite-core/primary-keys.d.ts +0 -1
  922. package/sqlite-core/primary-keys.js +0 -2
  923. package/sqlite-core/primary-keys.js.map +1 -1
  924. package/sqlite-core/query-builders/count.cjs.map +1 -1
  925. package/sqlite-core/query-builders/count.d.cts +1 -1
  926. package/sqlite-core/query-builders/count.d.ts +1 -1
  927. package/sqlite-core/query-builders/count.js.map +1 -1
  928. package/sqlite-core/query-builders/insert.cjs.map +1 -1
  929. package/sqlite-core/query-builders/insert.d.cts +2 -2
  930. package/sqlite-core/query-builders/insert.d.ts +2 -2
  931. package/sqlite-core/query-builders/insert.js.map +1 -1
  932. package/sqlite-core/query-builders/update.cjs +2 -2
  933. package/sqlite-core/query-builders/update.cjs.map +1 -1
  934. package/sqlite-core/query-builders/update.d.cts +1 -1
  935. package/sqlite-core/query-builders/update.d.ts +1 -1
  936. package/sqlite-core/query-builders/update.js +2 -2
  937. package/sqlite-core/query-builders/update.js.map +1 -1
  938. package/sqlite-core/unique-constraint.cjs +0 -2
  939. package/sqlite-core/unique-constraint.cjs.map +1 -1
  940. package/sqlite-core/unique-constraint.d.cts +2 -3
  941. package/sqlite-core/unique-constraint.d.ts +2 -3
  942. package/sqlite-core/unique-constraint.js +0 -2
  943. package/sqlite-core/unique-constraint.js.map +1 -1
  944. package/tidb-serverless/driver.cjs +12 -8
  945. package/tidb-serverless/driver.cjs.map +1 -1
  946. package/tidb-serverless/driver.d.cts +3 -3
  947. package/tidb-serverless/driver.d.ts +3 -3
  948. package/tidb-serverless/driver.js +12 -8
  949. package/tidb-serverless/driver.js.map +1 -1
  950. package/tracing.cjs +3 -3
  951. package/tracing.cjs.map +1 -1
  952. package/tracing.js +3 -3
  953. package/tracing.js.map +1 -1
  954. package/tursodatabase/database.cjs +10 -6
  955. package/tursodatabase/database.cjs.map +1 -1
  956. package/tursodatabase/database.d.cts +3 -3
  957. package/tursodatabase/database.d.ts +3 -3
  958. package/tursodatabase/database.js +10 -6
  959. package/tursodatabase/database.js.map +1 -1
  960. package/tursodatabase/wasm.cjs +10 -6
  961. package/tursodatabase/wasm.cjs.map +1 -1
  962. package/tursodatabase/wasm.d.cts +3 -3
  963. package/tursodatabase/wasm.d.ts +3 -3
  964. package/tursodatabase/wasm.js +10 -6
  965. package/tursodatabase/wasm.js.map +1 -1
  966. package/vercel-postgres/session.cjs.map +1 -1
  967. package/vercel-postgres/session.js.map +1 -1
  968. package/version.cjs +1 -1
  969. package/version.d.cts +1 -1
  970. package/version.d.ts +1 -1
  971. package/version.js +1 -1
  972. package/cockroach/driver.cjs +0 -109
  973. package/cockroach/driver.cjs.map +0 -1
  974. package/cockroach/driver.d.cts +0 -42
  975. package/cockroach/driver.d.ts +0 -42
  976. package/cockroach/driver.js +0 -73
  977. package/cockroach/driver.js.map +0 -1
  978. package/cockroach/index.cjs +0 -25
  979. package/cockroach/index.cjs.map +0 -1
  980. package/cockroach/index.d.cts +0 -2
  981. package/cockroach/index.d.ts +0 -2
  982. package/cockroach/index.js +0 -3
  983. package/cockroach/index.js.map +0 -1
  984. package/cockroach/migrator.cjs +0 -33
  985. package/cockroach/migrator.cjs.map +0 -1
  986. package/cockroach/migrator.d.cts +0 -3
  987. package/cockroach/migrator.d.ts +0 -3
  988. package/cockroach/migrator.js +0 -9
  989. package/cockroach/migrator.js.map +0 -1
  990. package/cockroach/session.cjs +0 -253
  991. package/cockroach/session.cjs.map +0 -1
  992. package/cockroach/session.d.cts +0 -48
  993. package/cockroach/session.d.ts +0 -48
  994. package/cockroach/session.js +0 -217
  995. package/cockroach/session.js.map +0 -1
  996. package/cockroach-core/alias.cjs +0 -32
  997. package/cockroach-core/alias.cjs.map +0 -1
  998. package/cockroach-core/alias.d.cts +0 -4
  999. package/cockroach-core/alias.d.ts +0 -4
  1000. package/cockroach-core/alias.js +0 -8
  1001. package/cockroach-core/alias.js.map +0 -1
  1002. package/cockroach-core/checks.cjs +0 -58
  1003. package/cockroach-core/checks.cjs.map +0 -1
  1004. package/cockroach-core/checks.d.cts +0 -18
  1005. package/cockroach-core/checks.d.ts +0 -18
  1006. package/cockroach-core/checks.js +0 -32
  1007. package/cockroach-core/checks.js.map +0 -1
  1008. package/cockroach-core/columns/all.cjs +0 -81
  1009. package/cockroach-core/columns/all.cjs.map +0 -1
  1010. package/cockroach-core/columns/all.d.cts +0 -52
  1011. package/cockroach-core/columns/all.d.ts +0 -52
  1012. package/cockroach-core/columns/all.js +0 -57
  1013. package/cockroach-core/columns/all.js.map +0 -1
  1014. package/cockroach-core/columns/bigint.cjs +0 -104
  1015. package/cockroach-core/columns/bigint.cjs.map +0 -1
  1016. package/cockroach-core/columns/bigint.d.cts +0 -37
  1017. package/cockroach-core/columns/bigint.d.ts +0 -37
  1018. package/cockroach-core/columns/bigint.js +0 -75
  1019. package/cockroach-core/columns/bigint.js.map +0 -1
  1020. package/cockroach-core/columns/bit.cjs +0 -61
  1021. package/cockroach-core/columns/bit.cjs.map +0 -1
  1022. package/cockroach-core/columns/bit.d.cts +0 -29
  1023. package/cockroach-core/columns/bit.d.ts +0 -29
  1024. package/cockroach-core/columns/bit.js +0 -35
  1025. package/cockroach-core/columns/bit.js.map +0 -1
  1026. package/cockroach-core/columns/bool.cjs +0 -59
  1027. package/cockroach-core/columns/bool.cjs.map +0 -1
  1028. package/cockroach-core/columns/bool.d.cts +0 -17
  1029. package/cockroach-core/columns/bool.d.ts +0 -17
  1030. package/cockroach-core/columns/bool.js +0 -32
  1031. package/cockroach-core/columns/bool.js.map +0 -1
  1032. package/cockroach-core/columns/char.cjs +0 -62
  1033. package/cockroach-core/columns/char.cjs.map +0 -1
  1034. package/cockroach-core/columns/char.d.cts +0 -31
  1035. package/cockroach-core/columns/char.d.ts +0 -31
  1036. package/cockroach-core/columns/char.js +0 -36
  1037. package/cockroach-core/columns/char.js.map +0 -1
  1038. package/cockroach-core/columns/common.cjs +0 -198
  1039. package/cockroach-core/columns/common.cjs.map +0 -1
  1040. package/cockroach-core/columns/common.d.cts +0 -98
  1041. package/cockroach-core/columns/common.d.ts +0 -98
  1042. package/cockroach-core/columns/common.js +0 -168
  1043. package/cockroach-core/columns/common.js.map +0 -1
  1044. package/cockroach-core/columns/custom.cjs +0 -102
  1045. package/cockroach-core/columns/custom.cjs.map +0 -1
  1046. package/cockroach-core/columns/custom.d.cts +0 -261
  1047. package/cockroach-core/columns/custom.d.ts +0 -261
  1048. package/cockroach-core/columns/custom.js +0 -76
  1049. package/cockroach-core/columns/custom.js.map +0 -1
  1050. package/cockroach-core/columns/date.cjs +0 -91
  1051. package/cockroach-core/columns/date.cjs.map +0 -1
  1052. package/cockroach-core/columns/date.common.cjs +0 -37
  1053. package/cockroach-core/columns/date.common.cjs.map +0 -1
  1054. package/cockroach-core/columns/date.common.d.cts +0 -7
  1055. package/cockroach-core/columns/date.common.d.ts +0 -7
  1056. package/cockroach-core/columns/date.common.js +0 -13
  1057. package/cockroach-core/columns/date.common.js.map +0 -1
  1058. package/cockroach-core/columns/date.d.cts +0 -36
  1059. package/cockroach-core/columns/date.d.ts +0 -36
  1060. package/cockroach-core/columns/date.js +0 -63
  1061. package/cockroach-core/columns/date.js.map +0 -1
  1062. package/cockroach-core/columns/decimal.cjs +0 -164
  1063. package/cockroach-core/columns/decimal.cjs.map +0 -1
  1064. package/cockroach-core/columns/decimal.d.cts +0 -80
  1065. package/cockroach-core/columns/decimal.d.ts +0 -80
  1066. package/cockroach-core/columns/decimal.js +0 -133
  1067. package/cockroach-core/columns/decimal.js.map +0 -1
  1068. package/cockroach-core/columns/enum.cjs +0 -127
  1069. package/cockroach-core/columns/enum.cjs.map +0 -1
  1070. package/cockroach-core/columns/enum.d.cts +0 -64
  1071. package/cockroach-core/columns/enum.d.ts +0 -64
  1072. package/cockroach-core/columns/enum.js +0 -96
  1073. package/cockroach-core/columns/enum.js.map +0 -1
  1074. package/cockroach-core/columns/float.cjs +0 -65
  1075. package/cockroach-core/columns/float.cjs.map +0 -1
  1076. package/cockroach-core/columns/float.d.cts +0 -18
  1077. package/cockroach-core/columns/float.d.ts +0 -18
  1078. package/cockroach-core/columns/float.js +0 -38
  1079. package/cockroach-core/columns/float.js.map +0 -1
  1080. package/cockroach-core/columns/geometry.cjs +0 -105
  1081. package/cockroach-core/columns/geometry.cjs.map +0 -1
  1082. package/cockroach-core/columns/geometry.d.cts +0 -60
  1083. package/cockroach-core/columns/geometry.d.ts +0 -60
  1084. package/cockroach-core/columns/geometry.js +0 -77
  1085. package/cockroach-core/columns/geometry.js.map +0 -1
  1086. package/cockroach-core/columns/index.cjs +0 -71
  1087. package/cockroach-core/columns/index.cjs.map +0 -1
  1088. package/cockroach-core/columns/index.d.cts +0 -25
  1089. package/cockroach-core/columns/index.d.ts +0 -25
  1090. package/cockroach-core/columns/index.js +0 -26
  1091. package/cockroach-core/columns/index.js.map +0 -1
  1092. package/cockroach-core/columns/inet.cjs +0 -56
  1093. package/cockroach-core/columns/inet.cjs.map +0 -1
  1094. package/cockroach-core/columns/inet.d.cts +0 -16
  1095. package/cockroach-core/columns/inet.d.ts +0 -16
  1096. package/cockroach-core/columns/inet.js +0 -30
  1097. package/cockroach-core/columns/inet.js.map +0 -1
  1098. package/cockroach-core/columns/int.common.cjs +0 -55
  1099. package/cockroach-core/columns/int.common.cjs.map +0 -1
  1100. package/cockroach-core/columns/int.common.d.cts +0 -11
  1101. package/cockroach-core/columns/int.common.d.ts +0 -11
  1102. package/cockroach-core/columns/int.common.js +0 -31
  1103. package/cockroach-core/columns/int.common.js.map +0 -1
  1104. package/cockroach-core/columns/integer.cjs +0 -63
  1105. package/cockroach-core/columns/integer.cjs.map +0 -1
  1106. package/cockroach-core/columns/integer.d.cts +0 -18
  1107. package/cockroach-core/columns/integer.d.ts +0 -18
  1108. package/cockroach-core/columns/integer.js +0 -37
  1109. package/cockroach-core/columns/integer.js.map +0 -1
  1110. package/cockroach-core/columns/interval.cjs +0 -63
  1111. package/cockroach-core/columns/interval.cjs.map +0 -1
  1112. package/cockroach-core/columns/interval.d.cts +0 -28
  1113. package/cockroach-core/columns/interval.d.ts +0 -28
  1114. package/cockroach-core/columns/interval.js +0 -37
  1115. package/cockroach-core/columns/interval.js.map +0 -1
  1116. package/cockroach-core/columns/jsonb.cjs +0 -72
  1117. package/cockroach-core/columns/jsonb.cjs.map +0 -1
  1118. package/cockroach-core/columns/jsonb.d.cts +0 -20
  1119. package/cockroach-core/columns/jsonb.d.ts +0 -20
  1120. package/cockroach-core/columns/jsonb.js +0 -46
  1121. package/cockroach-core/columns/jsonb.js.map +0 -1
  1122. package/cockroach-core/columns/real.cjs +0 -66
  1123. package/cockroach-core/columns/real.cjs.map +0 -1
  1124. package/cockroach-core/columns/real.d.cts +0 -21
  1125. package/cockroach-core/columns/real.d.ts +0 -21
  1126. package/cockroach-core/columns/real.js +0 -40
  1127. package/cockroach-core/columns/real.js.map +0 -1
  1128. package/cockroach-core/columns/smallint.cjs +0 -68
  1129. package/cockroach-core/columns/smallint.cjs.map +0 -1
  1130. package/cockroach-core/columns/smallint.d.cts +0 -19
  1131. package/cockroach-core/columns/smallint.d.ts +0 -19
  1132. package/cockroach-core/columns/smallint.js +0 -41
  1133. package/cockroach-core/columns/smallint.js.map +0 -1
  1134. package/cockroach-core/columns/string.cjs +0 -67
  1135. package/cockroach-core/columns/string.cjs.map +0 -1
  1136. package/cockroach-core/columns/string.d.cts +0 -36
  1137. package/cockroach-core/columns/string.d.ts +0 -36
  1138. package/cockroach-core/columns/string.js +0 -40
  1139. package/cockroach-core/columns/string.js.map +0 -1
  1140. package/cockroach-core/columns/time.cjs +0 -70
  1141. package/cockroach-core/columns/time.cjs.map +0 -1
  1142. package/cockroach-core/columns/time.d.cts +0 -31
  1143. package/cockroach-core/columns/time.d.ts +0 -31
  1144. package/cockroach-core/columns/time.js +0 -44
  1145. package/cockroach-core/columns/time.js.map +0 -1
  1146. package/cockroach-core/columns/timestamp.cjs +0 -111
  1147. package/cockroach-core/columns/timestamp.cjs.map +0 -1
  1148. package/cockroach-core/columns/timestamp.d.cts +0 -52
  1149. package/cockroach-core/columns/timestamp.d.ts +0 -52
  1150. package/cockroach-core/columns/timestamp.js +0 -83
  1151. package/cockroach-core/columns/timestamp.js.map +0 -1
  1152. package/cockroach-core/columns/utils.cjs +0 -65
  1153. package/cockroach-core/columns/utils.cjs.map +0 -1
  1154. package/cockroach-core/columns/utils.d.cts +0 -4
  1155. package/cockroach-core/columns/utils.d.ts +0 -4
  1156. package/cockroach-core/columns/utils.js +0 -41
  1157. package/cockroach-core/columns/utils.js.map +0 -1
  1158. package/cockroach-core/columns/uuid.cjs +0 -63
  1159. package/cockroach-core/columns/uuid.cjs.map +0 -1
  1160. package/cockroach-core/columns/uuid.d.cts +0 -20
  1161. package/cockroach-core/columns/uuid.d.ts +0 -20
  1162. package/cockroach-core/columns/uuid.js +0 -37
  1163. package/cockroach-core/columns/uuid.js.map +0 -1
  1164. package/cockroach-core/columns/varbit.cjs +0 -59
  1165. package/cockroach-core/columns/varbit.cjs.map +0 -1
  1166. package/cockroach-core/columns/varbit.d.cts +0 -24
  1167. package/cockroach-core/columns/varbit.d.ts +0 -24
  1168. package/cockroach-core/columns/varbit.js +0 -33
  1169. package/cockroach-core/columns/varbit.js.map +0 -1
  1170. package/cockroach-core/columns/varchar.cjs +0 -61
  1171. package/cockroach-core/columns/varchar.cjs.map +0 -1
  1172. package/cockroach-core/columns/varchar.d.cts +0 -30
  1173. package/cockroach-core/columns/varchar.d.ts +0 -30
  1174. package/cockroach-core/columns/varchar.js +0 -35
  1175. package/cockroach-core/columns/varchar.js.map +0 -1
  1176. package/cockroach-core/columns/vector.cjs +0 -65
  1177. package/cockroach-core/columns/vector.cjs.map +0 -1
  1178. package/cockroach-core/columns/vector.d.cts +0 -26
  1179. package/cockroach-core/columns/vector.d.ts +0 -26
  1180. package/cockroach-core/columns/vector.js +0 -39
  1181. package/cockroach-core/columns/vector.js.map +0 -1
  1182. package/cockroach-core/db.cjs +0 -346
  1183. package/cockroach-core/db.cjs.map +0 -1
  1184. package/cockroach-core/db.d.cts +0 -282
  1185. package/cockroach-core/db.d.ts +0 -282
  1186. package/cockroach-core/db.js +0 -327
  1187. package/cockroach-core/db.js.map +0 -1
  1188. package/cockroach-core/dialect.cjs +0 -1146
  1189. package/cockroach-core/dialect.cjs.map +0 -1
  1190. package/cockroach-core/dialect.d.cts +0 -65
  1191. package/cockroach-core/dialect.d.ts +0 -65
  1192. package/cockroach-core/dialect.js +0 -1126
  1193. package/cockroach-core/dialect.js.map +0 -1
  1194. package/cockroach-core/expressions.cjs +0 -49
  1195. package/cockroach-core/expressions.cjs.map +0 -1
  1196. package/cockroach-core/expressions.d.cts +0 -8
  1197. package/cockroach-core/expressions.d.ts +0 -8
  1198. package/cockroach-core/expressions.js +0 -22
  1199. package/cockroach-core/expressions.js.map +0 -1
  1200. package/cockroach-core/foreign-keys.cjs +0 -95
  1201. package/cockroach-core/foreign-keys.cjs.map +0 -1
  1202. package/cockroach-core/foreign-keys.d.cts +0 -53
  1203. package/cockroach-core/foreign-keys.d.ts +0 -53
  1204. package/cockroach-core/foreign-keys.js +0 -69
  1205. package/cockroach-core/foreign-keys.js.map +0 -1
  1206. package/cockroach-core/index.cjs +0 -61
  1207. package/cockroach-core/index.cjs.map +0 -1
  1208. package/cockroach-core/index.d.cts +0 -20
  1209. package/cockroach-core/index.d.ts +0 -20
  1210. package/cockroach-core/index.js +0 -21
  1211. package/cockroach-core/index.js.map +0 -1
  1212. package/cockroach-core/indexes.cjs +0 -139
  1213. package/cockroach-core/indexes.cjs.map +0 -1
  1214. package/cockroach-core/indexes.d.cts +0 -65
  1215. package/cockroach-core/indexes.d.ts +0 -65
  1216. package/cockroach-core/indexes.js +0 -111
  1217. package/cockroach-core/indexes.js.map +0 -1
  1218. package/cockroach-core/policies.cjs +0 -58
  1219. package/cockroach-core/policies.cjs.map +0 -1
  1220. package/cockroach-core/policies.d.cts +0 -24
  1221. package/cockroach-core/policies.d.ts +0 -24
  1222. package/cockroach-core/policies.js +0 -33
  1223. package/cockroach-core/policies.js.map +0 -1
  1224. package/cockroach-core/primary-keys.cjs +0 -66
  1225. package/cockroach-core/primary-keys.cjs.map +0 -1
  1226. package/cockroach-core/primary-keys.d.cts +0 -24
  1227. package/cockroach-core/primary-keys.d.ts +0 -24
  1228. package/cockroach-core/primary-keys.js +0 -40
  1229. package/cockroach-core/primary-keys.js.map +0 -1
  1230. package/cockroach-core/query-builders/count.cjs +0 -79
  1231. package/cockroach-core/query-builders/count.cjs.map +0 -1
  1232. package/cockroach-core/query-builders/count.d.cts +0 -29
  1233. package/cockroach-core/query-builders/count.d.ts +0 -29
  1234. package/cockroach-core/query-builders/count.js +0 -55
  1235. package/cockroach-core/query-builders/count.js.map +0 -1
  1236. package/cockroach-core/query-builders/delete.cjs +0 -124
  1237. package/cockroach-core/query-builders/delete.cjs.map +0 -1
  1238. package/cockroach-core/query-builders/delete.d.cts +0 -103
  1239. package/cockroach-core/query-builders/delete.d.ts +0 -103
  1240. package/cockroach-core/query-builders/delete.js +0 -100
  1241. package/cockroach-core/query-builders/delete.js.map +0 -1
  1242. package/cockroach-core/query-builders/index.cjs +0 -35
  1243. package/cockroach-core/query-builders/index.cjs.map +0 -1
  1244. package/cockroach-core/query-builders/index.d.cts +0 -7
  1245. package/cockroach-core/query-builders/index.d.ts +0 -7
  1246. package/cockroach-core/query-builders/index.js +0 -8
  1247. package/cockroach-core/query-builders/index.js.map +0 -1
  1248. package/cockroach-core/query-builders/insert.cjs +0 -213
  1249. package/cockroach-core/query-builders/insert.cjs.map +0 -1
  1250. package/cockroach-core/query-builders/insert.d.cts +0 -168
  1251. package/cockroach-core/query-builders/insert.d.ts +0 -168
  1252. package/cockroach-core/query-builders/insert.js +0 -188
  1253. package/cockroach-core/query-builders/insert.js.map +0 -1
  1254. package/cockroach-core/query-builders/query-builder.cjs +0 -118
  1255. package/cockroach-core/query-builders/query-builder.cjs.map +0 -1
  1256. package/cockroach-core/query-builders/query-builder.d.cts +0 -37
  1257. package/cockroach-core/query-builders/query-builder.d.ts +0 -37
  1258. package/cockroach-core/query-builders/query-builder.js +0 -94
  1259. package/cockroach-core/query-builders/query-builder.js.map +0 -1
  1260. package/cockroach-core/query-builders/query.cjs +0 -145
  1261. package/cockroach-core/query-builders/query.cjs.map +0 -1
  1262. package/cockroach-core/query-builders/query.d.cts +0 -47
  1263. package/cockroach-core/query-builders/query.d.ts +0 -47
  1264. package/cockroach-core/query-builders/query.js +0 -122
  1265. package/cockroach-core/query-builders/query.js.map +0 -1
  1266. package/cockroach-core/query-builders/raw.cjs +0 -57
  1267. package/cockroach-core/query-builders/raw.cjs.map +0 -1
  1268. package/cockroach-core/query-builders/raw.d.cts +0 -22
  1269. package/cockroach-core/query-builders/raw.d.ts +0 -22
  1270. package/cockroach-core/query-builders/raw.js +0 -33
  1271. package/cockroach-core/query-builders/raw.js.map +0 -1
  1272. package/cockroach-core/query-builders/refresh-materialized-view.cjs +0 -83
  1273. package/cockroach-core/query-builders/refresh-materialized-view.cjs.map +0 -1
  1274. package/cockroach-core/query-builders/refresh-materialized-view.d.cts +0 -28
  1275. package/cockroach-core/query-builders/refresh-materialized-view.d.ts +0 -28
  1276. package/cockroach-core/query-builders/refresh-materialized-view.js +0 -59
  1277. package/cockroach-core/query-builders/refresh-materialized-view.js.map +0 -1
  1278. package/cockroach-core/query-builders/select.cjs +0 -847
  1279. package/cockroach-core/query-builders/select.cjs.map +0 -1
  1280. package/cockroach-core/query-builders/select.d.cts +0 -787
  1281. package/cockroach-core/query-builders/select.d.ts +0 -787
  1282. package/cockroach-core/query-builders/select.js +0 -821
  1283. package/cockroach-core/query-builders/select.js.map +0 -1
  1284. package/cockroach-core/query-builders/select.types.cjs +0 -17
  1285. package/cockroach-core/query-builders/select.types.cjs.map +0 -1
  1286. package/cockroach-core/query-builders/select.types.d.cts +0 -140
  1287. package/cockroach-core/query-builders/select.types.d.ts +0 -140
  1288. package/cockroach-core/query-builders/select.types.js +0 -1
  1289. package/cockroach-core/query-builders/select.types.js.map +0 -1
  1290. package/cockroach-core/query-builders/update.cjs +0 -240
  1291. package/cockroach-core/query-builders/update.cjs.map +0 -1
  1292. package/cockroach-core/query-builders/update.d.cts +0 -170
  1293. package/cockroach-core/query-builders/update.d.ts +0 -170
  1294. package/cockroach-core/query-builders/update.js +0 -219
  1295. package/cockroach-core/query-builders/update.js.map +0 -1
  1296. package/cockroach-core/roles.cjs +0 -54
  1297. package/cockroach-core/roles.cjs.map +0 -1
  1298. package/cockroach-core/roles.d.cts +0 -12
  1299. package/cockroach-core/roles.d.ts +0 -12
  1300. package/cockroach-core/roles.js +0 -29
  1301. package/cockroach-core/roles.js.map +0 -1
  1302. package/cockroach-core/schema.cjs +0 -80
  1303. package/cockroach-core/schema.cjs.map +0 -1
  1304. package/cockroach-core/schema.d.cts +0 -22
  1305. package/cockroach-core/schema.d.ts +0 -22
  1306. package/cockroach-core/schema.js +0 -60
  1307. package/cockroach-core/schema.js.map +0 -1
  1308. package/cockroach-core/sequence.cjs +0 -52
  1309. package/cockroach-core/sequence.cjs.map +0 -1
  1310. package/cockroach-core/sequence.d.cts +0 -17
  1311. package/cockroach-core/sequence.d.ts +0 -17
  1312. package/cockroach-core/sequence.js +0 -25
  1313. package/cockroach-core/sequence.js.map +0 -1
  1314. package/cockroach-core/session.cjs +0 -120
  1315. package/cockroach-core/session.cjs.map +0 -1
  1316. package/cockroach-core/session.d.cts +0 -62
  1317. package/cockroach-core/session.d.ts +0 -62
  1318. package/cockroach-core/session.js +0 -94
  1319. package/cockroach-core/session.js.map +0 -1
  1320. package/cockroach-core/subquery.cjs +0 -17
  1321. package/cockroach-core/subquery.cjs.map +0 -1
  1322. package/cockroach-core/subquery.d.cts +0 -18
  1323. package/cockroach-core/subquery.d.ts +0 -18
  1324. package/cockroach-core/subquery.js +0 -1
  1325. package/cockroach-core/subquery.js.map +0 -1
  1326. package/cockroach-core/table.cjs +0 -100
  1327. package/cockroach-core/table.cjs.map +0 -1
  1328. package/cockroach-core/table.d.cts +0 -37
  1329. package/cockroach-core/table.d.ts +0 -37
  1330. package/cockroach-core/table.js +0 -73
  1331. package/cockroach-core/table.js.map +0 -1
  1332. package/cockroach-core/unique-constraint.cjs +0 -77
  1333. package/cockroach-core/unique-constraint.cjs.map +0 -1
  1334. package/cockroach-core/unique-constraint.d.cts +0 -23
  1335. package/cockroach-core/unique-constraint.d.ts +0 -23
  1336. package/cockroach-core/unique-constraint.js +0 -50
  1337. package/cockroach-core/unique-constraint.js.map +0 -1
  1338. package/cockroach-core/utils/array.cjs +0 -106
  1339. package/cockroach-core/utils/array.cjs.map +0 -1
  1340. package/cockroach-core/utils/array.d.cts +0 -3
  1341. package/cockroach-core/utils/array.d.ts +0 -3
  1342. package/cockroach-core/utils/array.js +0 -80
  1343. package/cockroach-core/utils/array.js.map +0 -1
  1344. package/cockroach-core/utils/index.cjs +0 -23
  1345. package/cockroach-core/utils/index.cjs.map +0 -1
  1346. package/cockroach-core/utils/index.d.cts +0 -1
  1347. package/cockroach-core/utils/index.d.ts +0 -1
  1348. package/cockroach-core/utils/index.js +0 -2
  1349. package/cockroach-core/utils/index.js.map +0 -1
  1350. package/cockroach-core/utils.cjs +0 -98
  1351. package/cockroach-core/utils.cjs.map +0 -1
  1352. package/cockroach-core/utils.d.cts +0 -47
  1353. package/cockroach-core/utils.d.ts +0 -47
  1354. package/cockroach-core/utils.js +0 -72
  1355. package/cockroach-core/utils.js.map +0 -1
  1356. package/cockroach-core/view-base.cjs +0 -33
  1357. package/cockroach-core/view-base.cjs.map +0 -1
  1358. package/cockroach-core/view-base.d.cts +0 -8
  1359. package/cockroach-core/view-base.d.ts +0 -8
  1360. package/cockroach-core/view-base.js +0 -9
  1361. package/cockroach-core/view-base.js.map +0 -1
  1362. package/cockroach-core/view.cjs +0 -271
  1363. package/cockroach-core/view.cjs.map +0 -1
  1364. package/cockroach-core/view.d.cts +0 -106
  1365. package/cockroach-core/view.d.ts +0 -106
  1366. package/cockroach-core/view.js +0 -233
  1367. package/cockroach-core/view.js.map +0 -1
  1368. package/mssql-core/alias.cjs +0 -32
  1369. package/mssql-core/alias.cjs.map +0 -1
  1370. package/mssql-core/alias.d.cts +0 -4
  1371. package/mssql-core/alias.d.ts +0 -4
  1372. package/mssql-core/alias.js +0 -8
  1373. package/mssql-core/alias.js.map +0 -1
  1374. package/mssql-core/checks.cjs +0 -58
  1375. package/mssql-core/checks.cjs.map +0 -1
  1376. package/mssql-core/checks.d.cts +0 -18
  1377. package/mssql-core/checks.d.ts +0 -18
  1378. package/mssql-core/checks.js +0 -32
  1379. package/mssql-core/checks.js.map +0 -1
  1380. package/mssql-core/columns/all.cjs +0 -74
  1381. package/mssql-core/columns/all.cjs.map +0 -1
  1382. package/mssql-core/columns/all.d.cts +0 -45
  1383. package/mssql-core/columns/all.d.ts +0 -45
  1384. package/mssql-core/columns/all.js +0 -50
  1385. package/mssql-core/columns/all.js.map +0 -1
  1386. package/mssql-core/columns/bigint.cjs +0 -72
  1387. package/mssql-core/columns/bigint.cjs.map +0 -1
  1388. package/mssql-core/columns/bigint.d.cts +0 -25
  1389. package/mssql-core/columns/bigint.d.ts +0 -25
  1390. package/mssql-core/columns/bigint.js +0 -46
  1391. package/mssql-core/columns/bigint.js.map +0 -1
  1392. package/mssql-core/columns/binary.cjs +0 -57
  1393. package/mssql-core/columns/binary.cjs.map +0 -1
  1394. package/mssql-core/columns/binary.d.cts +0 -24
  1395. package/mssql-core/columns/binary.d.ts +0 -24
  1396. package/mssql-core/columns/binary.js +0 -31
  1397. package/mssql-core/columns/binary.js.map +0 -1
  1398. package/mssql-core/columns/bit.cjs +0 -54
  1399. package/mssql-core/columns/bit.cjs.map +0 -1
  1400. package/mssql-core/columns/bit.d.cts +0 -17
  1401. package/mssql-core/columns/bit.d.ts +0 -17
  1402. package/mssql-core/columns/bit.js +0 -28
  1403. package/mssql-core/columns/bit.js.map +0 -1
  1404. package/mssql-core/columns/char.cjs +0 -73
  1405. package/mssql-core/columns/char.cjs.map +0 -1
  1406. package/mssql-core/columns/char.d.cts +0 -29
  1407. package/mssql-core/columns/char.d.ts +0 -29
  1408. package/mssql-core/columns/char.js +0 -46
  1409. package/mssql-core/columns/char.js.map +0 -1
  1410. package/mssql-core/columns/common.cjs +0 -112
  1411. package/mssql-core/columns/common.cjs.map +0 -1
  1412. package/mssql-core/columns/common.d.cts +0 -57
  1413. package/mssql-core/columns/common.d.ts +0 -57
  1414. package/mssql-core/columns/common.js +0 -85
  1415. package/mssql-core/columns/common.js.map +0 -1
  1416. package/mssql-core/columns/custom.cjs +0 -105
  1417. package/mssql-core/columns/custom.cjs.map +0 -1
  1418. package/mssql-core/columns/custom.d.cts +0 -261
  1419. package/mssql-core/columns/custom.d.ts +0 -261
  1420. package/mssql-core/columns/custom.js +0 -79
  1421. package/mssql-core/columns/custom.js.map +0 -1
  1422. package/mssql-core/columns/date.cjs +0 -94
  1423. package/mssql-core/columns/date.cjs.map +0 -1
  1424. package/mssql-core/columns/date.common.cjs +0 -37
  1425. package/mssql-core/columns/date.common.cjs.map +0 -1
  1426. package/mssql-core/columns/date.common.d.cts +0 -12
  1427. package/mssql-core/columns/date.common.d.ts +0 -12
  1428. package/mssql-core/columns/date.common.js +0 -13
  1429. package/mssql-core/columns/date.common.js.map +0 -1
  1430. package/mssql-core/columns/date.d.cts +0 -39
  1431. package/mssql-core/columns/date.d.ts +0 -39
  1432. package/mssql-core/columns/date.js +0 -66
  1433. package/mssql-core/columns/date.js.map +0 -1
  1434. package/mssql-core/columns/datetime.cjs +0 -94
  1435. package/mssql-core/columns/datetime.cjs.map +0 -1
  1436. package/mssql-core/columns/datetime.d.cts +0 -38
  1437. package/mssql-core/columns/datetime.d.ts +0 -38
  1438. package/mssql-core/columns/datetime.js +0 -66
  1439. package/mssql-core/columns/datetime.js.map +0 -1
  1440. package/mssql-core/columns/datetime2.cjs +0 -102
  1441. package/mssql-core/columns/datetime2.cjs.map +0 -1
  1442. package/mssql-core/columns/datetime2.d.cts +0 -38
  1443. package/mssql-core/columns/datetime2.d.ts +0 -38
  1444. package/mssql-core/columns/datetime2.js +0 -74
  1445. package/mssql-core/columns/datetime2.js.map +0 -1
  1446. package/mssql-core/columns/datetimeoffset.cjs +0 -102
  1447. package/mssql-core/columns/datetimeoffset.cjs.map +0 -1
  1448. package/mssql-core/columns/datetimeoffset.d.cts +0 -39
  1449. package/mssql-core/columns/datetimeoffset.d.ts +0 -39
  1450. package/mssql-core/columns/datetimeoffset.js +0 -74
  1451. package/mssql-core/columns/datetimeoffset.js.map +0 -1
  1452. package/mssql-core/columns/decimal.cjs +0 -146
  1453. package/mssql-core/columns/decimal.cjs.map +0 -1
  1454. package/mssql-core/columns/decimal.d.cts +0 -58
  1455. package/mssql-core/columns/decimal.d.ts +0 -58
  1456. package/mssql-core/columns/decimal.js +0 -116
  1457. package/mssql-core/columns/decimal.js.map +0 -1
  1458. package/mssql-core/columns/float.cjs +0 -58
  1459. package/mssql-core/columns/float.cjs.map +0 -1
  1460. package/mssql-core/columns/float.d.cts +0 -21
  1461. package/mssql-core/columns/float.d.ts +0 -21
  1462. package/mssql-core/columns/float.js +0 -32
  1463. package/mssql-core/columns/float.js.map +0 -1
  1464. package/mssql-core/columns/index.cjs +0 -63
  1465. package/mssql-core/columns/index.cjs.map +0 -1
  1466. package/mssql-core/columns/index.d.cts +0 -21
  1467. package/mssql-core/columns/index.d.ts +0 -21
  1468. package/mssql-core/columns/index.js +0 -22
  1469. package/mssql-core/columns/index.js.map +0 -1
  1470. package/mssql-core/columns/int.cjs +0 -53
  1471. package/mssql-core/columns/int.cjs.map +0 -1
  1472. package/mssql-core/columns/int.d.cts +0 -16
  1473. package/mssql-core/columns/int.d.ts +0 -16
  1474. package/mssql-core/columns/int.js +0 -27
  1475. package/mssql-core/columns/int.js.map +0 -1
  1476. package/mssql-core/columns/numeric.cjs +0 -146
  1477. package/mssql-core/columns/numeric.cjs.map +0 -1
  1478. package/mssql-core/columns/numeric.d.cts +0 -58
  1479. package/mssql-core/columns/numeric.d.ts +0 -58
  1480. package/mssql-core/columns/numeric.js +0 -116
  1481. package/mssql-core/columns/numeric.js.map +0 -1
  1482. package/mssql-core/columns/real.cjs +0 -53
  1483. package/mssql-core/columns/real.cjs.map +0 -1
  1484. package/mssql-core/columns/real.d.cts +0 -16
  1485. package/mssql-core/columns/real.d.ts +0 -16
  1486. package/mssql-core/columns/real.js +0 -27
  1487. package/mssql-core/columns/real.js.map +0 -1
  1488. package/mssql-core/columns/smallint.cjs +0 -62
  1489. package/mssql-core/columns/smallint.cjs.map +0 -1
  1490. package/mssql-core/columns/smallint.d.cts +0 -17
  1491. package/mssql-core/columns/smallint.d.ts +0 -17
  1492. package/mssql-core/columns/smallint.js +0 -36
  1493. package/mssql-core/columns/smallint.js.map +0 -1
  1494. package/mssql-core/columns/text.cjs +0 -68
  1495. package/mssql-core/columns/text.cjs.map +0 -1
  1496. package/mssql-core/columns/text.d.cts +0 -36
  1497. package/mssql-core/columns/text.d.ts +0 -36
  1498. package/mssql-core/columns/text.js +0 -41
  1499. package/mssql-core/columns/text.js.map +0 -1
  1500. package/mssql-core/columns/time.cjs +0 -90
  1501. package/mssql-core/columns/time.cjs.map +0 -1
  1502. package/mssql-core/columns/time.d.cts +0 -37
  1503. package/mssql-core/columns/time.d.ts +0 -37
  1504. package/mssql-core/columns/time.js +0 -62
  1505. package/mssql-core/columns/time.js.map +0 -1
  1506. package/mssql-core/columns/tinyint.cjs +0 -62
  1507. package/mssql-core/columns/tinyint.cjs.map +0 -1
  1508. package/mssql-core/columns/tinyint.d.cts +0 -17
  1509. package/mssql-core/columns/tinyint.d.ts +0 -17
  1510. package/mssql-core/columns/tinyint.js +0 -36
  1511. package/mssql-core/columns/tinyint.js.map +0 -1
  1512. package/mssql-core/columns/varbinary.cjs +0 -61
  1513. package/mssql-core/columns/varbinary.cjs.map +0 -1
  1514. package/mssql-core/columns/varbinary.d.cts +0 -23
  1515. package/mssql-core/columns/varbinary.d.ts +0 -23
  1516. package/mssql-core/columns/varbinary.js +0 -35
  1517. package/mssql-core/columns/varbinary.js.map +0 -1
  1518. package/mssql-core/columns/varchar.cjs +0 -117
  1519. package/mssql-core/columns/varchar.cjs.map +0 -1
  1520. package/mssql-core/columns/varchar.d.cts +0 -59
  1521. package/mssql-core/columns/varchar.d.ts +0 -59
  1522. package/mssql-core/columns/varchar.js +0 -88
  1523. package/mssql-core/columns/varchar.js.map +0 -1
  1524. package/mssql-core/db.cjs +0 -254
  1525. package/mssql-core/db.cjs.map +0 -1
  1526. package/mssql-core/db.d.cts +0 -228
  1527. package/mssql-core/db.d.ts +0 -228
  1528. package/mssql-core/db.js +0 -235
  1529. package/mssql-core/db.js.map +0 -1
  1530. package/mssql-core/dialect.cjs +0 -633
  1531. package/mssql-core/dialect.cjs.map +0 -1
  1532. package/mssql-core/dialect.d.cts +0 -58
  1533. package/mssql-core/dialect.d.ts +0 -58
  1534. package/mssql-core/dialect.js +0 -599
  1535. package/mssql-core/dialect.js.map +0 -1
  1536. package/mssql-core/expressions.cjs +0 -49
  1537. package/mssql-core/expressions.cjs.map +0 -1
  1538. package/mssql-core/expressions.d.cts +0 -8
  1539. package/mssql-core/expressions.d.ts +0 -8
  1540. package/mssql-core/expressions.js +0 -22
  1541. package/mssql-core/expressions.js.map +0 -1
  1542. package/mssql-core/foreign-keys.cjs +0 -94
  1543. package/mssql-core/foreign-keys.cjs.map +0 -1
  1544. package/mssql-core/foreign-keys.d.cts +0 -52
  1545. package/mssql-core/foreign-keys.d.ts +0 -52
  1546. package/mssql-core/foreign-keys.js +0 -68
  1547. package/mssql-core/foreign-keys.js.map +0 -1
  1548. package/mssql-core/index.cjs +0 -55
  1549. package/mssql-core/index.cjs.map +0 -1
  1550. package/mssql-core/index.d.cts +0 -17
  1551. package/mssql-core/index.d.ts +0 -17
  1552. package/mssql-core/index.js +0 -18
  1553. package/mssql-core/index.js.map +0 -1
  1554. package/mssql-core/indexes.cjs +0 -82
  1555. package/mssql-core/indexes.cjs.map +0 -1
  1556. package/mssql-core/indexes.d.cts +0 -50
  1557. package/mssql-core/indexes.d.ts +0 -50
  1558. package/mssql-core/indexes.js +0 -54
  1559. package/mssql-core/indexes.js.map +0 -1
  1560. package/mssql-core/primary-keys.cjs +0 -66
  1561. package/mssql-core/primary-keys.cjs.map +0 -1
  1562. package/mssql-core/primary-keys.d.cts +0 -24
  1563. package/mssql-core/primary-keys.d.ts +0 -24
  1564. package/mssql-core/primary-keys.js +0 -40
  1565. package/mssql-core/primary-keys.js.map +0 -1
  1566. package/mssql-core/query-builders/delete.cjs +0 -107
  1567. package/mssql-core/query-builders/delete.cjs.map +0 -1
  1568. package/mssql-core/query-builders/delete.d.cts +0 -98
  1569. package/mssql-core/query-builders/delete.d.ts +0 -98
  1570. package/mssql-core/query-builders/delete.js +0 -83
  1571. package/mssql-core/query-builders/delete.js.map +0 -1
  1572. package/mssql-core/query-builders/index.cjs +0 -33
  1573. package/mssql-core/query-builders/index.cjs.map +0 -1
  1574. package/mssql-core/query-builders/index.d.cts +0 -6
  1575. package/mssql-core/query-builders/index.d.ts +0 -6
  1576. package/mssql-core/query-builders/index.js +0 -7
  1577. package/mssql-core/query-builders/index.js.map +0 -1
  1578. package/mssql-core/query-builders/insert.cjs +0 -105
  1579. package/mssql-core/query-builders/insert.cjs.map +0 -1
  1580. package/mssql-core/query-builders/insert.d.cts +0 -79
  1581. package/mssql-core/query-builders/insert.d.ts +0 -79
  1582. package/mssql-core/query-builders/insert.js +0 -80
  1583. package/mssql-core/query-builders/insert.js.map +0 -1
  1584. package/mssql-core/query-builders/query-builder.cjs +0 -95
  1585. package/mssql-core/query-builders/query-builder.cjs.map +0 -1
  1586. package/mssql-core/query-builders/query-builder.d.cts +0 -32
  1587. package/mssql-core/query-builders/query-builder.d.ts +0 -32
  1588. package/mssql-core/query-builders/query-builder.js +0 -71
  1589. package/mssql-core/query-builders/query-builder.js.map +0 -1
  1590. package/mssql-core/query-builders/query.cjs +0 -126
  1591. package/mssql-core/query-builders/query.cjs.map +0 -1
  1592. package/mssql-core/query-builders/query.d.cts +0 -42
  1593. package/mssql-core/query-builders/query.d.ts +0 -42
  1594. package/mssql-core/query-builders/query.js +0 -103
  1595. package/mssql-core/query-builders/query.js.map +0 -1
  1596. package/mssql-core/query-builders/select.cjs +0 -678
  1597. package/mssql-core/query-builders/select.cjs.map +0 -1
  1598. package/mssql-core/query-builders/select.d.cts +0 -549
  1599. package/mssql-core/query-builders/select.d.ts +0 -549
  1600. package/mssql-core/query-builders/select.js +0 -654
  1601. package/mssql-core/query-builders/select.js.map +0 -1
  1602. package/mssql-core/query-builders/select.types.cjs +0 -17
  1603. package/mssql-core/query-builders/select.types.cjs.map +0 -1
  1604. package/mssql-core/query-builders/select.types.d.cts +0 -142
  1605. package/mssql-core/query-builders/select.types.d.ts +0 -142
  1606. package/mssql-core/query-builders/select.types.js +0 -1
  1607. package/mssql-core/query-builders/select.types.js.map +0 -1
  1608. package/mssql-core/query-builders/update.cjs +0 -138
  1609. package/mssql-core/query-builders/update.cjs.map +0 -1
  1610. package/mssql-core/query-builders/update.d.cts +0 -142
  1611. package/mssql-core/query-builders/update.d.ts +0 -142
  1612. package/mssql-core/query-builders/update.js +0 -113
  1613. package/mssql-core/query-builders/update.js.map +0 -1
  1614. package/mssql-core/schema.cjs +0 -51
  1615. package/mssql-core/schema.cjs.map +0 -1
  1616. package/mssql-core/schema.d.cts +0 -22
  1617. package/mssql-core/schema.d.ts +0 -22
  1618. package/mssql-core/schema.js +0 -25
  1619. package/mssql-core/schema.js.map +0 -1
  1620. package/mssql-core/session.cjs +0 -74
  1621. package/mssql-core/session.cjs.map +0 -1
  1622. package/mssql-core/session.d.cts +0 -63
  1623. package/mssql-core/session.d.ts +0 -63
  1624. package/mssql-core/session.js +0 -48
  1625. package/mssql-core/session.js.map +0 -1
  1626. package/mssql-core/subquery.cjs +0 -17
  1627. package/mssql-core/subquery.cjs.map +0 -1
  1628. package/mssql-core/subquery.d.cts +0 -18
  1629. package/mssql-core/subquery.d.ts +0 -18
  1630. package/mssql-core/subquery.js +0 -1
  1631. package/mssql-core/subquery.js.map +0 -1
  1632. package/mssql-core/table.cjs +0 -81
  1633. package/mssql-core/table.cjs.map +0 -1
  1634. package/mssql-core/table.d.cts +0 -40
  1635. package/mssql-core/table.d.ts +0 -40
  1636. package/mssql-core/table.js +0 -55
  1637. package/mssql-core/table.js.map +0 -1
  1638. package/mssql-core/unique-constraint.cjs +0 -78
  1639. package/mssql-core/unique-constraint.cjs.map +0 -1
  1640. package/mssql-core/unique-constraint.d.cts +0 -24
  1641. package/mssql-core/unique-constraint.d.ts +0 -24
  1642. package/mssql-core/unique-constraint.js +0 -51
  1643. package/mssql-core/unique-constraint.js.map +0 -1
  1644. package/mssql-core/utils.cjs +0 -85
  1645. package/mssql-core/utils.cjs.map +0 -1
  1646. package/mssql-core/utils.d.cts +0 -31
  1647. package/mssql-core/utils.d.ts +0 -31
  1648. package/mssql-core/utils.js +0 -60
  1649. package/mssql-core/utils.js.map +0 -1
  1650. package/mssql-core/view-base.cjs +0 -33
  1651. package/mssql-core/view-base.cjs.map +0 -1
  1652. package/mssql-core/view-base.d.cts +0 -9
  1653. package/mssql-core/view-base.d.ts +0 -9
  1654. package/mssql-core/view-base.js +0 -9
  1655. package/mssql-core/view-base.js.map +0 -1
  1656. package/mssql-core/view-common.cjs +0 -29
  1657. package/mssql-core/view-common.cjs.map +0 -1
  1658. package/mssql-core/view-common.d.cts +0 -1
  1659. package/mssql-core/view-common.d.ts +0 -1
  1660. package/mssql-core/view-common.js +0 -5
  1661. package/mssql-core/view-common.js.map +0 -1
  1662. package/mssql-core/view.cjs +0 -154
  1663. package/mssql-core/view.cjs.map +0 -1
  1664. package/mssql-core/view.d.cts +0 -63
  1665. package/mssql-core/view.d.ts +0 -63
  1666. package/mssql-core/view.js +0 -125
  1667. package/mssql-core/view.js.map +0 -1
  1668. package/mysql-core/columns/blob.cjs +0 -158
  1669. package/mysql-core/columns/blob.cjs.map +0 -1
  1670. package/mysql-core/columns/blob.d.cts +0 -54
  1671. package/mysql-core/columns/blob.d.ts +0 -54
  1672. package/mysql-core/columns/blob.js +0 -127
  1673. package/mysql-core/columns/blob.js.map +0 -1
  1674. package/mysql-core/columns/string.common.cjs +0 -48
  1675. package/mysql-core/columns/string.common.cjs.map +0 -1
  1676. package/mysql-core/columns/string.common.d.cts +0 -21
  1677. package/mysql-core/columns/string.common.d.ts +0 -21
  1678. package/mysql-core/columns/string.common.js +0 -23
  1679. package/mysql-core/columns/string.common.js.map +0 -1
  1680. package/node-mssql/driver.cjs +0 -113
  1681. package/node-mssql/driver.cjs.map +0 -1
  1682. package/node-mssql/driver.d.cts +0 -46
  1683. package/node-mssql/driver.d.ts +0 -46
  1684. package/node-mssql/driver.js +0 -77
  1685. package/node-mssql/driver.js.map +0 -1
  1686. package/node-mssql/index.cjs +0 -25
  1687. package/node-mssql/index.cjs.map +0 -1
  1688. package/node-mssql/index.d.cts +0 -2
  1689. package/node-mssql/index.d.ts +0 -2
  1690. package/node-mssql/index.js +0 -3
  1691. package/node-mssql/index.js.map +0 -1
  1692. package/node-mssql/migrator.cjs +0 -33
  1693. package/node-mssql/migrator.cjs.map +0 -1
  1694. package/node-mssql/migrator.d.cts +0 -3
  1695. package/node-mssql/migrator.d.ts +0 -3
  1696. package/node-mssql/migrator.js +0 -9
  1697. package/node-mssql/migrator.js.map +0 -1
  1698. package/node-mssql/pool.cjs +0 -54
  1699. package/node-mssql/pool.cjs.map +0 -1
  1700. package/node-mssql/pool.d.cts +0 -8
  1701. package/node-mssql/pool.d.ts +0 -8
  1702. package/node-mssql/pool.js +0 -20
  1703. package/node-mssql/pool.js.map +0 -1
  1704. package/node-mssql/session.cjs +0 -256
  1705. package/node-mssql/session.cjs.map +0 -1
  1706. package/node-mssql/session.d.cts +0 -48
  1707. package/node-mssql/session.d.ts +0 -48
  1708. package/node-mssql/session.js +0 -224
  1709. package/node-mssql/session.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/singlestore-core/primary-keys.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport type { AnySingleStoreColumn, SingleStoreColumn } from './columns/index.ts';\nimport { SingleStoreTable } from './table.ts';\n\nexport function primaryKey<\n\tTTableName extends string,\n\tTColumn extends AnySingleStoreColumn<{ tableName: TTableName }>,\n\tTColumns extends AnySingleStoreColumn<{ tableName: TTableName }>[],\n>(config: { name?: string; columns: [TColumn, ...TColumns] }): PrimaryKeyBuilder;\n/**\n * @deprecated: Please use primaryKey({ columns: [] }) instead of this function\n * @param columns\n */\nexport function primaryKey<\n\tTTableName extends string,\n\tTColumns extends AnySingleStoreColumn<{ tableName: TTableName }>[],\n>(...columns: TColumns): PrimaryKeyBuilder;\nexport function primaryKey(...config: any) {\n\tif (config[0].columns) {\n\t\treturn new PrimaryKeyBuilder(config[0].columns, config[0].name);\n\t}\n\treturn new PrimaryKeyBuilder(config);\n}\n\nexport class PrimaryKeyBuilder {\n\tstatic readonly [entityKind]: string = 'SingleStorePrimaryKeyBuilder';\n\n\t/** @internal */\n\tcolumns: SingleStoreColumn[];\n\n\t/** @internal */\n\tname?: string;\n\n\tconstructor(\n\t\tcolumns: SingleStoreColumn[],\n\t\tname?: string,\n\t) {\n\t\tthis.columns = columns;\n\t\tthis.name = name;\n\t}\n\n\t/** @internal */\n\tbuild(table: SingleStoreTable): PrimaryKey {\n\t\treturn new PrimaryKey(table, this.columns, this.name);\n\t}\n}\n\nexport class PrimaryKey {\n\tstatic readonly [entityKind]: string = 'SingleStorePrimaryKey';\n\n\treadonly columns: SingleStoreColumn[];\n\treadonly name?: string;\n\treadonly isNameExplicit: boolean;\n\n\tconstructor(readonly table: SingleStoreTable, columns: SingleStoreColumn[], name?: string) {\n\t\tthis.columns = columns;\n\t\tthis.name = name;\n\t\tthis.isNameExplicit = !!name;\n\t}\n\n\tgetName(): string {\n\t\treturn this.name\n\t\t\t?? `${this.table[SingleStoreTable.Symbol.Name]}_${this.columns.map((column) => column.name).join('_')}_pk`;\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA2B;AAE3B,mBAAiC;AAe1B,SAAS,cAAc,QAAa;AAC1C,MAAI,OAAO,CAAC,EAAE,SAAS;AACtB,WAAO,IAAI,kBAAkB,OAAO,CAAC,EAAE,SAAS,OAAO,CAAC,EAAE,IAAI;AAAA,EAC/D;AACA,SAAO,IAAI,kBAAkB,MAAM;AACpC;AAEO,MAAM,kBAAkB;AAAA,EAC9B,QAAiB,wBAAU,IAAY;AAAA;AAAA,EAGvC;AAAA;AAAA,EAGA;AAAA,EAEA,YACC,SACA,MACC;AACD,SAAK,UAAU;AACf,SAAK,OAAO;AAAA,EACb;AAAA;AAAA,EAGA,MAAM,OAAqC;AAC1C,WAAO,IAAI,WAAW,OAAO,KAAK,SAAS,KAAK,IAAI;AAAA,EACrD;AACD;AAEO,MAAM,WAAW;AAAA,EAOvB,YAAqB,OAAyB,SAA8B,MAAe;AAAtE;AACpB,SAAK,UAAU;AACf,SAAK,OAAO;AACZ,SAAK,iBAAiB,CAAC,CAAC;AAAA,EACzB;AAAA,EAVA,QAAiB,wBAAU,IAAY;AAAA,EAE9B;AAAA,EACA;AAAA,EACA;AAAA,EAQT,UAAkB;AACjB,WAAO,KAAK,QACR,GAAG,KAAK,MAAM,8BAAiB,OAAO,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,WAAW,OAAO,IAAI,EAAE,KAAK,GAAG,CAAC;AAAA,EACvG;AACD;","names":[]}
1
+ {"version":3,"sources":["../../src/singlestore-core/primary-keys.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport type { AnySingleStoreColumn, SingleStoreColumn } from './columns/index.ts';\nimport { SingleStoreTable } from './table.ts';\n\nexport function primaryKey<\n\tTTableName extends string,\n\tTColumn extends AnySingleStoreColumn<{ tableName: TTableName }>,\n\tTColumns extends AnySingleStoreColumn<{ tableName: TTableName }>[],\n>(config: { name?: string; columns: [TColumn, ...TColumns] }): PrimaryKeyBuilder;\n/**\n * @deprecated: Please use primaryKey({ columns: [] }) instead of this function\n * @param columns\n */\nexport function primaryKey<\n\tTTableName extends string,\n\tTColumns extends AnySingleStoreColumn<{ tableName: TTableName }>[],\n>(...columns: TColumns): PrimaryKeyBuilder;\nexport function primaryKey(...config: any) {\n\tif (config[0].columns) {\n\t\treturn new PrimaryKeyBuilder(config[0].columns, config[0].name);\n\t}\n\treturn new PrimaryKeyBuilder(config);\n}\n\nexport class PrimaryKeyBuilder {\n\tstatic readonly [entityKind]: string = 'SingleStorePrimaryKeyBuilder';\n\n\t/** @internal */\n\tcolumns: SingleStoreColumn[];\n\n\t/** @internal */\n\tname?: string;\n\n\tconstructor(\n\t\tcolumns: SingleStoreColumn[],\n\t\tname?: string,\n\t) {\n\t\tthis.columns = columns;\n\t\tthis.name = name;\n\t}\n\n\t/** @internal */\n\tbuild(table: SingleStoreTable): PrimaryKey {\n\t\treturn new PrimaryKey(table, this.columns, this.name);\n\t}\n}\n\nexport class PrimaryKey {\n\tstatic readonly [entityKind]: string = 'SingleStorePrimaryKey';\n\n\treadonly columns: SingleStoreColumn[];\n\treadonly name?: string;\n\n\tconstructor(readonly table: SingleStoreTable, columns: SingleStoreColumn[], name?: string) {\n\t\tthis.columns = columns;\n\t\tthis.name = name;\n\t}\n\n\tgetName(): string {\n\t\treturn this.name\n\t\t\t?? `${this.table[SingleStoreTable.Symbol.Name]}_${this.columns.map((column) => column.name).join('_')}_pk`;\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA2B;AAE3B,mBAAiC;AAe1B,SAAS,cAAc,QAAa;AAC1C,MAAI,OAAO,CAAC,EAAE,SAAS;AACtB,WAAO,IAAI,kBAAkB,OAAO,CAAC,EAAE,SAAS,OAAO,CAAC,EAAE,IAAI;AAAA,EAC/D;AACA,SAAO,IAAI,kBAAkB,MAAM;AACpC;AAEO,MAAM,kBAAkB;AAAA,EAC9B,QAAiB,wBAAU,IAAY;AAAA;AAAA,EAGvC;AAAA;AAAA,EAGA;AAAA,EAEA,YACC,SACA,MACC;AACD,SAAK,UAAU;AACf,SAAK,OAAO;AAAA,EACb;AAAA;AAAA,EAGA,MAAM,OAAqC;AAC1C,WAAO,IAAI,WAAW,OAAO,KAAK,SAAS,KAAK,IAAI;AAAA,EACrD;AACD;AAEO,MAAM,WAAW;AAAA,EAMvB,YAAqB,OAAyB,SAA8B,MAAe;AAAtE;AACpB,SAAK,UAAU;AACf,SAAK,OAAO;AAAA,EACb;AAAA,EARA,QAAiB,wBAAU,IAAY;AAAA,EAE9B;AAAA,EACA;AAAA,EAOT,UAAkB;AACjB,WAAO,KAAK,QACR,GAAG,KAAK,MAAM,8BAAiB,OAAO,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,WAAW,OAAO,IAAI,EAAE,KAAK,GAAG,CAAC;AAAA,EACvG;AACD;","names":[]}
@@ -25,7 +25,6 @@ export declare class PrimaryKey {
25
25
  static readonly [entityKind]: string;
26
26
  readonly columns: SingleStoreColumn[];
27
27
  readonly name?: string;
28
- readonly isNameExplicit: boolean;
29
28
  constructor(table: SingleStoreTable, columns: SingleStoreColumn[], name?: string);
30
29
  getName(): string;
31
30
  }
@@ -25,7 +25,6 @@ export declare class PrimaryKey {
25
25
  static readonly [entityKind]: string;
26
26
  readonly columns: SingleStoreColumn[];
27
27
  readonly name?: string;
28
- readonly isNameExplicit: boolean;
29
28
  constructor(table: SingleStoreTable, columns: SingleStoreColumn[], name?: string);
30
29
  getName(): string;
31
30
  }
@@ -26,12 +26,10 @@ class PrimaryKey {
26
26
  this.table = table;
27
27
  this.columns = columns;
28
28
  this.name = name;
29
- this.isNameExplicit = !!name;
30
29
  }
31
30
  static [entityKind] = "SingleStorePrimaryKey";
32
31
  columns;
33
32
  name;
34
- isNameExplicit;
35
33
  getName() {
36
34
  return this.name ?? `${this.table[SingleStoreTable.Symbol.Name]}_${this.columns.map((column) => column.name).join("_")}_pk`;
37
35
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/singlestore-core/primary-keys.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport type { AnySingleStoreColumn, SingleStoreColumn } from './columns/index.ts';\nimport { SingleStoreTable } from './table.ts';\n\nexport function primaryKey<\n\tTTableName extends string,\n\tTColumn extends AnySingleStoreColumn<{ tableName: TTableName }>,\n\tTColumns extends AnySingleStoreColumn<{ tableName: TTableName }>[],\n>(config: { name?: string; columns: [TColumn, ...TColumns] }): PrimaryKeyBuilder;\n/**\n * @deprecated: Please use primaryKey({ columns: [] }) instead of this function\n * @param columns\n */\nexport function primaryKey<\n\tTTableName extends string,\n\tTColumns extends AnySingleStoreColumn<{ tableName: TTableName }>[],\n>(...columns: TColumns): PrimaryKeyBuilder;\nexport function primaryKey(...config: any) {\n\tif (config[0].columns) {\n\t\treturn new PrimaryKeyBuilder(config[0].columns, config[0].name);\n\t}\n\treturn new PrimaryKeyBuilder(config);\n}\n\nexport class PrimaryKeyBuilder {\n\tstatic readonly [entityKind]: string = 'SingleStorePrimaryKeyBuilder';\n\n\t/** @internal */\n\tcolumns: SingleStoreColumn[];\n\n\t/** @internal */\n\tname?: string;\n\n\tconstructor(\n\t\tcolumns: SingleStoreColumn[],\n\t\tname?: string,\n\t) {\n\t\tthis.columns = columns;\n\t\tthis.name = name;\n\t}\n\n\t/** @internal */\n\tbuild(table: SingleStoreTable): PrimaryKey {\n\t\treturn new PrimaryKey(table, this.columns, this.name);\n\t}\n}\n\nexport class PrimaryKey {\n\tstatic readonly [entityKind]: string = 'SingleStorePrimaryKey';\n\n\treadonly columns: SingleStoreColumn[];\n\treadonly name?: string;\n\treadonly isNameExplicit: boolean;\n\n\tconstructor(readonly table: SingleStoreTable, columns: SingleStoreColumn[], name?: string) {\n\t\tthis.columns = columns;\n\t\tthis.name = name;\n\t\tthis.isNameExplicit = !!name;\n\t}\n\n\tgetName(): string {\n\t\treturn this.name\n\t\t\t?? `${this.table[SingleStoreTable.Symbol.Name]}_${this.columns.map((column) => column.name).join('_')}_pk`;\n\t}\n}\n"],"mappings":"AAAA,SAAS,kBAAkB;AAE3B,SAAS,wBAAwB;AAe1B,SAAS,cAAc,QAAa;AAC1C,MAAI,OAAO,CAAC,EAAE,SAAS;AACtB,WAAO,IAAI,kBAAkB,OAAO,CAAC,EAAE,SAAS,OAAO,CAAC,EAAE,IAAI;AAAA,EAC/D;AACA,SAAO,IAAI,kBAAkB,MAAM;AACpC;AAEO,MAAM,kBAAkB;AAAA,EAC9B,QAAiB,UAAU,IAAY;AAAA;AAAA,EAGvC;AAAA;AAAA,EAGA;AAAA,EAEA,YACC,SACA,MACC;AACD,SAAK,UAAU;AACf,SAAK,OAAO;AAAA,EACb;AAAA;AAAA,EAGA,MAAM,OAAqC;AAC1C,WAAO,IAAI,WAAW,OAAO,KAAK,SAAS,KAAK,IAAI;AAAA,EACrD;AACD;AAEO,MAAM,WAAW;AAAA,EAOvB,YAAqB,OAAyB,SAA8B,MAAe;AAAtE;AACpB,SAAK,UAAU;AACf,SAAK,OAAO;AACZ,SAAK,iBAAiB,CAAC,CAAC;AAAA,EACzB;AAAA,EAVA,QAAiB,UAAU,IAAY;AAAA,EAE9B;AAAA,EACA;AAAA,EACA;AAAA,EAQT,UAAkB;AACjB,WAAO,KAAK,QACR,GAAG,KAAK,MAAM,iBAAiB,OAAO,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,WAAW,OAAO,IAAI,EAAE,KAAK,GAAG,CAAC;AAAA,EACvG;AACD;","names":[]}
1
+ {"version":3,"sources":["../../src/singlestore-core/primary-keys.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport type { AnySingleStoreColumn, SingleStoreColumn } from './columns/index.ts';\nimport { SingleStoreTable } from './table.ts';\n\nexport function primaryKey<\n\tTTableName extends string,\n\tTColumn extends AnySingleStoreColumn<{ tableName: TTableName }>,\n\tTColumns extends AnySingleStoreColumn<{ tableName: TTableName }>[],\n>(config: { name?: string; columns: [TColumn, ...TColumns] }): PrimaryKeyBuilder;\n/**\n * @deprecated: Please use primaryKey({ columns: [] }) instead of this function\n * @param columns\n */\nexport function primaryKey<\n\tTTableName extends string,\n\tTColumns extends AnySingleStoreColumn<{ tableName: TTableName }>[],\n>(...columns: TColumns): PrimaryKeyBuilder;\nexport function primaryKey(...config: any) {\n\tif (config[0].columns) {\n\t\treturn new PrimaryKeyBuilder(config[0].columns, config[0].name);\n\t}\n\treturn new PrimaryKeyBuilder(config);\n}\n\nexport class PrimaryKeyBuilder {\n\tstatic readonly [entityKind]: string = 'SingleStorePrimaryKeyBuilder';\n\n\t/** @internal */\n\tcolumns: SingleStoreColumn[];\n\n\t/** @internal */\n\tname?: string;\n\n\tconstructor(\n\t\tcolumns: SingleStoreColumn[],\n\t\tname?: string,\n\t) {\n\t\tthis.columns = columns;\n\t\tthis.name = name;\n\t}\n\n\t/** @internal */\n\tbuild(table: SingleStoreTable): PrimaryKey {\n\t\treturn new PrimaryKey(table, this.columns, this.name);\n\t}\n}\n\nexport class PrimaryKey {\n\tstatic readonly [entityKind]: string = 'SingleStorePrimaryKey';\n\n\treadonly columns: SingleStoreColumn[];\n\treadonly name?: string;\n\n\tconstructor(readonly table: SingleStoreTable, columns: SingleStoreColumn[], name?: string) {\n\t\tthis.columns = columns;\n\t\tthis.name = name;\n\t}\n\n\tgetName(): string {\n\t\treturn this.name\n\t\t\t?? `${this.table[SingleStoreTable.Symbol.Name]}_${this.columns.map((column) => column.name).join('_')}_pk`;\n\t}\n}\n"],"mappings":"AAAA,SAAS,kBAAkB;AAE3B,SAAS,wBAAwB;AAe1B,SAAS,cAAc,QAAa;AAC1C,MAAI,OAAO,CAAC,EAAE,SAAS;AACtB,WAAO,IAAI,kBAAkB,OAAO,CAAC,EAAE,SAAS,OAAO,CAAC,EAAE,IAAI;AAAA,EAC/D;AACA,SAAO,IAAI,kBAAkB,MAAM;AACpC;AAEO,MAAM,kBAAkB;AAAA,EAC9B,QAAiB,UAAU,IAAY;AAAA;AAAA,EAGvC;AAAA;AAAA,EAGA;AAAA,EAEA,YACC,SACA,MACC;AACD,SAAK,UAAU;AACf,SAAK,OAAO;AAAA,EACb;AAAA;AAAA,EAGA,MAAM,OAAqC;AAC1C,WAAO,IAAI,WAAW,OAAO,KAAK,SAAS,KAAK,IAAI;AAAA,EACrD;AACD;AAEO,MAAM,WAAW;AAAA,EAMvB,YAAqB,OAAyB,SAA8B,MAAe;AAAtE;AACpB,SAAK,UAAU;AACf,SAAK,OAAO;AAAA,EACb;AAAA,EARA,QAAiB,UAAU,IAAY;AAAA,EAE9B;AAAA,EACA;AAAA,EAOT,UAAkB;AACjB,WAAO,KAAK,QACR,GAAG,KAAK,MAAM,iBAAiB,OAAO,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,WAAW,OAAO,IAAI,EAAE,KAAK,GAAG,CAAC;AAAA,EACvG;AACD;","names":[]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/singlestore-core/query-builders/count.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport { SQL, sql, type SQLWrapper } from '~/sql/sql.ts';\nimport type { SingleStoreSession } from '../session.ts';\nimport type { SingleStoreTable } from '../table.ts';\n/* import type { SingleStoreViewBase } from '../view-base.ts'; */\n\nexport class SingleStoreCountBuilder<\n\tTSession extends SingleStoreSession<any, any, any>,\n> extends SQL<number> implements Promise<number>, SQLWrapper {\n\tprivate sql: SQL<number>;\n\n\tstatic override readonly [entityKind]: string = 'SingleStoreCountBuilder';\n\t[Symbol.toStringTag] = 'SingleStoreCountBuilder';\n\n\tprivate session: TSession;\n\n\tprivate static buildEmbeddedCount(\n\t\tsource: SingleStoreTable | /* SingleStoreViewBase | */ SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`(select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters})`;\n\t}\n\n\tprivate static buildCount(\n\t\tsource: SingleStoreTable | /* SingleStoreViewBase | */ SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`select count(*) as count from ${source}${sql.raw(' where ').if(filters)}${filters}`;\n\t}\n\n\tconstructor(\n\t\treadonly params: {\n\t\t\tsource: SingleStoreTable | /* SingleStoreViewBase | */ SQL | SQLWrapper;\n\t\t\tfilters?: SQL<unknown>;\n\t\t\tsession: TSession;\n\t\t},\n\t) {\n\t\tsuper(SingleStoreCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);\n\n\t\tthis.mapWith(Number);\n\n\t\tthis.session = params.session;\n\n\t\tthis.sql = SingleStoreCountBuilder.buildCount(\n\t\t\tparams.source,\n\t\t\tparams.filters,\n\t\t);\n\t}\n\n\tthen<TResult1 = number, TResult2 = never>(\n\t\tonfulfilled?: ((value: number) => TResult1 | PromiseLike<TResult1>) | null | undefined,\n\t\tonrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null | undefined,\n\t): Promise<TResult1 | TResult2> {\n\t\treturn Promise.resolve(this.session.count(this.sql))\n\t\t\t.then(\n\t\t\t\tonfulfilled,\n\t\t\t\tonrejected,\n\t\t\t);\n\t}\n\n\tcatch(\n\t\tonRejected?: ((reason: any) => never | PromiseLike<never>) | null | undefined,\n\t): Promise<number> {\n\t\treturn this.then(undefined, onRejected);\n\t}\n\n\tfinally(onFinally?: (() => void) | null | undefined): Promise<number> {\n\t\treturn this.then(\n\t\t\t(value) => {\n\t\t\t\tonFinally?.();\n\t\t\t\treturn value;\n\t\t\t},\n\t\t\t(reason) => {\n\t\t\t\tonFinally?.();\n\t\t\t\tthrow reason;\n\t\t\t},\n\t\t);\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA2B;AAC3B,iBAA0C;AAKnC,MAAM,gCAEH,eAAmD;AAAA,EAsB5D,YACU,QAKR;AACD,UAAM,wBAAwB,mBAAmB,OAAO,QAAQ,OAAO,OAAO,EAAE,WAAW;AANlF;AAQT,SAAK,QAAQ,MAAM;AAEnB,SAAK,UAAU,OAAO;AAEtB,SAAK,MAAM,wBAAwB;AAAA,MAClC,OAAO;AAAA,MACP,OAAO;AAAA,IACR;AAAA,EACD;AAAA,EAtCQ;AAAA,EAER,QAA0B,wBAAU,IAAY;AAAA,EAChD,CAAC,OAAO,WAAW,IAAI;AAAA,EAEf;AAAA,EAER,OAAe,mBACd,QACA,SACc;AACd,WAAO,uCAAoC,MAAM,GAAG,eAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EAC7F;AAAA,EAEA,OAAe,WACd,QACA,SACc;AACd,WAAO,+CAA4C,MAAM,GAAG,eAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EACrG;AAAA,EAqBA,KACC,aACA,YAC+B;AAC/B,WAAO,QAAQ,QAAQ,KAAK,QAAQ,MAAM,KAAK,GAAG,CAAC,EACjD;AAAA,MACA;AAAA,MACA;AAAA,IACD;AAAA,EACF;AAAA,EAEA,MACC,YACkB;AAClB,WAAO,KAAK,KAAK,QAAW,UAAU;AAAA,EACvC;AAAA,EAEA,QAAQ,WAA8D;AACrE,WAAO,KAAK;AAAA,MACX,CAAC,UAAU;AACV,oBAAY;AACZ,eAAO;AAAA,MACR;AAAA,MACA,CAAC,WAAW;AACX,oBAAY;AACZ,cAAM;AAAA,MACP;AAAA,IACD;AAAA,EACD;AACD;","names":[]}
1
+ {"version":3,"sources":["../../../src/singlestore-core/query-builders/count.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport { SQL, sql, type SQLWrapper } from '~/sql/sql.ts';\nimport type { SingleStoreSession } from '../session.ts';\nimport type { SingleStoreTable } from '../table.ts';\n/* import type { SingleStoreViewBase } from '../view-base.ts'; */\n\nexport class SingleStoreCountBuilder<\n\tTSession extends SingleStoreSession<any, any, any>,\n> extends SQL<number> implements Promise<number>, SQLWrapper {\n\tprivate sql: SQL<number>;\n\n\tstatic override readonly [entityKind] = 'SingleStoreCountBuilder';\n\t[Symbol.toStringTag] = 'SingleStoreCountBuilder';\n\n\tprivate session: TSession;\n\n\tprivate static buildEmbeddedCount(\n\t\tsource: SingleStoreTable | /* SingleStoreViewBase | */ SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`(select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters})`;\n\t}\n\n\tprivate static buildCount(\n\t\tsource: SingleStoreTable | /* SingleStoreViewBase | */ SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`select count(*) as count from ${source}${sql.raw(' where ').if(filters)}${filters}`;\n\t}\n\n\tconstructor(\n\t\treadonly params: {\n\t\t\tsource: SingleStoreTable | /* SingleStoreViewBase | */ SQL | SQLWrapper;\n\t\t\tfilters?: SQL<unknown>;\n\t\t\tsession: TSession;\n\t\t},\n\t) {\n\t\tsuper(SingleStoreCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);\n\n\t\tthis.mapWith(Number);\n\n\t\tthis.session = params.session;\n\n\t\tthis.sql = SingleStoreCountBuilder.buildCount(\n\t\t\tparams.source,\n\t\t\tparams.filters,\n\t\t);\n\t}\n\n\tthen<TResult1 = number, TResult2 = never>(\n\t\tonfulfilled?: ((value: number) => TResult1 | PromiseLike<TResult1>) | null | undefined,\n\t\tonrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null | undefined,\n\t): Promise<TResult1 | TResult2> {\n\t\treturn Promise.resolve(this.session.count(this.sql))\n\t\t\t.then(\n\t\t\t\tonfulfilled,\n\t\t\t\tonrejected,\n\t\t\t);\n\t}\n\n\tcatch(\n\t\tonRejected?: ((reason: any) => never | PromiseLike<never>) | null | undefined,\n\t): Promise<number> {\n\t\treturn this.then(undefined, onRejected);\n\t}\n\n\tfinally(onFinally?: (() => void) | null | undefined): Promise<number> {\n\t\treturn this.then(\n\t\t\t(value) => {\n\t\t\t\tonFinally?.();\n\t\t\t\treturn value;\n\t\t\t},\n\t\t\t(reason) => {\n\t\t\t\tonFinally?.();\n\t\t\t\tthrow reason;\n\t\t\t},\n\t\t);\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA2B;AAC3B,iBAA0C;AAKnC,MAAM,gCAEH,eAAmD;AAAA,EAsB5D,YACU,QAKR;AACD,UAAM,wBAAwB,mBAAmB,OAAO,QAAQ,OAAO,OAAO,EAAE,WAAW;AANlF;AAQT,SAAK,QAAQ,MAAM;AAEnB,SAAK,UAAU,OAAO;AAEtB,SAAK,MAAM,wBAAwB;AAAA,MAClC,OAAO;AAAA,MACP,OAAO;AAAA,IACR;AAAA,EACD;AAAA,EAtCQ;AAAA,EAER,QAA0B,wBAAU,IAAI;AAAA,EACxC,CAAC,OAAO,WAAW,IAAI;AAAA,EAEf;AAAA,EAER,OAAe,mBACd,QACA,SACc;AACd,WAAO,uCAAoC,MAAM,GAAG,eAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EAC7F;AAAA,EAEA,OAAe,WACd,QACA,SACc;AACd,WAAO,+CAA4C,MAAM,GAAG,eAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EACrG;AAAA,EAqBA,KACC,aACA,YAC+B;AAC/B,WAAO,QAAQ,QAAQ,KAAK,QAAQ,MAAM,KAAK,GAAG,CAAC,EACjD;AAAA,MACA;AAAA,MACA;AAAA,IACD;AAAA,EACF;AAAA,EAEA,MACC,YACkB;AAClB,WAAO,KAAK,KAAK,QAAW,UAAU;AAAA,EACvC;AAAA,EAEA,QAAQ,WAA8D;AACrE,WAAO,KAAK;AAAA,MACX,CAAC,UAAU;AACV,oBAAY;AACZ,eAAO;AAAA,MACR;AAAA,MACA,CAAC,WAAW;AACX,oBAAY;AACZ,cAAM;AAAA,MACP;AAAA,IACD;AAAA,EACD;AACD;","names":[]}
@@ -9,7 +9,7 @@ export declare class SingleStoreCountBuilder<TSession extends SingleStoreSession
9
9
  session: TSession;
10
10
  };
11
11
  private sql;
12
- static readonly [entityKind]: string;
12
+ static readonly [entityKind] = "SingleStoreCountBuilder";
13
13
  [Symbol.toStringTag]: string;
14
14
  private session;
15
15
  private static buildEmbeddedCount;
@@ -9,7 +9,7 @@ export declare class SingleStoreCountBuilder<TSession extends SingleStoreSession
9
9
  session: TSession;
10
10
  };
11
11
  private sql;
12
- static readonly [entityKind]: string;
12
+ static readonly [entityKind] = "SingleStoreCountBuilder";
13
13
  [Symbol.toStringTag]: string;
14
14
  private session;
15
15
  private static buildEmbeddedCount;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/singlestore-core/query-builders/count.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport { SQL, sql, type SQLWrapper } from '~/sql/sql.ts';\nimport type { SingleStoreSession } from '../session.ts';\nimport type { SingleStoreTable } from '../table.ts';\n/* import type { SingleStoreViewBase } from '../view-base.ts'; */\n\nexport class SingleStoreCountBuilder<\n\tTSession extends SingleStoreSession<any, any, any>,\n> extends SQL<number> implements Promise<number>, SQLWrapper {\n\tprivate sql: SQL<number>;\n\n\tstatic override readonly [entityKind]: string = 'SingleStoreCountBuilder';\n\t[Symbol.toStringTag] = 'SingleStoreCountBuilder';\n\n\tprivate session: TSession;\n\n\tprivate static buildEmbeddedCount(\n\t\tsource: SingleStoreTable | /* SingleStoreViewBase | */ SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`(select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters})`;\n\t}\n\n\tprivate static buildCount(\n\t\tsource: SingleStoreTable | /* SingleStoreViewBase | */ SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`select count(*) as count from ${source}${sql.raw(' where ').if(filters)}${filters}`;\n\t}\n\n\tconstructor(\n\t\treadonly params: {\n\t\t\tsource: SingleStoreTable | /* SingleStoreViewBase | */ SQL | SQLWrapper;\n\t\t\tfilters?: SQL<unknown>;\n\t\t\tsession: TSession;\n\t\t},\n\t) {\n\t\tsuper(SingleStoreCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);\n\n\t\tthis.mapWith(Number);\n\n\t\tthis.session = params.session;\n\n\t\tthis.sql = SingleStoreCountBuilder.buildCount(\n\t\t\tparams.source,\n\t\t\tparams.filters,\n\t\t);\n\t}\n\n\tthen<TResult1 = number, TResult2 = never>(\n\t\tonfulfilled?: ((value: number) => TResult1 | PromiseLike<TResult1>) | null | undefined,\n\t\tonrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null | undefined,\n\t): Promise<TResult1 | TResult2> {\n\t\treturn Promise.resolve(this.session.count(this.sql))\n\t\t\t.then(\n\t\t\t\tonfulfilled,\n\t\t\t\tonrejected,\n\t\t\t);\n\t}\n\n\tcatch(\n\t\tonRejected?: ((reason: any) => never | PromiseLike<never>) | null | undefined,\n\t): Promise<number> {\n\t\treturn this.then(undefined, onRejected);\n\t}\n\n\tfinally(onFinally?: (() => void) | null | undefined): Promise<number> {\n\t\treturn this.then(\n\t\t\t(value) => {\n\t\t\t\tonFinally?.();\n\t\t\t\treturn value;\n\t\t\t},\n\t\t\t(reason) => {\n\t\t\t\tonFinally?.();\n\t\t\t\tthrow reason;\n\t\t\t},\n\t\t);\n\t}\n}\n"],"mappings":"AAAA,SAAS,kBAAkB;AAC3B,SAAS,KAAK,WAA4B;AAKnC,MAAM,gCAEH,IAAmD;AAAA,EAsB5D,YACU,QAKR;AACD,UAAM,wBAAwB,mBAAmB,OAAO,QAAQ,OAAO,OAAO,EAAE,WAAW;AANlF;AAQT,SAAK,QAAQ,MAAM;AAEnB,SAAK,UAAU,OAAO;AAEtB,SAAK,MAAM,wBAAwB;AAAA,MAClC,OAAO;AAAA,MACP,OAAO;AAAA,IACR;AAAA,EACD;AAAA,EAtCQ;AAAA,EAER,QAA0B,UAAU,IAAY;AAAA,EAChD,CAAC,OAAO,WAAW,IAAI;AAAA,EAEf;AAAA,EAER,OAAe,mBACd,QACA,SACc;AACd,WAAO,4BAAoC,MAAM,GAAG,IAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EAC7F;AAAA,EAEA,OAAe,WACd,QACA,SACc;AACd,WAAO,oCAA4C,MAAM,GAAG,IAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EACrG;AAAA,EAqBA,KACC,aACA,YAC+B;AAC/B,WAAO,QAAQ,QAAQ,KAAK,QAAQ,MAAM,KAAK,GAAG,CAAC,EACjD;AAAA,MACA;AAAA,MACA;AAAA,IACD;AAAA,EACF;AAAA,EAEA,MACC,YACkB;AAClB,WAAO,KAAK,KAAK,QAAW,UAAU;AAAA,EACvC;AAAA,EAEA,QAAQ,WAA8D;AACrE,WAAO,KAAK;AAAA,MACX,CAAC,UAAU;AACV,oBAAY;AACZ,eAAO;AAAA,MACR;AAAA,MACA,CAAC,WAAW;AACX,oBAAY;AACZ,cAAM;AAAA,MACP;AAAA,IACD;AAAA,EACD;AACD;","names":[]}
1
+ {"version":3,"sources":["../../../src/singlestore-core/query-builders/count.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport { SQL, sql, type SQLWrapper } from '~/sql/sql.ts';\nimport type { SingleStoreSession } from '../session.ts';\nimport type { SingleStoreTable } from '../table.ts';\n/* import type { SingleStoreViewBase } from '../view-base.ts'; */\n\nexport class SingleStoreCountBuilder<\n\tTSession extends SingleStoreSession<any, any, any>,\n> extends SQL<number> implements Promise<number>, SQLWrapper {\n\tprivate sql: SQL<number>;\n\n\tstatic override readonly [entityKind] = 'SingleStoreCountBuilder';\n\t[Symbol.toStringTag] = 'SingleStoreCountBuilder';\n\n\tprivate session: TSession;\n\n\tprivate static buildEmbeddedCount(\n\t\tsource: SingleStoreTable | /* SingleStoreViewBase | */ SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`(select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters})`;\n\t}\n\n\tprivate static buildCount(\n\t\tsource: SingleStoreTable | /* SingleStoreViewBase | */ SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`select count(*) as count from ${source}${sql.raw(' where ').if(filters)}${filters}`;\n\t}\n\n\tconstructor(\n\t\treadonly params: {\n\t\t\tsource: SingleStoreTable | /* SingleStoreViewBase | */ SQL | SQLWrapper;\n\t\t\tfilters?: SQL<unknown>;\n\t\t\tsession: TSession;\n\t\t},\n\t) {\n\t\tsuper(SingleStoreCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);\n\n\t\tthis.mapWith(Number);\n\n\t\tthis.session = params.session;\n\n\t\tthis.sql = SingleStoreCountBuilder.buildCount(\n\t\t\tparams.source,\n\t\t\tparams.filters,\n\t\t);\n\t}\n\n\tthen<TResult1 = number, TResult2 = never>(\n\t\tonfulfilled?: ((value: number) => TResult1 | PromiseLike<TResult1>) | null | undefined,\n\t\tonrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null | undefined,\n\t): Promise<TResult1 | TResult2> {\n\t\treturn Promise.resolve(this.session.count(this.sql))\n\t\t\t.then(\n\t\t\t\tonfulfilled,\n\t\t\t\tonrejected,\n\t\t\t);\n\t}\n\n\tcatch(\n\t\tonRejected?: ((reason: any) => never | PromiseLike<never>) | null | undefined,\n\t): Promise<number> {\n\t\treturn this.then(undefined, onRejected);\n\t}\n\n\tfinally(onFinally?: (() => void) | null | undefined): Promise<number> {\n\t\treturn this.then(\n\t\t\t(value) => {\n\t\t\t\tonFinally?.();\n\t\t\t\treturn value;\n\t\t\t},\n\t\t\t(reason) => {\n\t\t\t\tonFinally?.();\n\t\t\t\tthrow reason;\n\t\t\t},\n\t\t);\n\t}\n}\n"],"mappings":"AAAA,SAAS,kBAAkB;AAC3B,SAAS,KAAK,WAA4B;AAKnC,MAAM,gCAEH,IAAmD;AAAA,EAsB5D,YACU,QAKR;AACD,UAAM,wBAAwB,mBAAmB,OAAO,QAAQ,OAAO,OAAO,EAAE,WAAW;AANlF;AAQT,SAAK,QAAQ,MAAM;AAEnB,SAAK,UAAU,OAAO;AAEtB,SAAK,MAAM,wBAAwB;AAAA,MAClC,OAAO;AAAA,MACP,OAAO;AAAA,IACR;AAAA,EACD;AAAA,EAtCQ;AAAA,EAER,QAA0B,UAAU,IAAI;AAAA,EACxC,CAAC,OAAO,WAAW,IAAI;AAAA,EAEf;AAAA,EAER,OAAe,mBACd,QACA,SACc;AACd,WAAO,4BAAoC,MAAM,GAAG,IAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EAC7F;AAAA,EAEA,OAAe,WACd,QACA,SACc;AACd,WAAO,oCAA4C,MAAM,GAAG,IAAI,IAAI,SAAS,EAAE,GAAG,OAAO,CAAC,GAAG,OAAO;AAAA,EACrG;AAAA,EAqBA,KACC,aACA,YAC+B;AAC/B,WAAO,QAAQ,QAAQ,KAAK,QAAQ,MAAM,KAAK,GAAG,CAAC,EACjD;AAAA,MACA;AAAA,MACA;AAAA,IACD;AAAA,EACF;AAAA,EAEA,MACC,YACkB;AAClB,WAAO,KAAK,KAAK,QAAW,UAAU;AAAA,EACvC;AAAA,EAEA,QAAQ,WAA8D;AACrE,WAAO,KAAK;AAAA,MACX,CAAC,UAAU;AACV,oBAAY;AACZ,eAAO;AAAA,MACR;AAAA,MACA,CAAC,WAAW;AACX,oBAAY;AACZ,cAAM;AAAA,MACP;AAAA,IACD;AAAA,EACD;AACD;","names":[]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/singlestore-core/query-builders/insert.ts"],"sourcesContent":["import { entityKind, is } from '~/entity.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport type { SingleStoreDialect } from '~/singlestore-core/dialect.ts';\nimport type {\n\tAnySingleStoreQueryResultHKT,\n\tPreparedQueryHKTBase,\n\tPreparedQueryKind,\n\tSingleStorePreparedQueryConfig,\n\tSingleStoreQueryResultHKT,\n\tSingleStoreQueryResultKind,\n\tSingleStoreSession,\n} from '~/singlestore-core/session.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport type { Placeholder, Query, SQLWrapper } from '~/sql/sql.ts';\nimport { Param, SQL, sql } from '~/sql/sql.ts';\nimport type { InferInsertModel, InferModelFromColumns } from '~/table.ts';\nimport { Table } from '~/table.ts';\nimport { mapUpdateSet, orderSelectedFields } from '~/utils.ts';\nimport type { AnySingleStoreColumn, SingleStoreColumn } from '../columns/common.ts';\nimport { extractUsedTable } from '../utils.ts';\nimport type { SelectedFieldsOrdered } from './select.types.ts';\nimport type { SingleStoreUpdateSetSource } from './update.ts';\n\nexport interface SingleStoreInsertConfig<TTable extends SingleStoreTable = SingleStoreTable> {\n\ttable: TTable;\n\tvalues: Record<string, Param | SQL>[];\n\tignore: boolean;\n\tonConflict?: SQL;\n\treturning?: SelectedFieldsOrdered;\n}\n\nexport type AnySingleStoreInsertConfig = SingleStoreInsertConfig<SingleStoreTable>;\n\nexport type SingleStoreInsertValue<\n\tTTable extends SingleStoreTable,\n\tTModel extends Record<string, any> = InferInsertModel<TTable>,\n> =\n\t& {\n\t\t[Key in keyof TModel]: TModel[Key] | SQL | Placeholder;\n\t}\n\t& {};\n\nexport class SingleStoreInsertBuilder<\n\tTTable extends SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n> {\n\tstatic readonly [entityKind]: string = 'SingleStoreInsertBuilder';\n\n\tprivate shouldIgnore = false;\n\n\tconstructor(\n\t\tprivate table: TTable,\n\t\tprivate session: SingleStoreSession,\n\t\tprivate dialect: SingleStoreDialect,\n\t) {}\n\n\tignore(): this {\n\t\tthis.shouldIgnore = true;\n\t\treturn this;\n\t}\n\n\tvalues(value: SingleStoreInsertValue<TTable>): SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tvalues(values: SingleStoreInsertValue<TTable>[]): SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tvalues(\n\t\tvalues: SingleStoreInsertValue<TTable> | SingleStoreInsertValue<TTable>[],\n\t): SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT> {\n\t\tvalues = Array.isArray(values) ? values : [values];\n\t\tif (values.length === 0) {\n\t\t\tthrow new Error('values() must be called with at least one value');\n\t\t}\n\t\tconst mappedValues = values.map((entry) => {\n\t\t\tconst result: Record<string, Param | SQL> = {};\n\t\t\tconst cols = this.table[Table.Symbol.Columns];\n\t\t\tfor (const colKey of Object.keys(entry)) {\n\t\t\t\tconst colValue = entry[colKey as keyof typeof entry];\n\t\t\t\tresult[colKey] = is(colValue, SQL) ? colValue : new Param(colValue, cols[colKey]);\n\t\t\t}\n\t\t\treturn result;\n\t\t});\n\n\t\treturn new SingleStoreInsertBase(this.table, mappedValues, this.shouldIgnore, this.session, this.dialect);\n\t}\n}\n\nexport type SingleStoreInsertWithout<\n\tT extends AnySingleStoreInsert,\n\tTDynamic extends boolean,\n\tK extends keyof T & string,\n> = TDynamic extends true ? T\n\t: Omit<\n\t\tSingleStoreInsertBase<\n\t\t\tT['_']['table'],\n\t\t\tT['_']['queryResult'],\n\t\t\tT['_']['preparedQueryHKT'],\n\t\t\tT['_']['returning'],\n\t\t\tTDynamic,\n\t\t\tT['_']['excludedMethods'] | '$returning'\n\t\t>,\n\t\tT['_']['excludedMethods'] | K\n\t>;\n\nexport type SingleStoreInsertDynamic<T extends AnySingleStoreInsert> = SingleStoreInsert<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['preparedQueryHKT'],\n\tT['_']['returning']\n>;\n\nexport type SingleStoreInsertPrepare<\n\tT extends AnySingleStoreInsert,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n> = PreparedQueryKind<\n\tT['_']['preparedQueryHKT'],\n\tSingleStorePreparedQueryConfig & {\n\t\texecute: TReturning extends undefined ? SingleStoreQueryResultKind<T['_']['queryResult'], never> : TReturning[];\n\t\titerator: never;\n\t},\n\ttrue\n>;\n\nexport type SingleStoreInsertOnDuplicateKeyUpdateConfig<T extends AnySingleStoreInsert> = {\n\tset: SingleStoreUpdateSetSource<T['_']['table']>;\n};\n\nexport type SingleStoreInsert<\n\tTTable extends SingleStoreTable = SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT = AnySingleStoreQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase = PreparedQueryHKTBase,\n\tTReturning extends Record<string, unknown> | undefined = Record<string, unknown> | undefined,\n> = SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT, TReturning, true, never>;\n\nexport type SingleStoreInsertReturning<\n\tT extends AnySingleStoreInsert,\n\tTDynamic extends boolean,\n> = SingleStoreInsertBase<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['preparedQueryHKT'],\n\tInferModelFromColumns<GetPrimarySerialOrDefaultKeys<T['_']['table']['_']['columns']>>,\n\tTDynamic,\n\tT['_']['excludedMethods'] | '$returning'\n>;\n\nexport type AnySingleStoreInsert = SingleStoreInsertBase<any, any, any, any, any, any>;\n\nexport interface SingleStoreInsertBase<\n\tTTable extends SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n> extends\n\tQueryPromise<TReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[]>,\n\tRunnableQuery<\n\t\tTReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[],\n\t\t'singlestore'\n\t>,\n\tSQLWrapper\n{\n\treadonly _: {\n\t\treadonly dialect: 'singlestore';\n\t\treadonly table: TTable;\n\t\treadonly queryResult: TQueryResult;\n\t\treadonly preparedQueryHKT: TPreparedQueryHKT;\n\t\treadonly dynamic: TDynamic;\n\t\treadonly excludedMethods: TExcludedMethods;\n\t\treadonly returning: TReturning;\n\t\treadonly result: TReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[];\n\t};\n}\n\nexport type PrimaryKeyKeys<T extends Record<string, AnySingleStoreColumn>> = {\n\t[K in keyof T]: T[K]['_']['isPrimaryKey'] extends true ? T[K]['_']['isAutoincrement'] extends true ? K\n\t\t: T[K]['_']['hasRuntimeDefault'] extends true ? T[K]['_']['isPrimaryKey'] extends true ? K : never\n\t\t: never\n\t\t: T[K]['_']['hasRuntimeDefault'] extends true ? T[K]['_']['isPrimaryKey'] extends true ? K : never\n\t\t: never;\n}[keyof T];\n\nexport type GetPrimarySerialOrDefaultKeys<T extends Record<string, AnySingleStoreColumn>> = {\n\t[K in PrimaryKeyKeys<T>]: T[K];\n};\n\nexport class SingleStoreInsertBase<\n\tTTable extends SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTDynamic extends boolean = false,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTExcludedMethods extends string = never,\n> extends QueryPromise<TReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[]>\n\timplements\n\t\tRunnableQuery<\n\t\t\tTReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[],\n\t\t\t'singlestore'\n\t\t>,\n\t\tSQLWrapper\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreInsert';\n\n\tdeclare protected $table: TTable;\n\n\tprivate config: SingleStoreInsertConfig<TTable>;\n\n\tconstructor(\n\t\ttable: TTable,\n\t\tvalues: SingleStoreInsertConfig['values'],\n\t\tignore: boolean,\n\t\tprivate session: SingleStoreSession,\n\t\tprivate dialect: SingleStoreDialect,\n\t) {\n\t\tsuper();\n\t\tthis.config = { table, values, ignore };\n\t}\n\n\t/**\n\t * Adds an `on duplicate key update` clause to the query.\n\t *\n\t * Calling this method will update update the row if any unique index conflicts. MySQL will automatically determine the conflict target based on the primary key and unique indexes.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/insert#on-duplicate-key-update}\n\t *\n\t * @param config The `set` clause\n\t *\n\t * @example\n\t * ```ts\n\t * await db.insert(cars)\n\t * .values({ id: 1, brand: 'BMW'})\n\t * .onDuplicateKeyUpdate({ set: { brand: 'Porsche' }});\n\t * ```\n\t *\n\t * While MySQL does not directly support doing nothing on conflict, you can perform a no-op by setting any column's value to itself and achieve the same effect:\n\t *\n\t * ```ts\n\t * import { sql } from 'drizzle-orm';\n\t *\n\t * await db.insert(cars)\n\t * .values({ id: 1, brand: 'BMW' })\n\t * .onDuplicateKeyUpdate({ set: { id: sql`id` } });\n\t * ```\n\t */\n\tonDuplicateKeyUpdate(\n\t\tconfig: SingleStoreInsertOnDuplicateKeyUpdateConfig<this>,\n\t): SingleStoreInsertWithout<this, TDynamic, 'onDuplicateKeyUpdate'> {\n\t\tconst setSql = this.dialect.buildUpdateSet(this.config.table, mapUpdateSet(this.config.table, config.set));\n\t\tthis.config.onConflict = sql`update ${setSql}`;\n\t\treturn this as any;\n\t}\n\n\t$returningId(): SingleStoreInsertWithout<\n\t\tSingleStoreInsertReturning<this, TDynamic>,\n\t\tTDynamic,\n\t\t'$returningId'\n\t> {\n\t\tconst returning: SelectedFieldsOrdered = [];\n\t\tfor (const [key, value] of Object.entries(this.config.table[Table.Symbol.Columns])) {\n\t\t\tif (value.primary) {\n\t\t\t\treturning.push({ field: value, path: [key] });\n\t\t\t}\n\t\t}\n\t\tthis.config.returning = orderSelectedFields<SingleStoreColumn>(this.config.table[Table.Symbol.Columns]);\n\t\treturn this as any;\n\t}\n\n\t/** @internal */\n\tgetSQL(): SQL {\n\t\treturn this.dialect.buildInsertQuery(this.config).sql;\n\t}\n\n\ttoSQL(): Query {\n\t\tconst { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n\t\treturn rest;\n\t}\n\n\tprepare(): SingleStoreInsertPrepare<this, TReturning> {\n\t\tconst { sql, generatedIds } = this.dialect.buildInsertQuery(this.config);\n\t\treturn this.session.prepareQuery(\n\t\t\tthis.dialect.sqlToQuery(sql),\n\t\t\tundefined,\n\t\t\tundefined,\n\t\t\tgeneratedIds,\n\t\t\tthis.config.returning,\n\t\t\t{\n\t\t\t\ttype: 'delete',\n\t\t\t\ttables: extractUsedTable(this.config.table),\n\t\t\t},\n\t\t) as SingleStoreInsertPrepare<this, TReturning>;\n\t}\n\n\toverride execute: ReturnType<this['prepare']>['execute'] = (placeholderValues) => {\n\t\treturn this.prepare().execute(placeholderValues);\n\t};\n\n\tprivate createIterator = (): ReturnType<this['prepare']>['iterator'] => {\n\t\tconst self = this;\n\t\treturn async function*(placeholderValues) {\n\t\t\tyield* self.prepare().iterator(placeholderValues);\n\t\t};\n\t};\n\n\titerator = this.createIterator();\n\n\t$dynamic(): SingleStoreInsertDynamic<this> {\n\t\treturn this as any;\n\t}\n}\n"],"mappings":"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","names":["import_utils","sql"]}
1
+ {"version":3,"sources":["../../../src/singlestore-core/query-builders/insert.ts"],"sourcesContent":["import { entityKind, is } from '~/entity.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport type { SingleStoreDialect } from '~/singlestore-core/dialect.ts';\nimport type {\n\tAnySingleStoreQueryResultHKT,\n\tPreparedQueryHKTBase,\n\tPreparedQueryKind,\n\tSingleStorePreparedQueryConfig,\n\tSingleStoreQueryResultHKT,\n\tSingleStoreQueryResultKind,\n\tSingleStoreSession,\n} from '~/singlestore-core/session.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport type { Placeholder, Query, SQLWrapper } from '~/sql/sql.ts';\nimport { Param, SQL, sql } from '~/sql/sql.ts';\nimport type { InferInsertModel, InferModelFromColumns } from '~/table.ts';\nimport { Table } from '~/table.ts';\nimport { mapUpdateSet, orderSelectedFields } from '~/utils.ts';\nimport type { AnySingleStoreColumn, SingleStoreColumn } from '../columns/common.ts';\nimport { extractUsedTable } from '../utils.ts';\nimport type { SelectedFieldsOrdered } from './select.types.ts';\nimport type { SingleStoreUpdateSetSource } from './update.ts';\n\nexport interface SingleStoreInsertConfig<TTable extends SingleStoreTable = SingleStoreTable> {\n\ttable: TTable;\n\tvalues: Record<string, Param | SQL>[];\n\tignore: boolean;\n\tonConflict?: SQL;\n\treturning?: SelectedFieldsOrdered;\n}\n\nexport type AnySingleStoreInsertConfig = SingleStoreInsertConfig<SingleStoreTable>;\n\nexport type SingleStoreInsertValue<\n\tTTable extends SingleStoreTable,\n\tTModel extends InferInsertModel<TTable> = InferInsertModel<TTable>,\n> =\n\t& {\n\t\t[Key in keyof TModel]: TModel[Key] | SQL | Placeholder;\n\t}\n\t& {};\n\nexport class SingleStoreInsertBuilder<\n\tTTable extends SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n> {\n\tstatic readonly [entityKind]: string = 'SingleStoreInsertBuilder';\n\n\tprivate shouldIgnore = false;\n\n\tconstructor(\n\t\tprivate table: TTable,\n\t\tprivate session: SingleStoreSession,\n\t\tprivate dialect: SingleStoreDialect,\n\t) {}\n\n\tignore(): this {\n\t\tthis.shouldIgnore = true;\n\t\treturn this;\n\t}\n\n\tvalues(value: SingleStoreInsertValue<TTable>): SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tvalues(values: SingleStoreInsertValue<TTable>[]): SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tvalues(\n\t\tvalues: SingleStoreInsertValue<TTable> | SingleStoreInsertValue<TTable>[],\n\t): SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT> {\n\t\tvalues = Array.isArray(values) ? values : [values];\n\t\tif (values.length === 0) {\n\t\t\tthrow new Error('values() must be called with at least one value');\n\t\t}\n\t\tconst mappedValues = values.map((entry) => {\n\t\t\tconst result: Record<string, Param | SQL> = {};\n\t\t\tconst cols = this.table[Table.Symbol.Columns];\n\t\t\tfor (const colKey of Object.keys(entry)) {\n\t\t\t\tconst colValue = entry[colKey as keyof typeof entry];\n\t\t\t\tresult[colKey] = is(colValue, SQL) ? colValue : new Param(colValue, cols[colKey]);\n\t\t\t}\n\t\t\treturn result;\n\t\t});\n\n\t\treturn new SingleStoreInsertBase(this.table, mappedValues, this.shouldIgnore, this.session, this.dialect);\n\t}\n}\n\nexport type SingleStoreInsertWithout<\n\tT extends AnySingleStoreInsert,\n\tTDynamic extends boolean,\n\tK extends keyof T & string,\n> = TDynamic extends true ? T\n\t: Omit<\n\t\tSingleStoreInsertBase<\n\t\t\tT['_']['table'],\n\t\t\tT['_']['queryResult'],\n\t\t\tT['_']['preparedQueryHKT'],\n\t\t\tT['_']['returning'],\n\t\t\tTDynamic,\n\t\t\tT['_']['excludedMethods'] | '$returning'\n\t\t>,\n\t\tT['_']['excludedMethods'] | K\n\t>;\n\nexport type SingleStoreInsertDynamic<T extends AnySingleStoreInsert> = SingleStoreInsert<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['preparedQueryHKT'],\n\tT['_']['returning']\n>;\n\nexport type SingleStoreInsertPrepare<\n\tT extends AnySingleStoreInsert,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n> = PreparedQueryKind<\n\tT['_']['preparedQueryHKT'],\n\tSingleStorePreparedQueryConfig & {\n\t\texecute: TReturning extends undefined ? SingleStoreQueryResultKind<T['_']['queryResult'], never> : TReturning[];\n\t\titerator: never;\n\t},\n\ttrue\n>;\n\nexport type SingleStoreInsertOnDuplicateKeyUpdateConfig<T extends AnySingleStoreInsert> = {\n\tset: SingleStoreUpdateSetSource<T['_']['table']>;\n};\n\nexport type SingleStoreInsert<\n\tTTable extends SingleStoreTable = SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT = AnySingleStoreQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase = PreparedQueryHKTBase,\n\tTReturning extends Record<string, unknown> | undefined = Record<string, unknown> | undefined,\n> = SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT, TReturning, true, never>;\n\nexport type SingleStoreInsertReturning<\n\tT extends AnySingleStoreInsert,\n\tTDynamic extends boolean,\n> = SingleStoreInsertBase<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['preparedQueryHKT'],\n\tInferModelFromColumns<GetPrimarySerialOrDefaultKeys<T['_']['table']['_']['columns']>>,\n\tTDynamic,\n\tT['_']['excludedMethods'] | '$returning'\n>;\n\nexport type AnySingleStoreInsert = SingleStoreInsertBase<any, any, any, any, any, any>;\n\nexport interface SingleStoreInsertBase<\n\tTTable extends SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n> extends\n\tQueryPromise<TReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[]>,\n\tRunnableQuery<\n\t\tTReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[],\n\t\t'singlestore'\n\t>,\n\tSQLWrapper\n{\n\treadonly _: {\n\t\treadonly dialect: 'singlestore';\n\t\treadonly table: TTable;\n\t\treadonly queryResult: TQueryResult;\n\t\treadonly preparedQueryHKT: TPreparedQueryHKT;\n\t\treadonly dynamic: TDynamic;\n\t\treadonly excludedMethods: TExcludedMethods;\n\t\treadonly returning: TReturning;\n\t\treadonly result: TReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[];\n\t};\n}\n\nexport type PrimaryKeyKeys<T extends Record<string, AnySingleStoreColumn>> = {\n\t[K in keyof T]: T[K]['_']['isPrimaryKey'] extends true ? T[K]['_']['isAutoincrement'] extends true ? K\n\t\t: T[K]['_']['hasRuntimeDefault'] extends true ? T[K]['_']['isPrimaryKey'] extends true ? K : never\n\t\t: never\n\t\t: T[K]['_']['hasRuntimeDefault'] extends true ? T[K]['_']['isPrimaryKey'] extends true ? K : never\n\t\t: never;\n}[keyof T];\n\nexport type GetPrimarySerialOrDefaultKeys<T extends Record<string, AnySingleStoreColumn>> = {\n\t[K in PrimaryKeyKeys<T>]: T[K];\n};\n\nexport class SingleStoreInsertBase<\n\tTTable extends SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTDynamic extends boolean = false,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTExcludedMethods extends string = never,\n> extends QueryPromise<TReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[]>\n\timplements\n\t\tRunnableQuery<\n\t\t\tTReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[],\n\t\t\t'singlestore'\n\t\t>,\n\t\tSQLWrapper\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreInsert';\n\n\tdeclare protected $table: TTable;\n\n\tprivate config: SingleStoreInsertConfig<TTable>;\n\n\tconstructor(\n\t\ttable: TTable,\n\t\tvalues: SingleStoreInsertConfig['values'],\n\t\tignore: boolean,\n\t\tprivate session: SingleStoreSession,\n\t\tprivate dialect: SingleStoreDialect,\n\t) {\n\t\tsuper();\n\t\tthis.config = { table, values, ignore };\n\t}\n\n\t/**\n\t * Adds an `on duplicate key update` clause to the query.\n\t *\n\t * Calling this method will update update the row if any unique index conflicts. MySQL will automatically determine the conflict target based on the primary key and unique indexes.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/insert#on-duplicate-key-update}\n\t *\n\t * @param config The `set` clause\n\t *\n\t * @example\n\t * ```ts\n\t * await db.insert(cars)\n\t * .values({ id: 1, brand: 'BMW'})\n\t * .onDuplicateKeyUpdate({ set: { brand: 'Porsche' }});\n\t * ```\n\t *\n\t * While MySQL does not directly support doing nothing on conflict, you can perform a no-op by setting any column's value to itself and achieve the same effect:\n\t *\n\t * ```ts\n\t * import { sql } from 'drizzle-orm';\n\t *\n\t * await db.insert(cars)\n\t * .values({ id: 1, brand: 'BMW' })\n\t * .onDuplicateKeyUpdate({ set: { id: sql`id` } });\n\t * ```\n\t */\n\tonDuplicateKeyUpdate(\n\t\tconfig: SingleStoreInsertOnDuplicateKeyUpdateConfig<this>,\n\t): SingleStoreInsertWithout<this, TDynamic, 'onDuplicateKeyUpdate'> {\n\t\tconst setSql = this.dialect.buildUpdateSet(this.config.table, mapUpdateSet(this.config.table, config.set));\n\t\tthis.config.onConflict = sql`update ${setSql}`;\n\t\treturn this as any;\n\t}\n\n\t$returningId(): SingleStoreInsertWithout<\n\t\tSingleStoreInsertReturning<this, TDynamic>,\n\t\tTDynamic,\n\t\t'$returningId'\n\t> {\n\t\tconst returning: SelectedFieldsOrdered = [];\n\t\tfor (const [key, value] of Object.entries(this.config.table[Table.Symbol.Columns])) {\n\t\t\tif (value.primary) {\n\t\t\t\treturning.push({ field: value, path: [key] });\n\t\t\t}\n\t\t}\n\t\tthis.config.returning = orderSelectedFields<SingleStoreColumn>(this.config.table[Table.Symbol.Columns]);\n\t\treturn this as any;\n\t}\n\n\t/** @internal */\n\tgetSQL(): SQL {\n\t\treturn this.dialect.buildInsertQuery(this.config).sql;\n\t}\n\n\ttoSQL(): Query {\n\t\tconst { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n\t\treturn rest;\n\t}\n\n\tprepare(): SingleStoreInsertPrepare<this, TReturning> {\n\t\tconst { sql, generatedIds } = this.dialect.buildInsertQuery(this.config);\n\t\treturn this.session.prepareQuery(\n\t\t\tthis.dialect.sqlToQuery(sql),\n\t\t\tundefined,\n\t\t\tundefined,\n\t\t\tgeneratedIds,\n\t\t\tthis.config.returning,\n\t\t\t{\n\t\t\t\ttype: 'delete',\n\t\t\t\ttables: extractUsedTable(this.config.table),\n\t\t\t},\n\t\t) as SingleStoreInsertPrepare<this, TReturning>;\n\t}\n\n\toverride execute: ReturnType<this['prepare']>['execute'] = (placeholderValues) => {\n\t\treturn this.prepare().execute(placeholderValues);\n\t};\n\n\tprivate createIterator = (): ReturnType<this['prepare']>['iterator'] => {\n\t\tconst self = this;\n\t\treturn async function*(placeholderValues) {\n\t\t\tyield* self.prepare().iterator(placeholderValues);\n\t\t};\n\t};\n\n\titerator = this.createIterator();\n\n\t$dynamic(): SingleStoreInsertDynamic<this> {\n\t\treturn this as any;\n\t}\n}\n"],"mappings":"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","names":["import_utils","sql"]}
@@ -18,7 +18,7 @@ export interface SingleStoreInsertConfig<TTable extends SingleStoreTable = Singl
18
18
  returning?: SelectedFieldsOrdered;
19
19
  }
20
20
  export type AnySingleStoreInsertConfig = SingleStoreInsertConfig<SingleStoreTable>;
21
- export type SingleStoreInsertValue<TTable extends SingleStoreTable, TModel extends Record<string, any> = InferInsertModel<TTable>> = {
21
+ export type SingleStoreInsertValue<TTable extends SingleStoreTable, TModel extends InferInsertModel<TTable> = InferInsertModel<TTable>> = {
22
22
  [Key in keyof TModel]: TModel[Key] | SQL | Placeholder;
23
23
  } & {};
24
24
  export declare class SingleStoreInsertBuilder<TTable extends SingleStoreTable, TQueryResult extends SingleStoreQueryResultHKT, TPreparedQueryHKT extends PreparedQueryHKTBase> {
@@ -18,7 +18,7 @@ export interface SingleStoreInsertConfig<TTable extends SingleStoreTable = Singl
18
18
  returning?: SelectedFieldsOrdered;
19
19
  }
20
20
  export type AnySingleStoreInsertConfig = SingleStoreInsertConfig<SingleStoreTable>;
21
- export type SingleStoreInsertValue<TTable extends SingleStoreTable, TModel extends Record<string, any> = InferInsertModel<TTable>> = {
21
+ export type SingleStoreInsertValue<TTable extends SingleStoreTable, TModel extends InferInsertModel<TTable> = InferInsertModel<TTable>> = {
22
22
  [Key in keyof TModel]: TModel[Key] | SQL | Placeholder;
23
23
  } & {};
24
24
  export declare class SingleStoreInsertBuilder<TTable extends SingleStoreTable, TQueryResult extends SingleStoreQueryResultHKT, TPreparedQueryHKT extends PreparedQueryHKTBase> {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/singlestore-core/query-builders/insert.ts"],"sourcesContent":["import { entityKind, is } from '~/entity.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport type { SingleStoreDialect } from '~/singlestore-core/dialect.ts';\nimport type {\n\tAnySingleStoreQueryResultHKT,\n\tPreparedQueryHKTBase,\n\tPreparedQueryKind,\n\tSingleStorePreparedQueryConfig,\n\tSingleStoreQueryResultHKT,\n\tSingleStoreQueryResultKind,\n\tSingleStoreSession,\n} from '~/singlestore-core/session.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport type { Placeholder, Query, SQLWrapper } from '~/sql/sql.ts';\nimport { Param, SQL, sql } from '~/sql/sql.ts';\nimport type { InferInsertModel, InferModelFromColumns } from '~/table.ts';\nimport { Table } from '~/table.ts';\nimport { mapUpdateSet, orderSelectedFields } from '~/utils.ts';\nimport type { AnySingleStoreColumn, SingleStoreColumn } from '../columns/common.ts';\nimport { extractUsedTable } from '../utils.ts';\nimport type { SelectedFieldsOrdered } from './select.types.ts';\nimport type { SingleStoreUpdateSetSource } from './update.ts';\n\nexport interface SingleStoreInsertConfig<TTable extends SingleStoreTable = SingleStoreTable> {\n\ttable: TTable;\n\tvalues: Record<string, Param | SQL>[];\n\tignore: boolean;\n\tonConflict?: SQL;\n\treturning?: SelectedFieldsOrdered;\n}\n\nexport type AnySingleStoreInsertConfig = SingleStoreInsertConfig<SingleStoreTable>;\n\nexport type SingleStoreInsertValue<\n\tTTable extends SingleStoreTable,\n\tTModel extends Record<string, any> = InferInsertModel<TTable>,\n> =\n\t& {\n\t\t[Key in keyof TModel]: TModel[Key] | SQL | Placeholder;\n\t}\n\t& {};\n\nexport class SingleStoreInsertBuilder<\n\tTTable extends SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n> {\n\tstatic readonly [entityKind]: string = 'SingleStoreInsertBuilder';\n\n\tprivate shouldIgnore = false;\n\n\tconstructor(\n\t\tprivate table: TTable,\n\t\tprivate session: SingleStoreSession,\n\t\tprivate dialect: SingleStoreDialect,\n\t) {}\n\n\tignore(): this {\n\t\tthis.shouldIgnore = true;\n\t\treturn this;\n\t}\n\n\tvalues(value: SingleStoreInsertValue<TTable>): SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tvalues(values: SingleStoreInsertValue<TTable>[]): SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tvalues(\n\t\tvalues: SingleStoreInsertValue<TTable> | SingleStoreInsertValue<TTable>[],\n\t): SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT> {\n\t\tvalues = Array.isArray(values) ? values : [values];\n\t\tif (values.length === 0) {\n\t\t\tthrow new Error('values() must be called with at least one value');\n\t\t}\n\t\tconst mappedValues = values.map((entry) => {\n\t\t\tconst result: Record<string, Param | SQL> = {};\n\t\t\tconst cols = this.table[Table.Symbol.Columns];\n\t\t\tfor (const colKey of Object.keys(entry)) {\n\t\t\t\tconst colValue = entry[colKey as keyof typeof entry];\n\t\t\t\tresult[colKey] = is(colValue, SQL) ? colValue : new Param(colValue, cols[colKey]);\n\t\t\t}\n\t\t\treturn result;\n\t\t});\n\n\t\treturn new SingleStoreInsertBase(this.table, mappedValues, this.shouldIgnore, this.session, this.dialect);\n\t}\n}\n\nexport type SingleStoreInsertWithout<\n\tT extends AnySingleStoreInsert,\n\tTDynamic extends boolean,\n\tK extends keyof T & string,\n> = TDynamic extends true ? T\n\t: Omit<\n\t\tSingleStoreInsertBase<\n\t\t\tT['_']['table'],\n\t\t\tT['_']['queryResult'],\n\t\t\tT['_']['preparedQueryHKT'],\n\t\t\tT['_']['returning'],\n\t\t\tTDynamic,\n\t\t\tT['_']['excludedMethods'] | '$returning'\n\t\t>,\n\t\tT['_']['excludedMethods'] | K\n\t>;\n\nexport type SingleStoreInsertDynamic<T extends AnySingleStoreInsert> = SingleStoreInsert<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['preparedQueryHKT'],\n\tT['_']['returning']\n>;\n\nexport type SingleStoreInsertPrepare<\n\tT extends AnySingleStoreInsert,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n> = PreparedQueryKind<\n\tT['_']['preparedQueryHKT'],\n\tSingleStorePreparedQueryConfig & {\n\t\texecute: TReturning extends undefined ? SingleStoreQueryResultKind<T['_']['queryResult'], never> : TReturning[];\n\t\titerator: never;\n\t},\n\ttrue\n>;\n\nexport type SingleStoreInsertOnDuplicateKeyUpdateConfig<T extends AnySingleStoreInsert> = {\n\tset: SingleStoreUpdateSetSource<T['_']['table']>;\n};\n\nexport type SingleStoreInsert<\n\tTTable extends SingleStoreTable = SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT = AnySingleStoreQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase = PreparedQueryHKTBase,\n\tTReturning extends Record<string, unknown> | undefined = Record<string, unknown> | undefined,\n> = SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT, TReturning, true, never>;\n\nexport type SingleStoreInsertReturning<\n\tT extends AnySingleStoreInsert,\n\tTDynamic extends boolean,\n> = SingleStoreInsertBase<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['preparedQueryHKT'],\n\tInferModelFromColumns<GetPrimarySerialOrDefaultKeys<T['_']['table']['_']['columns']>>,\n\tTDynamic,\n\tT['_']['excludedMethods'] | '$returning'\n>;\n\nexport type AnySingleStoreInsert = SingleStoreInsertBase<any, any, any, any, any, any>;\n\nexport interface SingleStoreInsertBase<\n\tTTable extends SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n> extends\n\tQueryPromise<TReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[]>,\n\tRunnableQuery<\n\t\tTReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[],\n\t\t'singlestore'\n\t>,\n\tSQLWrapper\n{\n\treadonly _: {\n\t\treadonly dialect: 'singlestore';\n\t\treadonly table: TTable;\n\t\treadonly queryResult: TQueryResult;\n\t\treadonly preparedQueryHKT: TPreparedQueryHKT;\n\t\treadonly dynamic: TDynamic;\n\t\treadonly excludedMethods: TExcludedMethods;\n\t\treadonly returning: TReturning;\n\t\treadonly result: TReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[];\n\t};\n}\n\nexport type PrimaryKeyKeys<T extends Record<string, AnySingleStoreColumn>> = {\n\t[K in keyof T]: T[K]['_']['isPrimaryKey'] extends true ? T[K]['_']['isAutoincrement'] extends true ? K\n\t\t: T[K]['_']['hasRuntimeDefault'] extends true ? T[K]['_']['isPrimaryKey'] extends true ? K : never\n\t\t: never\n\t\t: T[K]['_']['hasRuntimeDefault'] extends true ? T[K]['_']['isPrimaryKey'] extends true ? K : never\n\t\t: never;\n}[keyof T];\n\nexport type GetPrimarySerialOrDefaultKeys<T extends Record<string, AnySingleStoreColumn>> = {\n\t[K in PrimaryKeyKeys<T>]: T[K];\n};\n\nexport class SingleStoreInsertBase<\n\tTTable extends SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTDynamic extends boolean = false,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTExcludedMethods extends string = never,\n> extends QueryPromise<TReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[]>\n\timplements\n\t\tRunnableQuery<\n\t\t\tTReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[],\n\t\t\t'singlestore'\n\t\t>,\n\t\tSQLWrapper\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreInsert';\n\n\tdeclare protected $table: TTable;\n\n\tprivate config: SingleStoreInsertConfig<TTable>;\n\n\tconstructor(\n\t\ttable: TTable,\n\t\tvalues: SingleStoreInsertConfig['values'],\n\t\tignore: boolean,\n\t\tprivate session: SingleStoreSession,\n\t\tprivate dialect: SingleStoreDialect,\n\t) {\n\t\tsuper();\n\t\tthis.config = { table, values, ignore };\n\t}\n\n\t/**\n\t * Adds an `on duplicate key update` clause to the query.\n\t *\n\t * Calling this method will update update the row if any unique index conflicts. MySQL will automatically determine the conflict target based on the primary key and unique indexes.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/insert#on-duplicate-key-update}\n\t *\n\t * @param config The `set` clause\n\t *\n\t * @example\n\t * ```ts\n\t * await db.insert(cars)\n\t * .values({ id: 1, brand: 'BMW'})\n\t * .onDuplicateKeyUpdate({ set: { brand: 'Porsche' }});\n\t * ```\n\t *\n\t * While MySQL does not directly support doing nothing on conflict, you can perform a no-op by setting any column's value to itself and achieve the same effect:\n\t *\n\t * ```ts\n\t * import { sql } from 'drizzle-orm';\n\t *\n\t * await db.insert(cars)\n\t * .values({ id: 1, brand: 'BMW' })\n\t * .onDuplicateKeyUpdate({ set: { id: sql`id` } });\n\t * ```\n\t */\n\tonDuplicateKeyUpdate(\n\t\tconfig: SingleStoreInsertOnDuplicateKeyUpdateConfig<this>,\n\t): SingleStoreInsertWithout<this, TDynamic, 'onDuplicateKeyUpdate'> {\n\t\tconst setSql = this.dialect.buildUpdateSet(this.config.table, mapUpdateSet(this.config.table, config.set));\n\t\tthis.config.onConflict = sql`update ${setSql}`;\n\t\treturn this as any;\n\t}\n\n\t$returningId(): SingleStoreInsertWithout<\n\t\tSingleStoreInsertReturning<this, TDynamic>,\n\t\tTDynamic,\n\t\t'$returningId'\n\t> {\n\t\tconst returning: SelectedFieldsOrdered = [];\n\t\tfor (const [key, value] of Object.entries(this.config.table[Table.Symbol.Columns])) {\n\t\t\tif (value.primary) {\n\t\t\t\treturning.push({ field: value, path: [key] });\n\t\t\t}\n\t\t}\n\t\tthis.config.returning = orderSelectedFields<SingleStoreColumn>(this.config.table[Table.Symbol.Columns]);\n\t\treturn this as any;\n\t}\n\n\t/** @internal */\n\tgetSQL(): SQL {\n\t\treturn this.dialect.buildInsertQuery(this.config).sql;\n\t}\n\n\ttoSQL(): Query {\n\t\tconst { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n\t\treturn rest;\n\t}\n\n\tprepare(): SingleStoreInsertPrepare<this, TReturning> {\n\t\tconst { sql, generatedIds } = this.dialect.buildInsertQuery(this.config);\n\t\treturn this.session.prepareQuery(\n\t\t\tthis.dialect.sqlToQuery(sql),\n\t\t\tundefined,\n\t\t\tundefined,\n\t\t\tgeneratedIds,\n\t\t\tthis.config.returning,\n\t\t\t{\n\t\t\t\ttype: 'delete',\n\t\t\t\ttables: extractUsedTable(this.config.table),\n\t\t\t},\n\t\t) as SingleStoreInsertPrepare<this, TReturning>;\n\t}\n\n\toverride execute: ReturnType<this['prepare']>['execute'] = (placeholderValues) => {\n\t\treturn this.prepare().execute(placeholderValues);\n\t};\n\n\tprivate createIterator = (): ReturnType<this['prepare']>['iterator'] => {\n\t\tconst self = this;\n\t\treturn async function*(placeholderValues) {\n\t\t\tyield* self.prepare().iterator(placeholderValues);\n\t\t};\n\t};\n\n\titerator = this.createIterator();\n\n\t$dynamic(): SingleStoreInsertDynamic<this> {\n\t\treturn this as any;\n\t}\n}\n"],"mappings":"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","names":["sql"]}
1
+ {"version":3,"sources":["../../../src/singlestore-core/query-builders/insert.ts"],"sourcesContent":["import { entityKind, is } from '~/entity.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport type { SingleStoreDialect } from '~/singlestore-core/dialect.ts';\nimport type {\n\tAnySingleStoreQueryResultHKT,\n\tPreparedQueryHKTBase,\n\tPreparedQueryKind,\n\tSingleStorePreparedQueryConfig,\n\tSingleStoreQueryResultHKT,\n\tSingleStoreQueryResultKind,\n\tSingleStoreSession,\n} from '~/singlestore-core/session.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport type { Placeholder, Query, SQLWrapper } from '~/sql/sql.ts';\nimport { Param, SQL, sql } from '~/sql/sql.ts';\nimport type { InferInsertModel, InferModelFromColumns } from '~/table.ts';\nimport { Table } from '~/table.ts';\nimport { mapUpdateSet, orderSelectedFields } from '~/utils.ts';\nimport type { AnySingleStoreColumn, SingleStoreColumn } from '../columns/common.ts';\nimport { extractUsedTable } from '../utils.ts';\nimport type { SelectedFieldsOrdered } from './select.types.ts';\nimport type { SingleStoreUpdateSetSource } from './update.ts';\n\nexport interface SingleStoreInsertConfig<TTable extends SingleStoreTable = SingleStoreTable> {\n\ttable: TTable;\n\tvalues: Record<string, Param | SQL>[];\n\tignore: boolean;\n\tonConflict?: SQL;\n\treturning?: SelectedFieldsOrdered;\n}\n\nexport type AnySingleStoreInsertConfig = SingleStoreInsertConfig<SingleStoreTable>;\n\nexport type SingleStoreInsertValue<\n\tTTable extends SingleStoreTable,\n\tTModel extends InferInsertModel<TTable> = InferInsertModel<TTable>,\n> =\n\t& {\n\t\t[Key in keyof TModel]: TModel[Key] | SQL | Placeholder;\n\t}\n\t& {};\n\nexport class SingleStoreInsertBuilder<\n\tTTable extends SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n> {\n\tstatic readonly [entityKind]: string = 'SingleStoreInsertBuilder';\n\n\tprivate shouldIgnore = false;\n\n\tconstructor(\n\t\tprivate table: TTable,\n\t\tprivate session: SingleStoreSession,\n\t\tprivate dialect: SingleStoreDialect,\n\t) {}\n\n\tignore(): this {\n\t\tthis.shouldIgnore = true;\n\t\treturn this;\n\t}\n\n\tvalues(value: SingleStoreInsertValue<TTable>): SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tvalues(values: SingleStoreInsertValue<TTable>[]): SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tvalues(\n\t\tvalues: SingleStoreInsertValue<TTable> | SingleStoreInsertValue<TTable>[],\n\t): SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT> {\n\t\tvalues = Array.isArray(values) ? values : [values];\n\t\tif (values.length === 0) {\n\t\t\tthrow new Error('values() must be called with at least one value');\n\t\t}\n\t\tconst mappedValues = values.map((entry) => {\n\t\t\tconst result: Record<string, Param | SQL> = {};\n\t\t\tconst cols = this.table[Table.Symbol.Columns];\n\t\t\tfor (const colKey of Object.keys(entry)) {\n\t\t\t\tconst colValue = entry[colKey as keyof typeof entry];\n\t\t\t\tresult[colKey] = is(colValue, SQL) ? colValue : new Param(colValue, cols[colKey]);\n\t\t\t}\n\t\t\treturn result;\n\t\t});\n\n\t\treturn new SingleStoreInsertBase(this.table, mappedValues, this.shouldIgnore, this.session, this.dialect);\n\t}\n}\n\nexport type SingleStoreInsertWithout<\n\tT extends AnySingleStoreInsert,\n\tTDynamic extends boolean,\n\tK extends keyof T & string,\n> = TDynamic extends true ? T\n\t: Omit<\n\t\tSingleStoreInsertBase<\n\t\t\tT['_']['table'],\n\t\t\tT['_']['queryResult'],\n\t\t\tT['_']['preparedQueryHKT'],\n\t\t\tT['_']['returning'],\n\t\t\tTDynamic,\n\t\t\tT['_']['excludedMethods'] | '$returning'\n\t\t>,\n\t\tT['_']['excludedMethods'] | K\n\t>;\n\nexport type SingleStoreInsertDynamic<T extends AnySingleStoreInsert> = SingleStoreInsert<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['preparedQueryHKT'],\n\tT['_']['returning']\n>;\n\nexport type SingleStoreInsertPrepare<\n\tT extends AnySingleStoreInsert,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n> = PreparedQueryKind<\n\tT['_']['preparedQueryHKT'],\n\tSingleStorePreparedQueryConfig & {\n\t\texecute: TReturning extends undefined ? SingleStoreQueryResultKind<T['_']['queryResult'], never> : TReturning[];\n\t\titerator: never;\n\t},\n\ttrue\n>;\n\nexport type SingleStoreInsertOnDuplicateKeyUpdateConfig<T extends AnySingleStoreInsert> = {\n\tset: SingleStoreUpdateSetSource<T['_']['table']>;\n};\n\nexport type SingleStoreInsert<\n\tTTable extends SingleStoreTable = SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT = AnySingleStoreQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase = PreparedQueryHKTBase,\n\tTReturning extends Record<string, unknown> | undefined = Record<string, unknown> | undefined,\n> = SingleStoreInsertBase<TTable, TQueryResult, TPreparedQueryHKT, TReturning, true, never>;\n\nexport type SingleStoreInsertReturning<\n\tT extends AnySingleStoreInsert,\n\tTDynamic extends boolean,\n> = SingleStoreInsertBase<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['preparedQueryHKT'],\n\tInferModelFromColumns<GetPrimarySerialOrDefaultKeys<T['_']['table']['_']['columns']>>,\n\tTDynamic,\n\tT['_']['excludedMethods'] | '$returning'\n>;\n\nexport type AnySingleStoreInsert = SingleStoreInsertBase<any, any, any, any, any, any>;\n\nexport interface SingleStoreInsertBase<\n\tTTable extends SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n> extends\n\tQueryPromise<TReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[]>,\n\tRunnableQuery<\n\t\tTReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[],\n\t\t'singlestore'\n\t>,\n\tSQLWrapper\n{\n\treadonly _: {\n\t\treadonly dialect: 'singlestore';\n\t\treadonly table: TTable;\n\t\treadonly queryResult: TQueryResult;\n\t\treadonly preparedQueryHKT: TPreparedQueryHKT;\n\t\treadonly dynamic: TDynamic;\n\t\treadonly excludedMethods: TExcludedMethods;\n\t\treadonly returning: TReturning;\n\t\treadonly result: TReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[];\n\t};\n}\n\nexport type PrimaryKeyKeys<T extends Record<string, AnySingleStoreColumn>> = {\n\t[K in keyof T]: T[K]['_']['isPrimaryKey'] extends true ? T[K]['_']['isAutoincrement'] extends true ? K\n\t\t: T[K]['_']['hasRuntimeDefault'] extends true ? T[K]['_']['isPrimaryKey'] extends true ? K : never\n\t\t: never\n\t\t: T[K]['_']['hasRuntimeDefault'] extends true ? T[K]['_']['isPrimaryKey'] extends true ? K : never\n\t\t: never;\n}[keyof T];\n\nexport type GetPrimarySerialOrDefaultKeys<T extends Record<string, AnySingleStoreColumn>> = {\n\t[K in PrimaryKeyKeys<T>]: T[K];\n};\n\nexport class SingleStoreInsertBase<\n\tTTable extends SingleStoreTable,\n\tTQueryResult extends SingleStoreQueryResultHKT,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTDynamic extends boolean = false,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTExcludedMethods extends string = never,\n> extends QueryPromise<TReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[]>\n\timplements\n\t\tRunnableQuery<\n\t\t\tTReturning extends undefined ? SingleStoreQueryResultKind<TQueryResult, never> : TReturning[],\n\t\t\t'singlestore'\n\t\t>,\n\t\tSQLWrapper\n{\n\tstatic override readonly [entityKind]: string = 'SingleStoreInsert';\n\n\tdeclare protected $table: TTable;\n\n\tprivate config: SingleStoreInsertConfig<TTable>;\n\n\tconstructor(\n\t\ttable: TTable,\n\t\tvalues: SingleStoreInsertConfig['values'],\n\t\tignore: boolean,\n\t\tprivate session: SingleStoreSession,\n\t\tprivate dialect: SingleStoreDialect,\n\t) {\n\t\tsuper();\n\t\tthis.config = { table, values, ignore };\n\t}\n\n\t/**\n\t * Adds an `on duplicate key update` clause to the query.\n\t *\n\t * Calling this method will update update the row if any unique index conflicts. MySQL will automatically determine the conflict target based on the primary key and unique indexes.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/insert#on-duplicate-key-update}\n\t *\n\t * @param config The `set` clause\n\t *\n\t * @example\n\t * ```ts\n\t * await db.insert(cars)\n\t * .values({ id: 1, brand: 'BMW'})\n\t * .onDuplicateKeyUpdate({ set: { brand: 'Porsche' }});\n\t * ```\n\t *\n\t * While MySQL does not directly support doing nothing on conflict, you can perform a no-op by setting any column's value to itself and achieve the same effect:\n\t *\n\t * ```ts\n\t * import { sql } from 'drizzle-orm';\n\t *\n\t * await db.insert(cars)\n\t * .values({ id: 1, brand: 'BMW' })\n\t * .onDuplicateKeyUpdate({ set: { id: sql`id` } });\n\t * ```\n\t */\n\tonDuplicateKeyUpdate(\n\t\tconfig: SingleStoreInsertOnDuplicateKeyUpdateConfig<this>,\n\t): SingleStoreInsertWithout<this, TDynamic, 'onDuplicateKeyUpdate'> {\n\t\tconst setSql = this.dialect.buildUpdateSet(this.config.table, mapUpdateSet(this.config.table, config.set));\n\t\tthis.config.onConflict = sql`update ${setSql}`;\n\t\treturn this as any;\n\t}\n\n\t$returningId(): SingleStoreInsertWithout<\n\t\tSingleStoreInsertReturning<this, TDynamic>,\n\t\tTDynamic,\n\t\t'$returningId'\n\t> {\n\t\tconst returning: SelectedFieldsOrdered = [];\n\t\tfor (const [key, value] of Object.entries(this.config.table[Table.Symbol.Columns])) {\n\t\t\tif (value.primary) {\n\t\t\t\treturning.push({ field: value, path: [key] });\n\t\t\t}\n\t\t}\n\t\tthis.config.returning = orderSelectedFields<SingleStoreColumn>(this.config.table[Table.Symbol.Columns]);\n\t\treturn this as any;\n\t}\n\n\t/** @internal */\n\tgetSQL(): SQL {\n\t\treturn this.dialect.buildInsertQuery(this.config).sql;\n\t}\n\n\ttoSQL(): Query {\n\t\tconst { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n\t\treturn rest;\n\t}\n\n\tprepare(): SingleStoreInsertPrepare<this, TReturning> {\n\t\tconst { sql, generatedIds } = this.dialect.buildInsertQuery(this.config);\n\t\treturn this.session.prepareQuery(\n\t\t\tthis.dialect.sqlToQuery(sql),\n\t\t\tundefined,\n\t\t\tundefined,\n\t\t\tgeneratedIds,\n\t\t\tthis.config.returning,\n\t\t\t{\n\t\t\t\ttype: 'delete',\n\t\t\t\ttables: extractUsedTable(this.config.table),\n\t\t\t},\n\t\t) as SingleStoreInsertPrepare<this, TReturning>;\n\t}\n\n\toverride execute: ReturnType<this['prepare']>['execute'] = (placeholderValues) => {\n\t\treturn this.prepare().execute(placeholderValues);\n\t};\n\n\tprivate createIterator = (): ReturnType<this['prepare']>['iterator'] => {\n\t\tconst self = this;\n\t\treturn async function*(placeholderValues) {\n\t\t\tyield* self.prepare().iterator(placeholderValues);\n\t\t};\n\t};\n\n\titerator = this.createIterator();\n\n\t$dynamic(): SingleStoreInsertDynamic<this> {\n\t\treturn this as any;\n\t}\n}\n"],"mappings":"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","names":["sql"]}
@@ -720,9 +720,9 @@ class SingleStoreSelectBase extends SingleStoreSelectQueryBuilderBase {
720
720
  this.cacheConfig = config === void 0 ? { config: {}, enable: true, autoInvalidate: true } : config === false ? { enable: false } : { enable: true, autoInvalidate: true, ...config };
721
721
  return this;
722
722
  }
723
- execute = ((placeholderValues) => {
723
+ execute = (placeholderValues) => {
724
724
  return this.prepare().execute(placeholderValues);
725
- });
725
+ };
726
726
  createIterator = () => {
727
727
  const self = this;
728
728
  return async function* (placeholderValues) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/singlestore-core/query-builders/select.ts"],"sourcesContent":["import type { CacheConfig, WithCacheConfig } from '~/cache/core/types.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport type {\n\tBuildSubquerySelection,\n\tGetSelectTableName,\n\tGetSelectTableSelection,\n\tJoinNullability,\n\tJoinType,\n\tSelectMode,\n\tSelectResult,\n\tSetOperator,\n} from '~/query-builders/select.types.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport type { SingleStoreColumn } from '~/singlestore-core/columns/index.ts';\nimport type { SingleStoreDialect } from '~/singlestore-core/dialect.ts';\nimport type {\n\tPreparedQueryHKTBase,\n\tSingleStorePreparedQueryConfig,\n\tSingleStoreSession,\n} from '~/singlestore-core/session.ts';\nimport type { SubqueryWithSelection } from '~/singlestore-core/subquery.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport type { ColumnsSelection, Query } from '~/sql/sql.ts';\nimport { SQL } from '~/sql/sql.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { Table } from '~/table.ts';\nimport {\n\tapplyMixins,\n\tgetTableColumns,\n\tgetTableLikeName,\n\thaveSameKeys,\n\torderSelectedFields,\n\ttype ValueOrArray,\n} from '~/utils.ts';\nimport { extractUsedTable } from '../utils.ts';\nimport type {\n\tAnySingleStoreSelect,\n\tCreateSingleStoreSelectFromBuilderMode,\n\tGetSingleStoreSetOperators,\n\tLockConfig,\n\tLockStrength,\n\tSelectedFields,\n\tSetOperatorRightSelect,\n\tSingleStoreCreateSetOperatorFn,\n\tSingleStoreCrossJoinFn,\n\tSingleStoreJoinFn,\n\tSingleStoreSelectConfig,\n\tSingleStoreSelectDynamic,\n\tSingleStoreSelectHKT,\n\tSingleStoreSelectHKTBase,\n\tSingleStoreSelectPrepare,\n\tSingleStoreSelectWithout,\n\tSingleStoreSetOperatorExcludedMethods,\n\tSingleStoreSetOperatorWithResult,\n} from './select.types.ts';\n\nexport class SingleStoreSelectBuilder<\n\tTSelection extends SelectedFields | undefined,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\tTBuilderMode extends 'db' | 'qb' = 'db',\n> {\n\tstatic readonly [entityKind]: string = 'SingleStoreSelectBuilder';\n\n\tprivate fields: TSelection;\n\tprivate session: SingleStoreSession | undefined;\n\tprivate dialect: SingleStoreDialect;\n\tprivate withList: Subquery[] = [];\n\tprivate distinct: boolean | undefined;\n\n\tconstructor(\n\t\tconfig: {\n\t\t\tfields: TSelection;\n\t\t\tsession: SingleStoreSession | undefined;\n\t\t\tdialect: SingleStoreDialect;\n\t\t\twithList?: Subquery[];\n\t\t\tdistinct?: boolean;\n\t\t},\n\t) {\n\t\tthis.fields = config.fields;\n\t\tthis.session = config.session;\n\t\tthis.dialect = config.dialect;\n\t\tif (config.withList) {\n\t\t\tthis.withList = config.withList;\n\t\t}\n\t\tthis.distinct = config.distinct;\n\t}\n\n\tfrom<TFrom extends SingleStoreTable | Subquery | SQL>( // | SingleStoreViewBase\n\t\tsource: TFrom,\n\t): CreateSingleStoreSelectFromBuilderMode<\n\t\tTBuilderMode,\n\t\tGetSelectTableName<TFrom>,\n\t\tTSelection extends undefined ? GetSelectTableSelection<TFrom> : TSelection,\n\t\tTSelection extends undefined ? 'single' : 'partial',\n\t\tTPreparedQueryHKT\n\t> {\n\t\tconst isPartialSelect = !!this.fields;\n\n\t\tlet fields: SelectedFields;\n\t\tif (this.fields) {\n\t\t\tfields = this.fields;\n\t\t} else if (is(source, Subquery)) {\n\t\t\t// This is required to use the proxy handler to get the correct field values from the subquery\n\t\t\tfields = Object.fromEntries(\n\t\t\t\tObject.keys(source._.selectedFields).map((\n\t\t\t\t\tkey,\n\t\t\t\t) => [key, source[key as unknown as keyof typeof source] as unknown as SelectedFields[string]]),\n\t\t\t);\n\t\t\t/* } else if (is(source, SingleStoreViewBase)) {\n\t\t\tfields = source[ViewBaseConfig].selectedFields as SelectedFields; */\n\t\t} else if (is(source, SQL)) {\n\t\t\tfields = {};\n\t\t} else {\n\t\t\tfields = getTableColumns<SingleStoreTable>(source);\n\t\t}\n\n\t\treturn new SingleStoreSelectBase(\n\t\t\t{\n\t\t\t\ttable: source,\n\t\t\t\tfields,\n\t\t\t\tisPartialSelect,\n\t\t\t\tsession: this.session,\n\t\t\t\tdialect: this.dialect,\n\t\t\t\twithList: this.withList,\n\t\t\t\tdistinct: this.distinct,\n\t\t\t},\n\t\t) as any;\n\t}\n}\n\nexport abstract class SingleStoreSelectQueryBuilderBase<\n\tTHKT extends SingleStoreSelectHKTBase,\n\tTTableName extends string | undefined,\n\tTSelection extends ColumnsSelection,\n\tTSelectMode extends SelectMode,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\tTNullabilityMap extends Record<string, JoinNullability> = TTableName extends string ? Record<TTableName, 'not-null'>\n\t\t: {},\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n\tTResult extends any[] = SelectResult<TSelection, TSelectMode, TNullabilityMap>[],\n\tTSelectedFields extends ColumnsSelection = BuildSubquerySelection<TSelection, TNullabilityMap>,\n> extends TypedQueryBuilder<TSelectedFields, TResult> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreSelectQueryBuilder';\n\n\toverride readonly _: {\n\t\treadonly hkt: THKT;\n\t\treadonly tableName: TTableName;\n\t\treadonly selection: TSelection;\n\t\treadonly selectMode: TSelectMode;\n\t\treadonly preparedQueryHKT: TPreparedQueryHKT;\n\t\treadonly nullabilityMap: TNullabilityMap;\n\t\treadonly dynamic: TDynamic;\n\t\treadonly excludedMethods: TExcludedMethods;\n\t\treadonly result: TResult;\n\t\treadonly selectedFields: TSelectedFields;\n\t\treadonly config: SingleStoreSelectConfig;\n\t};\n\n\tprotected config: SingleStoreSelectConfig;\n\tprotected joinsNotNullableMap: Record<string, boolean>;\n\tprivate tableName: string | undefined;\n\tprivate isPartialSelect: boolean;\n\t/** @internal */\n\treadonly session: SingleStoreSession | undefined;\n\tprotected dialect: SingleStoreDialect;\n\tprotected cacheConfig?: WithCacheConfig = undefined;\n\tprotected usedTables: Set<string> = new Set();\n\n\tconstructor(\n\t\t{ table, fields, isPartialSelect, session, dialect, withList, distinct }: {\n\t\t\ttable: SingleStoreSelectConfig['table'];\n\t\t\tfields: SingleStoreSelectConfig['fields'];\n\t\t\tisPartialSelect: boolean;\n\t\t\tsession: SingleStoreSession | undefined;\n\t\t\tdialect: SingleStoreDialect;\n\t\t\twithList: Subquery[];\n\t\t\tdistinct: boolean | undefined;\n\t\t},\n\t) {\n\t\tsuper();\n\t\tthis.config = {\n\t\t\twithList,\n\t\t\ttable,\n\t\t\tfields: { ...fields },\n\t\t\tdistinct,\n\t\t\tsetOperators: [],\n\t\t};\n\t\tthis.isPartialSelect = isPartialSelect;\n\t\tthis.session = session;\n\t\tthis.dialect = dialect;\n\t\tthis._ = {\n\t\t\tselectedFields: fields as TSelectedFields,\n\t\t\tconfig: this.config,\n\t\t} as this['_'];\n\t\tthis.tableName = getTableLikeName(table);\n\t\tthis.joinsNotNullableMap = typeof this.tableName === 'string' ? { [this.tableName]: true } : {};\n\t\tfor (const item of extractUsedTable(table)) this.usedTables.add(item);\n\t}\n\n\t/** @internal */\n\tgetUsedTables() {\n\t\treturn [...this.usedTables];\n\t}\n\n\tprivate createJoin<\n\t\tTJoinType extends JoinType,\n\t\tTIsLateral extends (TJoinType extends 'full' | 'right' ? false : boolean),\n\t>(\n\t\tjoinType: TJoinType,\n\t\tlateral: TIsLateral,\n\t): 'cross' extends TJoinType ? SingleStoreCrossJoinFn<this, TDynamic, TIsLateral>\n\t\t: SingleStoreJoinFn<this, TDynamic, TJoinType, TIsLateral>\n\t{\n\t\treturn (\n\t\t\ttable: SingleStoreTable | Subquery | SQL, // | SingleStoreViewBase\n\t\t\ton?: ((aliases: TSelection) => SQL | undefined) | SQL | undefined,\n\t\t) => {\n\t\t\tconst baseTableName = this.tableName;\n\t\t\tconst tableName = getTableLikeName(table);\n\n\t\t\t// store all tables used in a query\n\t\t\tfor (const item of extractUsedTable(table)) this.usedTables.add(item);\n\n\t\t\tif (typeof tableName === 'string' && this.config.joins?.some((join) => join.alias === tableName)) {\n\t\t\t\tthrow new Error(`Alias \"${tableName}\" is already used in this query`);\n\t\t\t}\n\n\t\t\tif (!this.isPartialSelect) {\n\t\t\t\t// If this is the first join and this is not a partial select and we're not selecting from raw SQL, \"move\" the fields from the main table to the nested object\n\t\t\t\tif (Object.keys(this.joinsNotNullableMap).length === 1 && typeof baseTableName === 'string') {\n\t\t\t\t\tthis.config.fields = {\n\t\t\t\t\t\t[baseTableName]: this.config.fields,\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\tif (typeof tableName === 'string' && !is(table, SQL)) {\n\t\t\t\t\tconst selection = is(table, Subquery)\n\t\t\t\t\t\t? table._.selectedFields\n\t\t\t\t\t\t/* : is(table, View)\n\t\t\t\t\t\t? table[ViewBaseConfig].selectedFields */\n\t\t\t\t\t\t: table[Table.Symbol.Columns];\n\t\t\t\t\tthis.config.fields[tableName] = selection;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (typeof on === 'function') {\n\t\t\t\ton = on(\n\t\t\t\t\tnew Proxy(\n\t\t\t\t\t\tthis.config.fields,\n\t\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t\t) as TSelection,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tif (!this.config.joins) {\n\t\t\t\tthis.config.joins = [];\n\t\t\t}\n\n\t\t\tthis.config.joins.push({ on, table, joinType, alias: tableName, lateral });\n\n\t\t\tif (typeof tableName === 'string') {\n\t\t\t\tswitch (joinType) {\n\t\t\t\t\tcase 'left': {\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = false;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'right': {\n\t\t\t\t\t\tthis.joinsNotNullableMap = Object.fromEntries(\n\t\t\t\t\t\t\tObject.entries(this.joinsNotNullableMap).map(([key]) => [key, false]),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'cross':\n\t\t\t\t\tcase 'inner': {\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'full': {\n\t\t\t\t\t\tthis.joinsNotNullableMap = Object.fromEntries(\n\t\t\t\t\t\t\tObject.entries(this.joinsNotNullableMap).map(([key]) => [key, false]),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = false;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn this as any;\n\t\t};\n\t}\n\n\t/**\n\t * Executes a `left join` operation by adding another table to the current query.\n\t *\n\t * Calling this method associates each row of the table with the corresponding row from the joined table, if a match is found. If no matching row exists, it sets all columns of the joined table to null.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#left-join}\n\t *\n\t * @param table the table to join.\n\t * @param on the `on` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all users and their pets\n\t * const usersWithPets: { user: User; pets: Pet | null; }[] = await db.select()\n\t * .from(users)\n\t * .leftJoin(pets, eq(users.id, pets.ownerId))\n\t *\n\t * // Select userId and petId\n\t * const usersIdsAndPetIds: { userId: number; petId: number | null; }[] = await db.select({\n\t * userId: users.id,\n\t * petId: pets.id,\n\t * })\n\t * .from(users)\n\t * .leftJoin(pets, eq(users.id, pets.ownerId))\n\t * ```\n\t */\n\tleftJoin = this.createJoin('left', false);\n\n\t/**\n\t * Executes a `left join lateral` operation by adding subquery to the current query.\n\t *\n\t * A `lateral` join allows the right-hand expression to refer to columns from the left-hand side.\n\t *\n\t * Calling this method associates each row of the table with the corresponding row from the joined table, if a match is found. If no matching row exists, it sets all columns of the joined table to null.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#left-join-lateral}\n\t *\n\t * @param table the subquery to join.\n\t * @param on the `on` clause.\n\t */\n\tleftJoinLateral = this.createJoin('left', true);\n\n\t/**\n\t * Executes a `right join` operation by adding another table to the current query.\n\t *\n\t * Calling this method associates each row of the joined table with the corresponding row from the main table, if a match is found. If no matching row exists, it sets all columns of the main table to null.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#right-join}\n\t *\n\t * @param table the table to join.\n\t * @param on the `on` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all users and their pets\n\t * const usersWithPets: { user: User | null; pets: Pet; }[] = await db.select()\n\t * .from(users)\n\t * .rightJoin(pets, eq(users.id, pets.ownerId))\n\t *\n\t * // Select userId and petId\n\t * const usersIdsAndPetIds: { userId: number | null; petId: number; }[] = await db.select({\n\t * userId: users.id,\n\t * petId: pets.id,\n\t * })\n\t * .from(users)\n\t * .rightJoin(pets, eq(users.id, pets.ownerId))\n\t * ```\n\t */\n\trightJoin = this.createJoin('right', false);\n\n\t/**\n\t * Executes an `inner join` operation, creating a new table by combining rows from two tables that have matching values.\n\t *\n\t * Calling this method retrieves rows that have corresponding entries in both joined tables. Rows without matching entries in either table are excluded, resulting in a table that includes only matching pairs.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join}\n\t *\n\t * @param table the table to join.\n\t * @param on the `on` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all users and their pets\n\t * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()\n\t * .from(users)\n\t * .innerJoin(pets, eq(users.id, pets.ownerId))\n\t *\n\t * // Select userId and petId\n\t * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({\n\t * userId: users.id,\n\t * petId: pets.id,\n\t * })\n\t * .from(users)\n\t * .innerJoin(pets, eq(users.id, pets.ownerId))\n\t * ```\n\t */\n\tinnerJoin = this.createJoin('inner', false);\n\n\t/**\n\t * Executes an `inner join lateral` operation, creating a new table by combining rows from two queries that have matching values.\n\t *\n\t * A `lateral` join allows the right-hand expression to refer to columns from the left-hand side.\n\t *\n\t * Calling this method retrieves rows that have corresponding entries in both joined tables. Rows without matching entries in either table are excluded, resulting in a table that includes only matching pairs.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join-lateral}\n\t *\n\t * @param table the subquery to join.\n\t * @param on the `on` clause.\n\t */\n\tinnerJoinLateral = this.createJoin('inner', true);\n\n\t/**\n\t * Executes a `full join` operation by combining rows from two tables into a new table.\n\t *\n\t * Calling this method retrieves all rows from both main and joined tables, merging rows with matching values and filling in `null` for non-matching columns.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#full-join}\n\t *\n\t * @param table the table to join.\n\t * @param on the `on` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all users and their pets\n\t * const usersWithPets: { user: User | null; pets: Pet | null; }[] = await db.select()\n\t * .from(users)\n\t * .fullJoin(pets, eq(users.id, pets.ownerId))\n\t *\n\t * // Select userId and petId\n\t * const usersIdsAndPetIds: { userId: number | null; petId: number | null; }[] = await db.select({\n\t * userId: users.id,\n\t * petId: pets.id,\n\t * })\n\t * .from(users)\n\t * .fullJoin(pets, eq(users.id, pets.ownerId))\n\t * ```\n\t */\n\tfullJoin = this.createJoin('full', false);\n\n\t/**\n\t * Executes a `cross join` operation by combining rows from two tables into a new table.\n\t *\n\t * Calling this method retrieves all rows from both main and joined tables, merging all rows from each table.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#cross-join}\n\t *\n\t * @param table the table to join.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all users, each user with every pet\n\t * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()\n\t * .from(users)\n\t * .crossJoin(pets)\n\t *\n\t * // Select userId and petId\n\t * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({\n\t * userId: users.id,\n\t * petId: pets.id,\n\t * })\n\t * .from(users)\n\t * .crossJoin(pets)\n\t * ```\n\t */\n\tcrossJoin = this.createJoin('cross', false);\n\n\t/**\n\t * Executes a `cross join lateral` operation by combining rows from two queries into a new table.\n\t *\n\t * A `lateral` join allows the right-hand expression to refer to columns from the left-hand side.\n\t *\n\t * Calling this method retrieves all rows from both main and joined queries, merging all rows from each query.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#cross-join-lateral}\n\t *\n\t * @param table the query to join.\n\t */\n\tcrossJoinLateral = this.createJoin('cross', true);\n\n\tprivate createSetOperator(\n\t\ttype: SetOperator,\n\t\tisAll: boolean,\n\t): <TValue extends SingleStoreSetOperatorWithResult<TResult>>(\n\t\trightSelection:\n\t\t\t| ((setOperators: GetSingleStoreSetOperators) => SetOperatorRightSelect<TValue, TResult>)\n\t\t\t| SetOperatorRightSelect<TValue, TResult>,\n\t) => SingleStoreSelectWithout<\n\t\tthis,\n\t\tTDynamic,\n\t\tSingleStoreSetOperatorExcludedMethods,\n\t\ttrue\n\t> {\n\t\treturn (rightSelection) => {\n\t\t\tconst rightSelect = (typeof rightSelection === 'function'\n\t\t\t\t? rightSelection(getSingleStoreSetOperators())\n\t\t\t\t: rightSelection) as TypedQueryBuilder<\n\t\t\t\t\tany,\n\t\t\t\t\tTResult\n\t\t\t\t>;\n\n\t\t\tif (!haveSameKeys(this.getSelectedFields(), rightSelect.getSelectedFields())) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t'Set operator error (union / intersect / except): selected fields are not the same or are in a different order',\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tthis.config.setOperators.push({ type, isAll, rightSelect });\n\t\t\treturn this as any;\n\t\t};\n\t}\n\n\t/**\n\t * Adds `union` set operator to the query.\n\t *\n\t * Calling this method will combine the result sets of the `select` statements and remove any duplicate rows that appear across them.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/set-operations#union}\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all unique names from customers and users tables\n\t * await db.select({ name: users.name })\n\t * .from(users)\n\t * .union(\n\t * db.select({ name: customers.name }).from(customers)\n\t * );\n\t * // or\n\t * import { union } from 'drizzle-orm/singlestore-core'\n\t *\n\t * await union(\n\t * db.select({ name: users.name }).from(users),\n\t * db.select({ name: customers.name }).from(customers)\n\t * );\n\t * ```\n\t */\n\tunion = this.createSetOperator('union', false);\n\n\t/**\n\t * Adds `union all` set operator to the query.\n\t *\n\t * Calling this method will combine the result-set of the `select` statements and keep all duplicate rows that appear across them.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/set-operations#union-all}\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all transaction ids from both online and in-store sales\n\t * await db.select({ transaction: onlineSales.transactionId })\n\t * .from(onlineSales)\n\t * .unionAll(\n\t * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n\t * );\n\t * // or\n\t * import { unionAll } from 'drizzle-orm/singlestore-core'\n\t *\n\t * await unionAll(\n\t * db.select({ transaction: onlineSales.transactionId }).from(onlineSales),\n\t * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n\t * );\n\t * ```\n\t */\n\tunionAll = this.createSetOperator('union', true);\n\n\t/**\n\t * Adds `intersect` set operator to the query.\n\t *\n\t * Calling this method will retain only the rows that are present in both result sets and eliminate duplicates.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect}\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select course names that are offered in both departments A and B\n\t * await db.select({ courseName: depA.courseName })\n\t * .from(depA)\n\t * .intersect(\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * // or\n\t * import { intersect } from 'drizzle-orm/singlestore-core'\n\t *\n\t * await intersect(\n\t * db.select({ courseName: depA.courseName }).from(depA),\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * ```\n\t */\n\tintersect = this.createSetOperator('intersect', false);\n\n\t/**\n\t * Adds `except` set operator to the query.\n\t *\n\t * Calling this method will retrieve all unique rows from the left query, except for the rows that are present in the result set of the right query.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/set-operations#except}\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all courses offered in department A but not in department B\n\t * await db.select({ courseName: depA.courseName })\n\t * .from(depA)\n\t * .except(\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * // or\n\t * import { except } from 'drizzle-orm/singlestore-core'\n\t *\n\t * await except(\n\t * db.select({ courseName: depA.courseName }).from(depA),\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * ```\n\t */\n\texcept = this.createSetOperator('except', false);\n\n\t/**\n\t * Adds `minus` set operator to the query.\n\t *\n\t * This is an alias of `except` supported by SingleStore.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all courses offered in department A but not in department B\n\t * await db.select({ courseName: depA.courseName })\n\t * .from(depA)\n\t * .minus(\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * // or\n\t * import { minus } from 'drizzle-orm/singlestore-core'\n\t *\n\t * await minus(\n\t * db.select({ courseName: depA.courseName }).from(depA),\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * ```\n\t */\n\tminus = this.createSetOperator('except', false);\n\n\t/** @internal */\n\taddSetOperators(setOperators: SingleStoreSelectConfig['setOperators']): SingleStoreSelectWithout<\n\t\tthis,\n\t\tTDynamic,\n\t\tSingleStoreSetOperatorExcludedMethods,\n\t\ttrue\n\t> {\n\t\tthis.config.setOperators.push(...setOperators);\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `where` clause to the query.\n\t *\n\t * Calling this method will select only those rows that fulfill a specified condition.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#filtering}\n\t *\n\t * @param where the `where` clause.\n\t *\n\t * @example\n\t * You can use conditional operators and `sql function` to filter the rows to be selected.\n\t *\n\t * ```ts\n\t * // Select all cars with green color\n\t * await db.select().from(cars).where(eq(cars.color, 'green'));\n\t * // or\n\t * await db.select().from(cars).where(sql`${cars.color} = 'green'`)\n\t * ```\n\t *\n\t * You can logically combine conditional operators with `and()` and `or()` operators:\n\t *\n\t * ```ts\n\t * // Select all BMW cars with a green color\n\t * await db.select().from(cars).where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n\t *\n\t * // Select all cars with the green or blue color\n\t * await db.select().from(cars).where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n\t * ```\n\t */\n\twhere(\n\t\twhere: ((aliases: this['_']['selection']) => SQL | undefined) | SQL | undefined,\n\t): SingleStoreSelectWithout<this, TDynamic, 'where'> {\n\t\tif (typeof where === 'function') {\n\t\t\twhere = where(\n\t\t\t\tnew Proxy(\n\t\t\t\t\tthis.config.fields,\n\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t) as TSelection,\n\t\t\t);\n\t\t}\n\t\tthis.config.where = where;\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `having` clause to the query.\n\t *\n\t * Calling this method will select only those rows that fulfill a specified condition. It is typically used with aggregate functions to filter the aggregated data based on a specified condition.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#aggregations}\n\t *\n\t * @param having the `having` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all brands with more than one car\n\t * await db.select({\n\t * \tbrand: cars.brand,\n\t * \tcount: sql<number>`cast(count(${cars.id}) as int)`,\n\t * })\n\t * .from(cars)\n\t * .groupBy(cars.brand)\n\t * .having(({ count }) => gt(count, 1));\n\t * ```\n\t */\n\thaving(\n\t\thaving: ((aliases: this['_']['selection']) => SQL | undefined) | SQL | undefined,\n\t): SingleStoreSelectWithout<this, TDynamic, 'having'> {\n\t\tif (typeof having === 'function') {\n\t\t\thaving = having(\n\t\t\t\tnew Proxy(\n\t\t\t\t\tthis.config.fields,\n\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t) as TSelection,\n\t\t\t);\n\t\t}\n\t\tthis.config.having = having;\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `group by` clause to the query.\n\t *\n\t * Calling this method will group rows that have the same values into summary rows, often used for aggregation purposes.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#aggregations}\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Group and count people by their last names\n\t * await db.select({\n\t * lastName: people.lastName,\n\t * count: sql<number>`cast(count(*) as int)`\n\t * })\n\t * .from(people)\n\t * .groupBy(people.lastName);\n\t * ```\n\t */\n\tgroupBy(\n\t\tbuilder: (aliases: this['_']['selection']) => ValueOrArray<SingleStoreColumn | SQL | SQL.Aliased>,\n\t): SingleStoreSelectWithout<this, TDynamic, 'groupBy'>;\n\tgroupBy(...columns: (SingleStoreColumn | SQL | SQL.Aliased)[]): SingleStoreSelectWithout<this, TDynamic, 'groupBy'>;\n\tgroupBy(\n\t\t...columns:\n\t\t\t| [(aliases: this['_']['selection']) => ValueOrArray<SingleStoreColumn | SQL | SQL.Aliased>]\n\t\t\t| (SingleStoreColumn | SQL | SQL.Aliased)[]\n\t): SingleStoreSelectWithout<this, TDynamic, 'groupBy'> {\n\t\tif (typeof columns[0] === 'function') {\n\t\t\tconst groupBy = columns[0](\n\t\t\t\tnew Proxy(\n\t\t\t\t\tthis.config.fields,\n\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'alias', sqlBehavior: 'sql' }),\n\t\t\t\t) as TSelection,\n\t\t\t);\n\t\t\tthis.config.groupBy = Array.isArray(groupBy) ? groupBy : [groupBy];\n\t\t} else {\n\t\t\tthis.config.groupBy = columns as (SingleStoreColumn | SQL | SQL.Aliased)[];\n\t\t}\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds an `order by` clause to the query.\n\t *\n\t * Calling this method will sort the result-set in ascending or descending order. By default, the sort order is ascending.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#order-by}\n\t *\n\t * @example\n\t *\n\t * ```\n\t * // Select cars ordered by year\n\t * await db.select().from(cars).orderBy(cars.year);\n\t * ```\n\t *\n\t * You can specify whether results are in ascending or descending order with the `asc()` and `desc()` operators.\n\t *\n\t * ```ts\n\t * // Select cars ordered by year in descending order\n\t * await db.select().from(cars).orderBy(desc(cars.year));\n\t *\n\t * // Select cars ordered by year and price\n\t * await db.select().from(cars).orderBy(asc(cars.year), desc(cars.price));\n\t * ```\n\t */\n\torderBy(\n\t\tbuilder: (aliases: this['_']['selection']) => ValueOrArray<SingleStoreColumn | SQL | SQL.Aliased>,\n\t): SingleStoreSelectWithout<this, TDynamic, 'orderBy'>;\n\torderBy(...columns: (SingleStoreColumn | SQL | SQL.Aliased)[]): SingleStoreSelectWithout<this, TDynamic, 'orderBy'>;\n\torderBy(\n\t\t...columns:\n\t\t\t| [(aliases: this['_']['selection']) => ValueOrArray<SingleStoreColumn | SQL | SQL.Aliased>]\n\t\t\t| (SingleStoreColumn | SQL | SQL.Aliased)[]\n\t): SingleStoreSelectWithout<this, TDynamic, 'orderBy'> {\n\t\tif (typeof columns[0] === 'function') {\n\t\t\tconst orderBy = columns[0](\n\t\t\t\tnew Proxy(\n\t\t\t\t\tthis.config.fields,\n\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'alias', sqlBehavior: 'sql' }),\n\t\t\t\t) as TSelection,\n\t\t\t);\n\n\t\t\tconst orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];\n\n\t\t\tif (this.config.setOperators.length > 0) {\n\t\t\t\tthis.config.setOperators.at(-1)!.orderBy = orderByArray;\n\t\t\t} else {\n\t\t\t\tthis.config.orderBy = orderByArray;\n\t\t\t}\n\t\t} else {\n\t\t\tconst orderByArray = columns as (SingleStoreColumn | SQL | SQL.Aliased)[];\n\n\t\t\tif (this.config.setOperators.length > 0) {\n\t\t\t\tthis.config.setOperators.at(-1)!.orderBy = orderByArray;\n\t\t\t} else {\n\t\t\t\tthis.config.orderBy = orderByArray;\n\t\t\t}\n\t\t}\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `limit` clause to the query.\n\t *\n\t * Calling this method will set the maximum number of rows that will be returned by this query.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}\n\t *\n\t * @param limit the `limit` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Get the first 10 people from this query.\n\t * await db.select().from(people).limit(10);\n\t * ```\n\t */\n\tlimit(limit: number): SingleStoreSelectWithout<this, TDynamic, 'limit'> {\n\t\tif (this.config.setOperators.length > 0) {\n\t\t\tthis.config.setOperators.at(-1)!.limit = limit;\n\t\t} else {\n\t\t\tthis.config.limit = limit;\n\t\t}\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds an `offset` clause to the query.\n\t *\n\t * Calling this method will skip a number of rows when returning results from this query.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}\n\t *\n\t * @param offset the `offset` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Get the 10th-20th people from this query.\n\t * await db.select().from(people).offset(10).limit(10);\n\t * ```\n\t */\n\toffset(offset: number): SingleStoreSelectWithout<this, TDynamic, 'offset'> {\n\t\tif (this.config.setOperators.length > 0) {\n\t\t\tthis.config.setOperators.at(-1)!.offset = offset;\n\t\t} else {\n\t\t\tthis.config.offset = offset;\n\t\t}\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `for` clause to the query.\n\t *\n\t * Calling this method will specify a lock strength for this query that controls how strictly it acquires exclusive access to the rows being queried.\n\t *\n\t * @param strength the lock strength.\n\t * @param config the lock configuration.\n\t */\n\tfor(strength: LockStrength, config: LockConfig = {}): SingleStoreSelectWithout<this, TDynamic, 'for'> {\n\t\tthis.config.lockingClause = { strength, config };\n\t\treturn this as any;\n\t}\n\n\t/** @internal */\n\tgetSQL(): SQL {\n\t\treturn this.dialect.buildSelectQuery(this.config);\n\t}\n\n\ttoSQL(): Query {\n\t\tconst { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n\t\treturn rest;\n\t}\n\n\tas<TAlias extends string>(\n\t\talias: TAlias,\n\t): SubqueryWithSelection<this['_']['selectedFields'], TAlias> {\n\t\tconst usedTables: string[] = [];\n\t\tusedTables.push(...extractUsedTable(this.config.table));\n\t\tif (this.config.joins) { for (const it of this.config.joins) usedTables.push(...extractUsedTable(it.table)); }\n\n\t\treturn new Proxy(\n\t\t\tnew Subquery(this.getSQL(), this.config.fields, alias, false, [...new Set(usedTables)]),\n\t\t\tnew SelectionProxyHandler({ alias, sqlAliasedBehavior: 'alias', sqlBehavior: 'error' }),\n\t\t) as SubqueryWithSelection<this['_']['selectedFields'], TAlias>;\n\t}\n\n\t/** @internal */\n\toverride getSelectedFields(): this['_']['selectedFields'] {\n\t\treturn new Proxy(\n\t\t\tthis.config.fields,\n\t\t\tnew SelectionProxyHandler({ alias: this.tableName, sqlAliasedBehavior: 'alias', sqlBehavior: 'error' }),\n\t\t) as this['_']['selectedFields'];\n\t}\n\n\t$dynamic(): SingleStoreSelectDynamic<this> {\n\t\treturn this as any;\n\t}\n}\n\nexport interface SingleStoreSelectBase<\n\tTTableName extends string | undefined,\n\tTSelection extends ColumnsSelection,\n\tTSelectMode extends SelectMode,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\tTNullabilityMap extends Record<string, JoinNullability> = TTableName extends string ? Record<TTableName, 'not-null'>\n\t\t: {},\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n\tTResult extends any[] = SelectResult<TSelection, TSelectMode, TNullabilityMap>[],\n\tTSelectedFields extends ColumnsSelection = BuildSubquerySelection<TSelection, TNullabilityMap>,\n> extends\n\tSingleStoreSelectQueryBuilderBase<\n\t\tSingleStoreSelectHKT,\n\t\tTTableName,\n\t\tTSelection,\n\t\tTSelectMode,\n\t\tTPreparedQueryHKT,\n\t\tTNullabilityMap,\n\t\tTDynamic,\n\t\tTExcludedMethods,\n\t\tTResult,\n\t\tTSelectedFields\n\t>,\n\tQueryPromise<TResult>\n{}\n\nexport class SingleStoreSelectBase<\n\tTTableName extends string | undefined,\n\tTSelection,\n\tTSelectMode extends SelectMode,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\tTNullabilityMap extends Record<string, JoinNullability> = TTableName extends string ? Record<TTableName, 'not-null'>\n\t\t: {},\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n\tTResult = SelectResult<TSelection, TSelectMode, TNullabilityMap>[],\n\tTSelectedFields = BuildSubquerySelection<TSelection, TNullabilityMap>,\n> extends SingleStoreSelectQueryBuilderBase<\n\tSingleStoreSelectHKT,\n\tTTableName,\n\tTSelection,\n\tTSelectMode,\n\tTPreparedQueryHKT,\n\tTNullabilityMap,\n\tTDynamic,\n\tTExcludedMethods,\n\tTResult,\n\tTSelectedFields\n> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreSelect';\n\n\tprepare(): SingleStoreSelectPrepare<this> {\n\t\tif (!this.session) {\n\t\t\tthrow new Error('Cannot execute a query on a query builder. Please use a database instance instead.');\n\t\t}\n\t\tconst fieldsList = orderSelectedFields<SingleStoreColumn>(this.config.fields);\n\t\tconst query = this.session.prepareQuery<\n\t\t\tSingleStorePreparedQueryConfig & { execute: SelectResult<TSelection, TSelectMode, TNullabilityMap>[] },\n\t\t\tTPreparedQueryHKT\n\t\t>(this.dialect.sqlToQuery(this.getSQL()), fieldsList, undefined, undefined, undefined, {\n\t\t\ttype: 'select',\n\t\t\ttables: [...this.usedTables],\n\t\t}, this.cacheConfig);\n\t\tquery.joinsNotNullableMap = this.joinsNotNullableMap;\n\t\treturn query as SingleStoreSelectPrepare<this>;\n\t}\n\n\t$withCache(config?: { config?: CacheConfig; tag?: string; autoInvalidate?: boolean } | false) {\n\t\tthis.cacheConfig = config === undefined\n\t\t\t? { config: {}, enable: true, autoInvalidate: true }\n\t\t\t: config === false\n\t\t\t? { enable: false }\n\t\t\t: { enable: true, autoInvalidate: true, ...config };\n\t\treturn this;\n\t}\n\n\texecute = ((placeholderValues) => {\n\t\treturn this.prepare().execute(placeholderValues);\n\t}) as ReturnType<this['prepare']>['execute'];\n\n\tprivate createIterator = (): ReturnType<this['prepare']>['iterator'] => {\n\t\tconst self = this;\n\t\treturn async function*(placeholderValues) {\n\t\t\tyield* self.prepare().iterator(placeholderValues);\n\t\t};\n\t};\n\n\titerator = this.createIterator();\n}\n\napplyMixins(SingleStoreSelectBase, [QueryPromise]);\n\nfunction createSetOperator(type: SetOperator, isAll: boolean): SingleStoreCreateSetOperatorFn {\n\treturn (leftSelect, rightSelect, ...restSelects) => {\n\t\tconst setOperators = [rightSelect, ...restSelects].map((select) => ({\n\t\t\ttype,\n\t\t\tisAll,\n\t\t\trightSelect: select as AnySingleStoreSelect,\n\t\t}));\n\n\t\tfor (const setOperator of setOperators) {\n\t\t\tif (!haveSameKeys((leftSelect as any).getSelectedFields(), setOperator.rightSelect.getSelectedFields())) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t'Set operator error (union / intersect / except): selected fields are not the same or are in a different order',\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\n\t\treturn (leftSelect as AnySingleStoreSelect).addSetOperators(setOperators) as any;\n\t};\n}\n\nconst getSingleStoreSetOperators = () => ({\n\tunion,\n\tunionAll,\n\tintersect,\n\texcept,\n\tminus,\n});\n\n/**\n * Adds `union` set operator to the query.\n *\n * Calling this method will combine the result sets of the `select` statements and remove any duplicate rows that appear across them.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#union}\n *\n * @example\n *\n * ```ts\n * // Select all unique names from customers and users tables\n * import { union } from 'drizzle-orm/singlestore-core'\n *\n * await union(\n * db.select({ name: users.name }).from(users),\n * db.select({ name: customers.name }).from(customers)\n * );\n * // or\n * await db.select({ name: users.name })\n * .from(users)\n * .union(\n * db.select({ name: customers.name }).from(customers)\n * );\n * ```\n */\nexport const union = createSetOperator('union', false);\n\n/**\n * Adds `union all` set operator to the query.\n *\n * Calling this method will combine the result-set of the `select` statements and keep all duplicate rows that appear across them.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#union-all}\n *\n * @example\n *\n * ```ts\n * // Select all transaction ids from both online and in-store sales\n * import { unionAll } from 'drizzle-orm/singlestore-core'\n *\n * await unionAll(\n * db.select({ transaction: onlineSales.transactionId }).from(onlineSales),\n * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n * );\n * // or\n * await db.select({ transaction: onlineSales.transactionId })\n * .from(onlineSales)\n * .unionAll(\n * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n * );\n * ```\n */\nexport const unionAll = createSetOperator('union', true);\n\n/**\n * Adds `intersect` set operator to the query.\n *\n * Calling this method will retain only the rows that are present in both result sets and eliminate duplicates.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect}\n *\n * @example\n *\n * ```ts\n * // Select course names that are offered in both departments A and B\n * import { intersect } from 'drizzle-orm/singlestore-core'\n *\n * await intersect(\n * db.select({ courseName: depA.courseName }).from(depA),\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * // or\n * await db.select({ courseName: depA.courseName })\n * .from(depA)\n * .intersect(\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * ```\n */\nexport const intersect = createSetOperator('intersect', false);\n\n/**\n * Adds `except` set operator to the query.\n *\n * Calling this method will retrieve all unique rows from the left query, except for the rows that are present in the result set of the right query.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#except}\n *\n * @example\n *\n * ```ts\n * // Select all courses offered in department A but not in department B\n * import { except } from 'drizzle-orm/singlestore-core'\n *\n * await except(\n * db.select({ courseName: depA.courseName }).from(depA),\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * // or\n * await db.select({ courseName: depA.courseName })\n * .from(depA)\n * .except(\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * ```\n */\nexport const except = createSetOperator('except', false);\n\n/**\n * Adds `minus` set operator to the query.\n *\n * This is an alias of `except` supported by SingleStore.\n *\n * @example\n *\n * ```ts\n * // Select all courses offered in department A but not in department B\n * import { minus } from 'drizzle-orm/singlestore-core'\n *\n * await minus(\n * db.select({ courseName: depA.courseName }).from(depA),\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * // or\n * await db.select({ courseName: depA.courseName })\n * .from(depA)\n * .minus(\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * ```\n */\nexport const minus = createSetOperator('except', true);\n"],"mappings":"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","names":["import_utils"]}
1
+ {"version":3,"sources":["../../../src/singlestore-core/query-builders/select.ts"],"sourcesContent":["import type { CacheConfig, WithCacheConfig } from '~/cache/core/types.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport type {\n\tBuildSubquerySelection,\n\tGetSelectTableName,\n\tGetSelectTableSelection,\n\tJoinNullability,\n\tJoinType,\n\tSelectMode,\n\tSelectResult,\n\tSetOperator,\n} from '~/query-builders/select.types.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport type { SingleStoreColumn } from '~/singlestore-core/columns/index.ts';\nimport type { SingleStoreDialect } from '~/singlestore-core/dialect.ts';\nimport type {\n\tPreparedQueryHKTBase,\n\tSingleStorePreparedQueryConfig,\n\tSingleStoreSession,\n} from '~/singlestore-core/session.ts';\nimport type { SubqueryWithSelection } from '~/singlestore-core/subquery.ts';\nimport type { SingleStoreTable } from '~/singlestore-core/table.ts';\nimport type { ColumnsSelection, Query } from '~/sql/sql.ts';\nimport { SQL } from '~/sql/sql.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { Table } from '~/table.ts';\nimport {\n\tapplyMixins,\n\tgetTableColumns,\n\tgetTableLikeName,\n\thaveSameKeys,\n\torderSelectedFields,\n\ttype ValueOrArray,\n} from '~/utils.ts';\nimport { extractUsedTable } from '../utils.ts';\nimport type {\n\tAnySingleStoreSelect,\n\tCreateSingleStoreSelectFromBuilderMode,\n\tGetSingleStoreSetOperators,\n\tLockConfig,\n\tLockStrength,\n\tSelectedFields,\n\tSetOperatorRightSelect,\n\tSingleStoreCreateSetOperatorFn,\n\tSingleStoreCrossJoinFn,\n\tSingleStoreJoinFn,\n\tSingleStoreSelectConfig,\n\tSingleStoreSelectDynamic,\n\tSingleStoreSelectHKT,\n\tSingleStoreSelectHKTBase,\n\tSingleStoreSelectPrepare,\n\tSingleStoreSelectWithout,\n\tSingleStoreSetOperatorExcludedMethods,\n\tSingleStoreSetOperatorWithResult,\n} from './select.types.ts';\n\nexport class SingleStoreSelectBuilder<\n\tTSelection extends SelectedFields | undefined,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\tTBuilderMode extends 'db' | 'qb' = 'db',\n> {\n\tstatic readonly [entityKind]: string = 'SingleStoreSelectBuilder';\n\n\tprivate fields: TSelection;\n\tprivate session: SingleStoreSession | undefined;\n\tprivate dialect: SingleStoreDialect;\n\tprivate withList: Subquery[] = [];\n\tprivate distinct: boolean | undefined;\n\n\tconstructor(\n\t\tconfig: {\n\t\t\tfields: TSelection;\n\t\t\tsession: SingleStoreSession | undefined;\n\t\t\tdialect: SingleStoreDialect;\n\t\t\twithList?: Subquery[];\n\t\t\tdistinct?: boolean;\n\t\t},\n\t) {\n\t\tthis.fields = config.fields;\n\t\tthis.session = config.session;\n\t\tthis.dialect = config.dialect;\n\t\tif (config.withList) {\n\t\t\tthis.withList = config.withList;\n\t\t}\n\t\tthis.distinct = config.distinct;\n\t}\n\n\tfrom<TFrom extends SingleStoreTable | Subquery | SQL>( // | SingleStoreViewBase\n\t\tsource: TFrom,\n\t): CreateSingleStoreSelectFromBuilderMode<\n\t\tTBuilderMode,\n\t\tGetSelectTableName<TFrom>,\n\t\tTSelection extends undefined ? GetSelectTableSelection<TFrom> : TSelection,\n\t\tTSelection extends undefined ? 'single' : 'partial',\n\t\tTPreparedQueryHKT\n\t> {\n\t\tconst isPartialSelect = !!this.fields;\n\n\t\tlet fields: SelectedFields;\n\t\tif (this.fields) {\n\t\t\tfields = this.fields;\n\t\t} else if (is(source, Subquery)) {\n\t\t\t// This is required to use the proxy handler to get the correct field values from the subquery\n\t\t\tfields = Object.fromEntries(\n\t\t\t\tObject.keys(source._.selectedFields).map((\n\t\t\t\t\tkey,\n\t\t\t\t) => [key, source[key as unknown as keyof typeof source] as unknown as SelectedFields[string]]),\n\t\t\t);\n\t\t\t/* } else if (is(source, SingleStoreViewBase)) {\n\t\t\tfields = source[ViewBaseConfig].selectedFields as SelectedFields; */\n\t\t} else if (is(source, SQL)) {\n\t\t\tfields = {};\n\t\t} else {\n\t\t\tfields = getTableColumns<SingleStoreTable>(source);\n\t\t}\n\n\t\treturn new SingleStoreSelectBase(\n\t\t\t{\n\t\t\t\ttable: source,\n\t\t\t\tfields,\n\t\t\t\tisPartialSelect,\n\t\t\t\tsession: this.session,\n\t\t\t\tdialect: this.dialect,\n\t\t\t\twithList: this.withList,\n\t\t\t\tdistinct: this.distinct,\n\t\t\t},\n\t\t) as any;\n\t}\n}\n\nexport abstract class SingleStoreSelectQueryBuilderBase<\n\tTHKT extends SingleStoreSelectHKTBase,\n\tTTableName extends string | undefined,\n\tTSelection extends ColumnsSelection,\n\tTSelectMode extends SelectMode,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\tTNullabilityMap extends Record<string, JoinNullability> = TTableName extends string ? Record<TTableName, 'not-null'>\n\t\t: {},\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n\tTResult extends any[] = SelectResult<TSelection, TSelectMode, TNullabilityMap>[],\n\tTSelectedFields extends ColumnsSelection = BuildSubquerySelection<TSelection, TNullabilityMap>,\n> extends TypedQueryBuilder<TSelectedFields, TResult> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreSelectQueryBuilder';\n\n\toverride readonly _: {\n\t\treadonly hkt: THKT;\n\t\treadonly tableName: TTableName;\n\t\treadonly selection: TSelection;\n\t\treadonly selectMode: TSelectMode;\n\t\treadonly preparedQueryHKT: TPreparedQueryHKT;\n\t\treadonly nullabilityMap: TNullabilityMap;\n\t\treadonly dynamic: TDynamic;\n\t\treadonly excludedMethods: TExcludedMethods;\n\t\treadonly result: TResult;\n\t\treadonly selectedFields: TSelectedFields;\n\t\treadonly config: SingleStoreSelectConfig;\n\t};\n\n\tprotected config: SingleStoreSelectConfig;\n\tprotected joinsNotNullableMap: Record<string, boolean>;\n\tprivate tableName: string | undefined;\n\tprivate isPartialSelect: boolean;\n\t/** @internal */\n\treadonly session: SingleStoreSession | undefined;\n\tprotected dialect: SingleStoreDialect;\n\tprotected cacheConfig?: WithCacheConfig = undefined;\n\tprotected usedTables: Set<string> = new Set();\n\n\tconstructor(\n\t\t{ table, fields, isPartialSelect, session, dialect, withList, distinct }: {\n\t\t\ttable: SingleStoreSelectConfig['table'];\n\t\t\tfields: SingleStoreSelectConfig['fields'];\n\t\t\tisPartialSelect: boolean;\n\t\t\tsession: SingleStoreSession | undefined;\n\t\t\tdialect: SingleStoreDialect;\n\t\t\twithList: Subquery[];\n\t\t\tdistinct: boolean | undefined;\n\t\t},\n\t) {\n\t\tsuper();\n\t\tthis.config = {\n\t\t\twithList,\n\t\t\ttable,\n\t\t\tfields: { ...fields },\n\t\t\tdistinct,\n\t\t\tsetOperators: [],\n\t\t};\n\t\tthis.isPartialSelect = isPartialSelect;\n\t\tthis.session = session;\n\t\tthis.dialect = dialect;\n\t\tthis._ = {\n\t\t\tselectedFields: fields as TSelectedFields,\n\t\t\tconfig: this.config,\n\t\t} as this['_'];\n\t\tthis.tableName = getTableLikeName(table);\n\t\tthis.joinsNotNullableMap = typeof this.tableName === 'string' ? { [this.tableName]: true } : {};\n\t\tfor (const item of extractUsedTable(table)) this.usedTables.add(item);\n\t}\n\n\t/** @internal */\n\tgetUsedTables() {\n\t\treturn [...this.usedTables];\n\t}\n\n\tprivate createJoin<\n\t\tTJoinType extends JoinType,\n\t\tTIsLateral extends (TJoinType extends 'full' | 'right' ? false : boolean),\n\t>(\n\t\tjoinType: TJoinType,\n\t\tlateral: TIsLateral,\n\t): 'cross' extends TJoinType ? SingleStoreCrossJoinFn<this, TDynamic, TIsLateral>\n\t\t: SingleStoreJoinFn<this, TDynamic, TJoinType, TIsLateral>\n\t{\n\t\treturn (\n\t\t\ttable: SingleStoreTable | Subquery | SQL, // | SingleStoreViewBase\n\t\t\ton?: ((aliases: TSelection) => SQL | undefined) | SQL | undefined,\n\t\t) => {\n\t\t\tconst baseTableName = this.tableName;\n\t\t\tconst tableName = getTableLikeName(table);\n\n\t\t\t// store all tables used in a query\n\t\t\tfor (const item of extractUsedTable(table)) this.usedTables.add(item);\n\n\t\t\tif (typeof tableName === 'string' && this.config.joins?.some((join) => join.alias === tableName)) {\n\t\t\t\tthrow new Error(`Alias \"${tableName}\" is already used in this query`);\n\t\t\t}\n\n\t\t\tif (!this.isPartialSelect) {\n\t\t\t\t// If this is the first join and this is not a partial select and we're not selecting from raw SQL, \"move\" the fields from the main table to the nested object\n\t\t\t\tif (Object.keys(this.joinsNotNullableMap).length === 1 && typeof baseTableName === 'string') {\n\t\t\t\t\tthis.config.fields = {\n\t\t\t\t\t\t[baseTableName]: this.config.fields,\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\tif (typeof tableName === 'string' && !is(table, SQL)) {\n\t\t\t\t\tconst selection = is(table, Subquery)\n\t\t\t\t\t\t? table._.selectedFields\n\t\t\t\t\t\t/* : is(table, View)\n\t\t\t\t\t\t? table[ViewBaseConfig].selectedFields */\n\t\t\t\t\t\t: table[Table.Symbol.Columns];\n\t\t\t\t\tthis.config.fields[tableName] = selection;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (typeof on === 'function') {\n\t\t\t\ton = on(\n\t\t\t\t\tnew Proxy(\n\t\t\t\t\t\tthis.config.fields,\n\t\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t\t) as TSelection,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tif (!this.config.joins) {\n\t\t\t\tthis.config.joins = [];\n\t\t\t}\n\n\t\t\tthis.config.joins.push({ on, table, joinType, alias: tableName, lateral });\n\n\t\t\tif (typeof tableName === 'string') {\n\t\t\t\tswitch (joinType) {\n\t\t\t\t\tcase 'left': {\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = false;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'right': {\n\t\t\t\t\t\tthis.joinsNotNullableMap = Object.fromEntries(\n\t\t\t\t\t\t\tObject.entries(this.joinsNotNullableMap).map(([key]) => [key, false]),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'cross':\n\t\t\t\t\tcase 'inner': {\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'full': {\n\t\t\t\t\t\tthis.joinsNotNullableMap = Object.fromEntries(\n\t\t\t\t\t\t\tObject.entries(this.joinsNotNullableMap).map(([key]) => [key, false]),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = false;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn this as any;\n\t\t};\n\t}\n\n\t/**\n\t * Executes a `left join` operation by adding another table to the current query.\n\t *\n\t * Calling this method associates each row of the table with the corresponding row from the joined table, if a match is found. If no matching row exists, it sets all columns of the joined table to null.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#left-join}\n\t *\n\t * @param table the table to join.\n\t * @param on the `on` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all users and their pets\n\t * const usersWithPets: { user: User; pets: Pet | null; }[] = await db.select()\n\t * .from(users)\n\t * .leftJoin(pets, eq(users.id, pets.ownerId))\n\t *\n\t * // Select userId and petId\n\t * const usersIdsAndPetIds: { userId: number; petId: number | null; }[] = await db.select({\n\t * userId: users.id,\n\t * petId: pets.id,\n\t * })\n\t * .from(users)\n\t * .leftJoin(pets, eq(users.id, pets.ownerId))\n\t * ```\n\t */\n\tleftJoin = this.createJoin('left', false);\n\n\t/**\n\t * Executes a `left join lateral` operation by adding subquery to the current query.\n\t *\n\t * A `lateral` join allows the right-hand expression to refer to columns from the left-hand side.\n\t *\n\t * Calling this method associates each row of the table with the corresponding row from the joined table, if a match is found. If no matching row exists, it sets all columns of the joined table to null.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#left-join-lateral}\n\t *\n\t * @param table the subquery to join.\n\t * @param on the `on` clause.\n\t */\n\tleftJoinLateral = this.createJoin('left', true);\n\n\t/**\n\t * Executes a `right join` operation by adding another table to the current query.\n\t *\n\t * Calling this method associates each row of the joined table with the corresponding row from the main table, if a match is found. If no matching row exists, it sets all columns of the main table to null.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#right-join}\n\t *\n\t * @param table the table to join.\n\t * @param on the `on` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all users and their pets\n\t * const usersWithPets: { user: User | null; pets: Pet; }[] = await db.select()\n\t * .from(users)\n\t * .rightJoin(pets, eq(users.id, pets.ownerId))\n\t *\n\t * // Select userId and petId\n\t * const usersIdsAndPetIds: { userId: number | null; petId: number; }[] = await db.select({\n\t * userId: users.id,\n\t * petId: pets.id,\n\t * })\n\t * .from(users)\n\t * .rightJoin(pets, eq(users.id, pets.ownerId))\n\t * ```\n\t */\n\trightJoin = this.createJoin('right', false);\n\n\t/**\n\t * Executes an `inner join` operation, creating a new table by combining rows from two tables that have matching values.\n\t *\n\t * Calling this method retrieves rows that have corresponding entries in both joined tables. Rows without matching entries in either table are excluded, resulting in a table that includes only matching pairs.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join}\n\t *\n\t * @param table the table to join.\n\t * @param on the `on` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all users and their pets\n\t * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()\n\t * .from(users)\n\t * .innerJoin(pets, eq(users.id, pets.ownerId))\n\t *\n\t * // Select userId and petId\n\t * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({\n\t * userId: users.id,\n\t * petId: pets.id,\n\t * })\n\t * .from(users)\n\t * .innerJoin(pets, eq(users.id, pets.ownerId))\n\t * ```\n\t */\n\tinnerJoin = this.createJoin('inner', false);\n\n\t/**\n\t * Executes an `inner join lateral` operation, creating a new table by combining rows from two queries that have matching values.\n\t *\n\t * A `lateral` join allows the right-hand expression to refer to columns from the left-hand side.\n\t *\n\t * Calling this method retrieves rows that have corresponding entries in both joined tables. Rows without matching entries in either table are excluded, resulting in a table that includes only matching pairs.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join-lateral}\n\t *\n\t * @param table the subquery to join.\n\t * @param on the `on` clause.\n\t */\n\tinnerJoinLateral = this.createJoin('inner', true);\n\n\t/**\n\t * Executes a `full join` operation by combining rows from two tables into a new table.\n\t *\n\t * Calling this method retrieves all rows from both main and joined tables, merging rows with matching values and filling in `null` for non-matching columns.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#full-join}\n\t *\n\t * @param table the table to join.\n\t * @param on the `on` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all users and their pets\n\t * const usersWithPets: { user: User | null; pets: Pet | null; }[] = await db.select()\n\t * .from(users)\n\t * .fullJoin(pets, eq(users.id, pets.ownerId))\n\t *\n\t * // Select userId and petId\n\t * const usersIdsAndPetIds: { userId: number | null; petId: number | null; }[] = await db.select({\n\t * userId: users.id,\n\t * petId: pets.id,\n\t * })\n\t * .from(users)\n\t * .fullJoin(pets, eq(users.id, pets.ownerId))\n\t * ```\n\t */\n\tfullJoin = this.createJoin('full', false);\n\n\t/**\n\t * Executes a `cross join` operation by combining rows from two tables into a new table.\n\t *\n\t * Calling this method retrieves all rows from both main and joined tables, merging all rows from each table.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#cross-join}\n\t *\n\t * @param table the table to join.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all users, each user with every pet\n\t * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()\n\t * .from(users)\n\t * .crossJoin(pets)\n\t *\n\t * // Select userId and petId\n\t * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({\n\t * userId: users.id,\n\t * petId: pets.id,\n\t * })\n\t * .from(users)\n\t * .crossJoin(pets)\n\t * ```\n\t */\n\tcrossJoin = this.createJoin('cross', false);\n\n\t/**\n\t * Executes a `cross join lateral` operation by combining rows from two queries into a new table.\n\t *\n\t * A `lateral` join allows the right-hand expression to refer to columns from the left-hand side.\n\t *\n\t * Calling this method retrieves all rows from both main and joined queries, merging all rows from each query.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#cross-join-lateral}\n\t *\n\t * @param table the query to join.\n\t */\n\tcrossJoinLateral = this.createJoin('cross', true);\n\n\tprivate createSetOperator(\n\t\ttype: SetOperator,\n\t\tisAll: boolean,\n\t): <TValue extends SingleStoreSetOperatorWithResult<TResult>>(\n\t\trightSelection:\n\t\t\t| ((setOperators: GetSingleStoreSetOperators) => SetOperatorRightSelect<TValue, TResult>)\n\t\t\t| SetOperatorRightSelect<TValue, TResult>,\n\t) => SingleStoreSelectWithout<\n\t\tthis,\n\t\tTDynamic,\n\t\tSingleStoreSetOperatorExcludedMethods,\n\t\ttrue\n\t> {\n\t\treturn (rightSelection) => {\n\t\t\tconst rightSelect = (typeof rightSelection === 'function'\n\t\t\t\t? rightSelection(getSingleStoreSetOperators())\n\t\t\t\t: rightSelection) as TypedQueryBuilder<\n\t\t\t\t\tany,\n\t\t\t\t\tTResult\n\t\t\t\t>;\n\n\t\t\tif (!haveSameKeys(this.getSelectedFields(), rightSelect.getSelectedFields())) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t'Set operator error (union / intersect / except): selected fields are not the same or are in a different order',\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tthis.config.setOperators.push({ type, isAll, rightSelect });\n\t\t\treturn this as any;\n\t\t};\n\t}\n\n\t/**\n\t * Adds `union` set operator to the query.\n\t *\n\t * Calling this method will combine the result sets of the `select` statements and remove any duplicate rows that appear across them.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/set-operations#union}\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all unique names from customers and users tables\n\t * await db.select({ name: users.name })\n\t * .from(users)\n\t * .union(\n\t * db.select({ name: customers.name }).from(customers)\n\t * );\n\t * // or\n\t * import { union } from 'drizzle-orm/singlestore-core'\n\t *\n\t * await union(\n\t * db.select({ name: users.name }).from(users),\n\t * db.select({ name: customers.name }).from(customers)\n\t * );\n\t * ```\n\t */\n\tunion = this.createSetOperator('union', false);\n\n\t/**\n\t * Adds `union all` set operator to the query.\n\t *\n\t * Calling this method will combine the result-set of the `select` statements and keep all duplicate rows that appear across them.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/set-operations#union-all}\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all transaction ids from both online and in-store sales\n\t * await db.select({ transaction: onlineSales.transactionId })\n\t * .from(onlineSales)\n\t * .unionAll(\n\t * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n\t * );\n\t * // or\n\t * import { unionAll } from 'drizzle-orm/singlestore-core'\n\t *\n\t * await unionAll(\n\t * db.select({ transaction: onlineSales.transactionId }).from(onlineSales),\n\t * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n\t * );\n\t * ```\n\t */\n\tunionAll = this.createSetOperator('union', true);\n\n\t/**\n\t * Adds `intersect` set operator to the query.\n\t *\n\t * Calling this method will retain only the rows that are present in both result sets and eliminate duplicates.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect}\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select course names that are offered in both departments A and B\n\t * await db.select({ courseName: depA.courseName })\n\t * .from(depA)\n\t * .intersect(\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * // or\n\t * import { intersect } from 'drizzle-orm/singlestore-core'\n\t *\n\t * await intersect(\n\t * db.select({ courseName: depA.courseName }).from(depA),\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * ```\n\t */\n\tintersect = this.createSetOperator('intersect', false);\n\n\t/**\n\t * Adds `except` set operator to the query.\n\t *\n\t * Calling this method will retrieve all unique rows from the left query, except for the rows that are present in the result set of the right query.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/set-operations#except}\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all courses offered in department A but not in department B\n\t * await db.select({ courseName: depA.courseName })\n\t * .from(depA)\n\t * .except(\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * // or\n\t * import { except } from 'drizzle-orm/singlestore-core'\n\t *\n\t * await except(\n\t * db.select({ courseName: depA.courseName }).from(depA),\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * ```\n\t */\n\texcept = this.createSetOperator('except', false);\n\n\t/**\n\t * Adds `minus` set operator to the query.\n\t *\n\t * This is an alias of `except` supported by SingleStore.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all courses offered in department A but not in department B\n\t * await db.select({ courseName: depA.courseName })\n\t * .from(depA)\n\t * .minus(\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * // or\n\t * import { minus } from 'drizzle-orm/singlestore-core'\n\t *\n\t * await minus(\n\t * db.select({ courseName: depA.courseName }).from(depA),\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * ```\n\t */\n\tminus = this.createSetOperator('except', false);\n\n\t/** @internal */\n\taddSetOperators(setOperators: SingleStoreSelectConfig['setOperators']): SingleStoreSelectWithout<\n\t\tthis,\n\t\tTDynamic,\n\t\tSingleStoreSetOperatorExcludedMethods,\n\t\ttrue\n\t> {\n\t\tthis.config.setOperators.push(...setOperators);\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `where` clause to the query.\n\t *\n\t * Calling this method will select only those rows that fulfill a specified condition.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#filtering}\n\t *\n\t * @param where the `where` clause.\n\t *\n\t * @example\n\t * You can use conditional operators and `sql function` to filter the rows to be selected.\n\t *\n\t * ```ts\n\t * // Select all cars with green color\n\t * await db.select().from(cars).where(eq(cars.color, 'green'));\n\t * // or\n\t * await db.select().from(cars).where(sql`${cars.color} = 'green'`)\n\t * ```\n\t *\n\t * You can logically combine conditional operators with `and()` and `or()` operators:\n\t *\n\t * ```ts\n\t * // Select all BMW cars with a green color\n\t * await db.select().from(cars).where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n\t *\n\t * // Select all cars with the green or blue color\n\t * await db.select().from(cars).where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n\t * ```\n\t */\n\twhere(\n\t\twhere: ((aliases: this['_']['selection']) => SQL | undefined) | SQL | undefined,\n\t): SingleStoreSelectWithout<this, TDynamic, 'where'> {\n\t\tif (typeof where === 'function') {\n\t\t\twhere = where(\n\t\t\t\tnew Proxy(\n\t\t\t\t\tthis.config.fields,\n\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t) as TSelection,\n\t\t\t);\n\t\t}\n\t\tthis.config.where = where;\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `having` clause to the query.\n\t *\n\t * Calling this method will select only those rows that fulfill a specified condition. It is typically used with aggregate functions to filter the aggregated data based on a specified condition.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#aggregations}\n\t *\n\t * @param having the `having` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all brands with more than one car\n\t * await db.select({\n\t * \tbrand: cars.brand,\n\t * \tcount: sql<number>`cast(count(${cars.id}) as int)`,\n\t * })\n\t * .from(cars)\n\t * .groupBy(cars.brand)\n\t * .having(({ count }) => gt(count, 1));\n\t * ```\n\t */\n\thaving(\n\t\thaving: ((aliases: this['_']['selection']) => SQL | undefined) | SQL | undefined,\n\t): SingleStoreSelectWithout<this, TDynamic, 'having'> {\n\t\tif (typeof having === 'function') {\n\t\t\thaving = having(\n\t\t\t\tnew Proxy(\n\t\t\t\t\tthis.config.fields,\n\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t) as TSelection,\n\t\t\t);\n\t\t}\n\t\tthis.config.having = having;\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `group by` clause to the query.\n\t *\n\t * Calling this method will group rows that have the same values into summary rows, often used for aggregation purposes.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#aggregations}\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Group and count people by their last names\n\t * await db.select({\n\t * lastName: people.lastName,\n\t * count: sql<number>`cast(count(*) as int)`\n\t * })\n\t * .from(people)\n\t * .groupBy(people.lastName);\n\t * ```\n\t */\n\tgroupBy(\n\t\tbuilder: (aliases: this['_']['selection']) => ValueOrArray<SingleStoreColumn | SQL | SQL.Aliased>,\n\t): SingleStoreSelectWithout<this, TDynamic, 'groupBy'>;\n\tgroupBy(...columns: (SingleStoreColumn | SQL | SQL.Aliased)[]): SingleStoreSelectWithout<this, TDynamic, 'groupBy'>;\n\tgroupBy(\n\t\t...columns:\n\t\t\t| [(aliases: this['_']['selection']) => ValueOrArray<SingleStoreColumn | SQL | SQL.Aliased>]\n\t\t\t| (SingleStoreColumn | SQL | SQL.Aliased)[]\n\t): SingleStoreSelectWithout<this, TDynamic, 'groupBy'> {\n\t\tif (typeof columns[0] === 'function') {\n\t\t\tconst groupBy = columns[0](\n\t\t\t\tnew Proxy(\n\t\t\t\t\tthis.config.fields,\n\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'alias', sqlBehavior: 'sql' }),\n\t\t\t\t) as TSelection,\n\t\t\t);\n\t\t\tthis.config.groupBy = Array.isArray(groupBy) ? groupBy : [groupBy];\n\t\t} else {\n\t\t\tthis.config.groupBy = columns as (SingleStoreColumn | SQL | SQL.Aliased)[];\n\t\t}\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds an `order by` clause to the query.\n\t *\n\t * Calling this method will sort the result-set in ascending or descending order. By default, the sort order is ascending.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#order-by}\n\t *\n\t * @example\n\t *\n\t * ```\n\t * // Select cars ordered by year\n\t * await db.select().from(cars).orderBy(cars.year);\n\t * ```\n\t *\n\t * You can specify whether results are in ascending or descending order with the `asc()` and `desc()` operators.\n\t *\n\t * ```ts\n\t * // Select cars ordered by year in descending order\n\t * await db.select().from(cars).orderBy(desc(cars.year));\n\t *\n\t * // Select cars ordered by year and price\n\t * await db.select().from(cars).orderBy(asc(cars.year), desc(cars.price));\n\t * ```\n\t */\n\torderBy(\n\t\tbuilder: (aliases: this['_']['selection']) => ValueOrArray<SingleStoreColumn | SQL | SQL.Aliased>,\n\t): SingleStoreSelectWithout<this, TDynamic, 'orderBy'>;\n\torderBy(...columns: (SingleStoreColumn | SQL | SQL.Aliased)[]): SingleStoreSelectWithout<this, TDynamic, 'orderBy'>;\n\torderBy(\n\t\t...columns:\n\t\t\t| [(aliases: this['_']['selection']) => ValueOrArray<SingleStoreColumn | SQL | SQL.Aliased>]\n\t\t\t| (SingleStoreColumn | SQL | SQL.Aliased)[]\n\t): SingleStoreSelectWithout<this, TDynamic, 'orderBy'> {\n\t\tif (typeof columns[0] === 'function') {\n\t\t\tconst orderBy = columns[0](\n\t\t\t\tnew Proxy(\n\t\t\t\t\tthis.config.fields,\n\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'alias', sqlBehavior: 'sql' }),\n\t\t\t\t) as TSelection,\n\t\t\t);\n\n\t\t\tconst orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];\n\n\t\t\tif (this.config.setOperators.length > 0) {\n\t\t\t\tthis.config.setOperators.at(-1)!.orderBy = orderByArray;\n\t\t\t} else {\n\t\t\t\tthis.config.orderBy = orderByArray;\n\t\t\t}\n\t\t} else {\n\t\t\tconst orderByArray = columns as (SingleStoreColumn | SQL | SQL.Aliased)[];\n\n\t\t\tif (this.config.setOperators.length > 0) {\n\t\t\t\tthis.config.setOperators.at(-1)!.orderBy = orderByArray;\n\t\t\t} else {\n\t\t\t\tthis.config.orderBy = orderByArray;\n\t\t\t}\n\t\t}\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `limit` clause to the query.\n\t *\n\t * Calling this method will set the maximum number of rows that will be returned by this query.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}\n\t *\n\t * @param limit the `limit` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Get the first 10 people from this query.\n\t * await db.select().from(people).limit(10);\n\t * ```\n\t */\n\tlimit(limit: number): SingleStoreSelectWithout<this, TDynamic, 'limit'> {\n\t\tif (this.config.setOperators.length > 0) {\n\t\t\tthis.config.setOperators.at(-1)!.limit = limit;\n\t\t} else {\n\t\t\tthis.config.limit = limit;\n\t\t}\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds an `offset` clause to the query.\n\t *\n\t * Calling this method will skip a number of rows when returning results from this query.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}\n\t *\n\t * @param offset the `offset` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Get the 10th-20th people from this query.\n\t * await db.select().from(people).offset(10).limit(10);\n\t * ```\n\t */\n\toffset(offset: number): SingleStoreSelectWithout<this, TDynamic, 'offset'> {\n\t\tif (this.config.setOperators.length > 0) {\n\t\t\tthis.config.setOperators.at(-1)!.offset = offset;\n\t\t} else {\n\t\t\tthis.config.offset = offset;\n\t\t}\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `for` clause to the query.\n\t *\n\t * Calling this method will specify a lock strength for this query that controls how strictly it acquires exclusive access to the rows being queried.\n\t *\n\t * @param strength the lock strength.\n\t * @param config the lock configuration.\n\t */\n\tfor(strength: LockStrength, config: LockConfig = {}): SingleStoreSelectWithout<this, TDynamic, 'for'> {\n\t\tthis.config.lockingClause = { strength, config };\n\t\treturn this as any;\n\t}\n\n\t/** @internal */\n\tgetSQL(): SQL {\n\t\treturn this.dialect.buildSelectQuery(this.config);\n\t}\n\n\ttoSQL(): Query {\n\t\tconst { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n\t\treturn rest;\n\t}\n\n\tas<TAlias extends string>(\n\t\talias: TAlias,\n\t): SubqueryWithSelection<this['_']['selectedFields'], TAlias> {\n\t\tconst usedTables: string[] = [];\n\t\tusedTables.push(...extractUsedTable(this.config.table));\n\t\tif (this.config.joins) { for (const it of this.config.joins) usedTables.push(...extractUsedTable(it.table)); }\n\n\t\treturn new Proxy(\n\t\t\tnew Subquery(this.getSQL(), this.config.fields, alias, false, [...new Set(usedTables)]),\n\t\t\tnew SelectionProxyHandler({ alias, sqlAliasedBehavior: 'alias', sqlBehavior: 'error' }),\n\t\t) as SubqueryWithSelection<this['_']['selectedFields'], TAlias>;\n\t}\n\n\t/** @internal */\n\toverride getSelectedFields(): this['_']['selectedFields'] {\n\t\treturn new Proxy(\n\t\t\tthis.config.fields,\n\t\t\tnew SelectionProxyHandler({ alias: this.tableName, sqlAliasedBehavior: 'alias', sqlBehavior: 'error' }),\n\t\t) as this['_']['selectedFields'];\n\t}\n\n\t$dynamic(): SingleStoreSelectDynamic<this> {\n\t\treturn this as any;\n\t}\n}\n\nexport interface SingleStoreSelectBase<\n\tTTableName extends string | undefined,\n\tTSelection extends ColumnsSelection,\n\tTSelectMode extends SelectMode,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\tTNullabilityMap extends Record<string, JoinNullability> = TTableName extends string ? Record<TTableName, 'not-null'>\n\t\t: {},\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n\tTResult extends any[] = SelectResult<TSelection, TSelectMode, TNullabilityMap>[],\n\tTSelectedFields extends ColumnsSelection = BuildSubquerySelection<TSelection, TNullabilityMap>,\n> extends\n\tSingleStoreSelectQueryBuilderBase<\n\t\tSingleStoreSelectHKT,\n\t\tTTableName,\n\t\tTSelection,\n\t\tTSelectMode,\n\t\tTPreparedQueryHKT,\n\t\tTNullabilityMap,\n\t\tTDynamic,\n\t\tTExcludedMethods,\n\t\tTResult,\n\t\tTSelectedFields\n\t>,\n\tQueryPromise<TResult>\n{}\n\nexport class SingleStoreSelectBase<\n\tTTableName extends string | undefined,\n\tTSelection,\n\tTSelectMode extends SelectMode,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n\tTNullabilityMap extends Record<string, JoinNullability> = TTableName extends string ? Record<TTableName, 'not-null'>\n\t\t: {},\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n\tTResult = SelectResult<TSelection, TSelectMode, TNullabilityMap>[],\n\tTSelectedFields = BuildSubquerySelection<TSelection, TNullabilityMap>,\n> extends SingleStoreSelectQueryBuilderBase<\n\tSingleStoreSelectHKT,\n\tTTableName,\n\tTSelection,\n\tTSelectMode,\n\tTPreparedQueryHKT,\n\tTNullabilityMap,\n\tTDynamic,\n\tTExcludedMethods,\n\tTResult,\n\tTSelectedFields\n> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreSelect';\n\n\tprepare(): SingleStoreSelectPrepare<this> {\n\t\tif (!this.session) {\n\t\t\tthrow new Error('Cannot execute a query on a query builder. Please use a database instance instead.');\n\t\t}\n\t\tconst fieldsList = orderSelectedFields<SingleStoreColumn>(this.config.fields);\n\t\tconst query = this.session.prepareQuery<\n\t\t\tSingleStorePreparedQueryConfig & { execute: SelectResult<TSelection, TSelectMode, TNullabilityMap>[] },\n\t\t\tTPreparedQueryHKT\n\t\t>(this.dialect.sqlToQuery(this.getSQL()), fieldsList, undefined, undefined, undefined, {\n\t\t\ttype: 'select',\n\t\t\ttables: [...this.usedTables],\n\t\t}, this.cacheConfig);\n\t\tquery.joinsNotNullableMap = this.joinsNotNullableMap;\n\t\treturn query as SingleStoreSelectPrepare<this>;\n\t}\n\n\t$withCache(config?: { config?: CacheConfig; tag?: string; autoInvalidate?: boolean } | false) {\n\t\tthis.cacheConfig = config === undefined\n\t\t\t? { config: {}, enable: true, autoInvalidate: true }\n\t\t\t: config === false\n\t\t\t? { enable: false }\n\t\t\t: { enable: true, autoInvalidate: true, ...config };\n\t\treturn this;\n\t}\n\n\texecute = ((placeholderValues) => {\n\t\treturn this.prepare().execute(placeholderValues);\n\t}) as ReturnType<this['prepare']>['execute'];\n\n\tprivate createIterator = (): ReturnType<this['prepare']>['iterator'] => {\n\t\tconst self = this;\n\t\treturn async function*(placeholderValues) {\n\t\t\tyield* self.prepare().iterator(placeholderValues);\n\t\t};\n\t};\n\n\titerator = this.createIterator();\n}\n\napplyMixins(SingleStoreSelectBase, [QueryPromise]);\n\nfunction createSetOperator(type: SetOperator, isAll: boolean): SingleStoreCreateSetOperatorFn {\n\treturn (leftSelect, rightSelect, ...restSelects) => {\n\t\tconst setOperators = [rightSelect, ...restSelects].map((select) => ({\n\t\t\ttype,\n\t\t\tisAll,\n\t\t\trightSelect: select as AnySingleStoreSelect,\n\t\t}));\n\n\t\tfor (const setOperator of setOperators) {\n\t\t\tif (!haveSameKeys((leftSelect as any).getSelectedFields(), setOperator.rightSelect.getSelectedFields())) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t'Set operator error (union / intersect / except): selected fields are not the same or are in a different order',\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\n\t\treturn (leftSelect as AnySingleStoreSelect).addSetOperators(setOperators) as any;\n\t};\n}\n\nconst getSingleStoreSetOperators = () => ({\n\tunion,\n\tunionAll,\n\tintersect,\n\texcept,\n\tminus,\n});\n\n/**\n * Adds `union` set operator to the query.\n *\n * Calling this method will combine the result sets of the `select` statements and remove any duplicate rows that appear across them.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#union}\n *\n * @example\n *\n * ```ts\n * // Select all unique names from customers and users tables\n * import { union } from 'drizzle-orm/singlestore-core'\n *\n * await union(\n * db.select({ name: users.name }).from(users),\n * db.select({ name: customers.name }).from(customers)\n * );\n * // or\n * await db.select({ name: users.name })\n * .from(users)\n * .union(\n * db.select({ name: customers.name }).from(customers)\n * );\n * ```\n */\nexport const union = createSetOperator('union', false);\n\n/**\n * Adds `union all` set operator to the query.\n *\n * Calling this method will combine the result-set of the `select` statements and keep all duplicate rows that appear across them.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#union-all}\n *\n * @example\n *\n * ```ts\n * // Select all transaction ids from both online and in-store sales\n * import { unionAll } from 'drizzle-orm/singlestore-core'\n *\n * await unionAll(\n * db.select({ transaction: onlineSales.transactionId }).from(onlineSales),\n * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n * );\n * // or\n * await db.select({ transaction: onlineSales.transactionId })\n * .from(onlineSales)\n * .unionAll(\n * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n * );\n * ```\n */\nexport const unionAll = createSetOperator('union', true);\n\n/**\n * Adds `intersect` set operator to the query.\n *\n * Calling this method will retain only the rows that are present in both result sets and eliminate duplicates.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect}\n *\n * @example\n *\n * ```ts\n * // Select course names that are offered in both departments A and B\n * import { intersect } from 'drizzle-orm/singlestore-core'\n *\n * await intersect(\n * db.select({ courseName: depA.courseName }).from(depA),\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * // or\n * await db.select({ courseName: depA.courseName })\n * .from(depA)\n * .intersect(\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * ```\n */\nexport const intersect = createSetOperator('intersect', false);\n\n/**\n * Adds `except` set operator to the query.\n *\n * Calling this method will retrieve all unique rows from the left query, except for the rows that are present in the result set of the right query.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#except}\n *\n * @example\n *\n * ```ts\n * // Select all courses offered in department A but not in department B\n * import { except } from 'drizzle-orm/singlestore-core'\n *\n * await except(\n * db.select({ courseName: depA.courseName }).from(depA),\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * // or\n * await db.select({ courseName: depA.courseName })\n * .from(depA)\n * .except(\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * ```\n */\nexport const except = createSetOperator('except', false);\n\n/**\n * Adds `minus` set operator to the query.\n *\n * This is an alias of `except` supported by SingleStore.\n *\n * @example\n *\n * ```ts\n * // Select all courses offered in department A but not in department B\n * import { minus } from 'drizzle-orm/singlestore-core'\n *\n * await minus(\n * db.select({ courseName: depA.courseName }).from(depA),\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * // or\n * await db.select({ courseName: depA.courseName })\n * .from(depA)\n * .minus(\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * ```\n */\nexport const minus = createSetOperator('except', true);\n"],"mappings":"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","names":["import_utils"]}
@@ -696,9 +696,9 @@ class SingleStoreSelectBase extends SingleStoreSelectQueryBuilderBase {
696
696
  this.cacheConfig = config === void 0 ? { config: {}, enable: true, autoInvalidate: true } : config === false ? { enable: false } : { enable: true, autoInvalidate: true, ...config };
697
697
  return this;
698
698
  }
699
- execute = ((placeholderValues) => {
699
+ execute = (placeholderValues) => {
700
700
  return this.prepare().execute(placeholderValues);
701
- });
701
+ };
702
702
  createIterator = () => {
703
703
  const self = this;
704
704
  return async function* (placeholderValues) {