drizzle-orm 0.42.0-da9af74 → 0.43.0-62ea5c4

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 (532) hide show
  1. package/aws-data-api/pg/driver.cjs +1 -5
  2. package/aws-data-api/pg/driver.cjs.map +1 -1
  3. package/aws-data-api/pg/driver.d.cts +0 -1
  4. package/aws-data-api/pg/driver.d.ts +0 -1
  5. package/aws-data-api/pg/driver.js +1 -5
  6. package/aws-data-api/pg/driver.js.map +1 -1
  7. package/aws-data-api/pg/session.cjs +4 -15
  8. package/aws-data-api/pg/session.cjs.map +1 -1
  9. package/aws-data-api/pg/session.d.cts +2 -13
  10. package/aws-data-api/pg/session.d.ts +2 -13
  11. package/aws-data-api/pg/session.js +4 -15
  12. package/aws-data-api/pg/session.js.map +1 -1
  13. package/better-sqlite3/driver.cjs.map +1 -1
  14. package/better-sqlite3/driver.js.map +1 -1
  15. package/better-sqlite3/session.cjs +3 -9
  16. package/better-sqlite3/session.cjs.map +1 -1
  17. package/better-sqlite3/session.d.cts +2 -12
  18. package/better-sqlite3/session.d.ts +2 -12
  19. package/better-sqlite3/session.js +3 -9
  20. package/better-sqlite3/session.js.map +1 -1
  21. package/bun-sql/driver.cjs +1 -5
  22. package/bun-sql/driver.cjs.map +1 -1
  23. package/bun-sql/driver.js +1 -5
  24. package/bun-sql/driver.js.map +1 -1
  25. package/bun-sql/session.cjs +9 -21
  26. package/bun-sql/session.cjs.map +1 -1
  27. package/bun-sql/session.d.cts +2 -12
  28. package/bun-sql/session.d.ts +2 -12
  29. package/bun-sql/session.js +9 -21
  30. package/bun-sql/session.js.map +1 -1
  31. package/d1/driver.cjs +1 -5
  32. package/d1/driver.cjs.map +1 -1
  33. package/d1/driver.js +1 -5
  34. package/d1/driver.js.map +1 -1
  35. package/d1/session.cjs +9 -23
  36. package/d1/session.cjs.map +1 -1
  37. package/d1/session.d.cts +2 -12
  38. package/d1/session.d.ts +2 -12
  39. package/d1/session.js +9 -23
  40. package/d1/session.js.map +1 -1
  41. package/durable-sqlite/session.cjs +1 -1
  42. package/durable-sqlite/session.cjs.map +1 -1
  43. package/durable-sqlite/session.js +1 -1
  44. package/durable-sqlite/session.js.map +1 -1
  45. package/gel/driver.cjs +2 -9
  46. package/gel/driver.cjs.map +1 -1
  47. package/gel/driver.d.cts +0 -2
  48. package/gel/driver.d.ts +0 -2
  49. package/gel/driver.js +2 -9
  50. package/gel/driver.js.map +1 -1
  51. package/gel/session.cjs +10 -25
  52. package/gel/session.cjs.map +1 -1
  53. package/gel/session.d.cts +2 -12
  54. package/gel/session.d.ts +2 -12
  55. package/gel/session.js +10 -25
  56. package/gel/session.js.map +1 -1
  57. package/gel-core/db.cjs +0 -1
  58. package/gel-core/db.cjs.map +1 -1
  59. package/gel-core/db.d.cts +0 -4
  60. package/gel-core/db.d.ts +0 -4
  61. package/gel-core/db.js +0 -1
  62. package/gel-core/db.js.map +1 -1
  63. package/gel-core/dialect.cjs +8 -23
  64. package/gel-core/dialect.cjs.map +1 -1
  65. package/gel-core/dialect.d.cts +1 -0
  66. package/gel-core/dialect.d.ts +1 -0
  67. package/gel-core/dialect.js +8 -23
  68. package/gel-core/dialect.js.map +1 -1
  69. package/gel-core/query-builders/delete.cjs +1 -5
  70. package/gel-core/query-builders/delete.cjs.map +1 -1
  71. package/gel-core/query-builders/delete.js +1 -5
  72. package/gel-core/query-builders/delete.js.map +1 -1
  73. package/gel-core/query-builders/insert.cjs +1 -5
  74. package/gel-core/query-builders/insert.cjs.map +1 -1
  75. package/gel-core/query-builders/insert.js +1 -5
  76. package/gel-core/query-builders/insert.js.map +1 -1
  77. package/gel-core/query-builders/select.cjs +84 -43
  78. package/gel-core/query-builders/select.cjs.map +1 -1
  79. package/gel-core/query-builders/select.d.cts +78 -22
  80. package/gel-core/query-builders/select.d.ts +78 -22
  81. package/gel-core/query-builders/select.js +84 -43
  82. package/gel-core/query-builders/select.js.map +1 -1
  83. package/gel-core/query-builders/select.types.cjs.map +1 -1
  84. package/gel-core/query-builders/select.types.d.cts +1 -1
  85. package/gel-core/query-builders/select.types.d.ts +1 -1
  86. package/gel-core/query-builders/update.cjs +1 -5
  87. package/gel-core/query-builders/update.cjs.map +1 -1
  88. package/gel-core/query-builders/update.js +1 -5
  89. package/gel-core/query-builders/update.js.map +1 -1
  90. package/gel-core/session.cjs +1 -52
  91. package/gel-core/session.cjs.map +1 -1
  92. package/gel-core/session.d.cts +3 -14
  93. package/gel-core/session.d.ts +3 -14
  94. package/gel-core/session.js +2 -53
  95. package/gel-core/session.js.map +1 -1
  96. package/gel-core/utils.cjs +0 -16
  97. package/gel-core/utils.cjs.map +1 -1
  98. package/gel-core/utils.d.cts +4 -8
  99. package/gel-core/utils.d.ts +4 -8
  100. package/gel-core/utils.js +0 -15
  101. package/gel-core/utils.js.map +1 -1
  102. package/libsql/driver-core.cjs +1 -5
  103. package/libsql/driver-core.cjs.map +1 -1
  104. package/libsql/driver-core.js +1 -5
  105. package/libsql/driver-core.js.map +1 -1
  106. package/libsql/session.cjs +13 -27
  107. package/libsql/session.cjs.map +1 -1
  108. package/libsql/session.d.cts +2 -12
  109. package/libsql/session.d.ts +2 -12
  110. package/libsql/session.js +13 -27
  111. package/libsql/session.js.map +1 -1
  112. package/mysql-core/db.cjs +0 -1
  113. package/mysql-core/db.cjs.map +1 -1
  114. package/mysql-core/db.d.cts +0 -4
  115. package/mysql-core/db.d.ts +0 -4
  116. package/mysql-core/db.js +0 -1
  117. package/mysql-core/db.js.map +1 -1
  118. package/mysql-core/dialect.cjs +5 -4
  119. package/mysql-core/dialect.cjs.map +1 -1
  120. package/mysql-core/dialect.js +5 -4
  121. package/mysql-core/dialect.js.map +1 -1
  122. package/mysql-core/query-builders/delete.cjs +1 -9
  123. package/mysql-core/query-builders/delete.cjs.map +1 -1
  124. package/mysql-core/query-builders/delete.js +1 -9
  125. package/mysql-core/query-builders/delete.js.map +1 -1
  126. package/mysql-core/query-builders/insert.cjs +1 -8
  127. package/mysql-core/query-builders/insert.cjs.map +1 -1
  128. package/mysql-core/query-builders/insert.d.cts +0 -2
  129. package/mysql-core/query-builders/insert.d.ts +0 -2
  130. package/mysql-core/query-builders/insert.js +1 -8
  131. package/mysql-core/query-builders/insert.js.map +1 -1
  132. package/mysql-core/query-builders/select.cjs +75 -61
  133. package/mysql-core/query-builders/select.cjs.map +1 -1
  134. package/mysql-core/query-builders/select.d.cts +66 -34
  135. package/mysql-core/query-builders/select.d.ts +66 -34
  136. package/mysql-core/query-builders/select.js +76 -62
  137. package/mysql-core/query-builders/select.js.map +1 -1
  138. package/mysql-core/query-builders/select.types.cjs.map +1 -1
  139. package/mysql-core/query-builders/select.types.d.cts +5 -4
  140. package/mysql-core/query-builders/select.types.d.ts +5 -4
  141. package/mysql-core/query-builders/update.cjs +1 -11
  142. package/mysql-core/query-builders/update.cjs.map +1 -1
  143. package/mysql-core/query-builders/update.d.cts +0 -2
  144. package/mysql-core/query-builders/update.d.ts +0 -2
  145. package/mysql-core/query-builders/update.js +1 -11
  146. package/mysql-core/query-builders/update.js.map +1 -1
  147. package/mysql-core/session.cjs +0 -53
  148. package/mysql-core/session.cjs.map +1 -1
  149. package/mysql-core/session.d.cts +2 -15
  150. package/mysql-core/session.d.ts +2 -15
  151. package/mysql-core/session.js +1 -54
  152. package/mysql-core/session.js.map +1 -1
  153. package/mysql-core/utils.cjs +0 -16
  154. package/mysql-core/utils.cjs.map +1 -1
  155. package/mysql-core/utils.d.cts +2 -6
  156. package/mysql-core/utils.d.ts +2 -6
  157. package/mysql-core/utils.js +0 -15
  158. package/mysql-core/utils.js.map +1 -1
  159. package/mysql-proxy/session.cjs +5 -15
  160. package/mysql-proxy/session.cjs.map +1 -1
  161. package/mysql-proxy/session.d.cts +2 -12
  162. package/mysql-proxy/session.d.ts +2 -12
  163. package/mysql-proxy/session.js +5 -15
  164. package/mysql-proxy/session.js.map +1 -1
  165. package/mysql2/driver.cjs +2 -10
  166. package/mysql2/driver.cjs.map +1 -1
  167. package/mysql2/driver.d.cts +0 -2
  168. package/mysql2/driver.d.ts +0 -2
  169. package/mysql2/driver.js +2 -10
  170. package/mysql2/driver.js.map +1 -1
  171. package/mysql2/session.cjs +5 -15
  172. package/mysql2/session.cjs.map +1 -1
  173. package/mysql2/session.d.cts +2 -12
  174. package/mysql2/session.d.ts +2 -12
  175. package/mysql2/session.js +5 -15
  176. package/mysql2/session.js.map +1 -1
  177. package/neon-http/driver.cjs +2 -9
  178. package/neon-http/driver.cjs.map +1 -1
  179. package/neon-http/driver.d.cts +0 -2
  180. package/neon-http/driver.d.ts +0 -2
  181. package/neon-http/driver.js +2 -9
  182. package/neon-http/driver.js.map +1 -1
  183. package/neon-http/session.cjs +15 -25
  184. package/neon-http/session.cjs.map +1 -1
  185. package/neon-http/session.d.cts +2 -12
  186. package/neon-http/session.d.ts +2 -12
  187. package/neon-http/session.js +15 -25
  188. package/neon-http/session.js.map +1 -1
  189. package/neon-serverless/driver.cjs +2 -9
  190. package/neon-serverless/driver.cjs.map +1 -1
  191. package/neon-serverless/driver.d.cts +0 -2
  192. package/neon-serverless/driver.d.ts +0 -2
  193. package/neon-serverless/driver.js +2 -9
  194. package/neon-serverless/driver.js.map +1 -1
  195. package/neon-serverless/session.cjs +7 -21
  196. package/neon-serverless/session.cjs.map +1 -1
  197. package/neon-serverless/session.d.cts +2 -12
  198. package/neon-serverless/session.d.ts +2 -12
  199. package/neon-serverless/session.js +7 -21
  200. package/neon-serverless/session.js.map +1 -1
  201. package/node-postgres/driver.cjs +2 -9
  202. package/node-postgres/driver.cjs.map +1 -1
  203. package/node-postgres/driver.d.cts +0 -2
  204. package/node-postgres/driver.d.ts +0 -2
  205. package/node-postgres/driver.js +2 -9
  206. package/node-postgres/driver.js.map +1 -1
  207. package/node-postgres/session.cjs +6 -19
  208. package/node-postgres/session.cjs.map +1 -1
  209. package/node-postgres/session.d.cts +2 -13
  210. package/node-postgres/session.d.ts +2 -13
  211. package/node-postgres/session.js +6 -19
  212. package/node-postgres/session.js.map +1 -1
  213. package/op-sqlite/driver.cjs +1 -5
  214. package/op-sqlite/driver.cjs.map +1 -1
  215. package/op-sqlite/driver.js +1 -5
  216. package/op-sqlite/driver.js.map +1 -1
  217. package/op-sqlite/session.cjs +9 -23
  218. package/op-sqlite/session.cjs.map +1 -1
  219. package/op-sqlite/session.d.cts +2 -12
  220. package/op-sqlite/session.d.ts +2 -12
  221. package/op-sqlite/session.js +9 -23
  222. package/op-sqlite/session.js.map +1 -1
  223. package/operations.cjs.map +1 -1
  224. package/operations.d.cts +5 -1
  225. package/operations.d.ts +5 -1
  226. package/package.json +4 -69
  227. package/pg-core/columns/text.cjs.map +1 -1
  228. package/pg-core/columns/text.d.cts +1 -2
  229. package/pg-core/columns/text.d.ts +1 -2
  230. package/pg-core/columns/text.js.map +1 -1
  231. package/pg-core/db.cjs +0 -1
  232. package/pg-core/db.cjs.map +1 -1
  233. package/pg-core/db.d.cts +0 -4
  234. package/pg-core/db.d.ts +0 -4
  235. package/pg-core/db.js +0 -1
  236. package/pg-core/db.js.map +1 -1
  237. package/pg-core/dialect.cjs +5 -4
  238. package/pg-core/dialect.cjs.map +1 -1
  239. package/pg-core/dialect.js +5 -4
  240. package/pg-core/dialect.js.map +1 -1
  241. package/pg-core/query-builders/delete.cjs +1 -6
  242. package/pg-core/query-builders/delete.cjs.map +1 -1
  243. package/pg-core/query-builders/delete.d.cts +1 -3
  244. package/pg-core/query-builders/delete.d.ts +1 -3
  245. package/pg-core/query-builders/delete.js +1 -6
  246. package/pg-core/query-builders/delete.js.map +1 -1
  247. package/pg-core/query-builders/insert.cjs +1 -6
  248. package/pg-core/query-builders/insert.cjs.map +1 -1
  249. package/pg-core/query-builders/insert.d.cts +0 -2
  250. package/pg-core/query-builders/insert.d.ts +0 -2
  251. package/pg-core/query-builders/insert.js +1 -6
  252. package/pg-core/query-builders/insert.js.map +1 -1
  253. package/pg-core/query-builders/select.cjs +85 -45
  254. package/pg-core/query-builders/select.cjs.map +1 -1
  255. package/pg-core/query-builders/select.d.cts +79 -23
  256. package/pg-core/query-builders/select.d.ts +79 -23
  257. package/pg-core/query-builders/select.js +85 -45
  258. package/pg-core/query-builders/select.js.map +1 -1
  259. package/pg-core/query-builders/select.types.cjs.map +1 -1
  260. package/pg-core/query-builders/select.types.d.cts +1 -1
  261. package/pg-core/query-builders/select.types.d.ts +1 -1
  262. package/pg-core/query-builders/update.cjs +1 -6
  263. package/pg-core/query-builders/update.cjs.map +1 -1
  264. package/pg-core/query-builders/update.d.cts +2 -4
  265. package/pg-core/query-builders/update.d.ts +2 -4
  266. package/pg-core/query-builders/update.js +1 -6
  267. package/pg-core/query-builders/update.js.map +1 -1
  268. package/pg-core/session.cjs +1 -52
  269. package/pg-core/session.cjs.map +1 -1
  270. package/pg-core/session.d.cts +3 -14
  271. package/pg-core/session.d.ts +3 -14
  272. package/pg-core/session.js +2 -53
  273. package/pg-core/session.js.map +1 -1
  274. package/pg-core/utils.cjs +0 -16
  275. package/pg-core/utils.cjs.map +1 -1
  276. package/pg-core/utils.d.cts +4 -8
  277. package/pg-core/utils.d.ts +4 -8
  278. package/pg-core/utils.js +1 -16
  279. package/pg-core/utils.js.map +1 -1
  280. package/pg-proxy/driver.cjs +2 -7
  281. package/pg-proxy/driver.cjs.map +1 -1
  282. package/pg-proxy/driver.js +2 -7
  283. package/pg-proxy/driver.js.map +1 -1
  284. package/pg-proxy/session.cjs +5 -15
  285. package/pg-proxy/session.cjs.map +1 -1
  286. package/pg-proxy/session.d.cts +2 -12
  287. package/pg-proxy/session.d.ts +2 -12
  288. package/pg-proxy/session.js +5 -15
  289. package/pg-proxy/session.js.map +1 -1
  290. package/pglite/driver.cjs +2 -9
  291. package/pglite/driver.cjs.map +1 -1
  292. package/pglite/driver.d.cts +0 -2
  293. package/pglite/driver.d.ts +0 -2
  294. package/pglite/driver.js +2 -9
  295. package/pglite/driver.js.map +1 -1
  296. package/pglite/session.cjs +7 -19
  297. package/pglite/session.cjs.map +1 -1
  298. package/pglite/session.d.cts +2 -12
  299. package/pglite/session.d.ts +2 -12
  300. package/pglite/session.js +7 -19
  301. package/pglite/session.js.map +1 -1
  302. package/planetscale-serverless/driver.cjs +1 -5
  303. package/planetscale-serverless/driver.cjs.map +1 -1
  304. package/planetscale-serverless/driver.d.cts +0 -1
  305. package/planetscale-serverless/driver.d.ts +0 -1
  306. package/planetscale-serverless/driver.js +1 -5
  307. package/planetscale-serverless/driver.js.map +1 -1
  308. package/planetscale-serverless/session.cjs +5 -15
  309. package/planetscale-serverless/session.cjs.map +1 -1
  310. package/planetscale-serverless/session.d.cts +2 -12
  311. package/planetscale-serverless/session.d.ts +2 -12
  312. package/planetscale-serverless/session.js +5 -15
  313. package/planetscale-serverless/session.js.map +1 -1
  314. package/postgres-js/driver.cjs +1 -5
  315. package/postgres-js/driver.cjs.map +1 -1
  316. package/postgres-js/driver.js +1 -5
  317. package/postgres-js/driver.js.map +1 -1
  318. package/postgres-js/session.cjs +6 -18
  319. package/postgres-js/session.cjs.map +1 -1
  320. package/postgres-js/session.d.cts +2 -12
  321. package/postgres-js/session.d.ts +2 -12
  322. package/postgres-js/session.js +6 -18
  323. package/postgres-js/session.js.map +1 -1
  324. package/prisma/mysql/session.cjs +1 -1
  325. package/prisma/mysql/session.cjs.map +1 -1
  326. package/prisma/mysql/session.js +1 -1
  327. package/prisma/mysql/session.js.map +1 -1
  328. package/prisma/pg/session.cjs +1 -1
  329. package/prisma/pg/session.cjs.map +1 -1
  330. package/prisma/pg/session.js +1 -1
  331. package/prisma/pg/session.js.map +1 -1
  332. package/query-builders/query-builder.cjs.map +1 -1
  333. package/query-builders/query-builder.d.cts +1 -2
  334. package/query-builders/query-builder.d.ts +1 -2
  335. package/query-builders/query-builder.js.map +1 -1
  336. package/query-builders/select.types.cjs.map +1 -1
  337. package/query-builders/select.types.d.cts +3 -1
  338. package/query-builders/select.types.d.ts +3 -1
  339. package/singlestore/driver.cjs +26 -14
  340. package/singlestore/driver.cjs.map +1 -1
  341. package/singlestore/driver.d.cts +3 -7
  342. package/singlestore/driver.d.ts +3 -7
  343. package/singlestore/driver.js +26 -14
  344. package/singlestore/driver.js.map +1 -1
  345. package/singlestore/session.cjs +5 -15
  346. package/singlestore/session.cjs.map +1 -1
  347. package/singlestore/session.d.cts +2 -12
  348. package/singlestore/session.d.ts +2 -12
  349. package/singlestore/session.js +5 -15
  350. package/singlestore/session.js.map +1 -1
  351. package/singlestore-core/db.cjs +0 -1
  352. package/singlestore-core/db.cjs.map +1 -1
  353. package/singlestore-core/db.d.cts +0 -4
  354. package/singlestore-core/db.d.ts +0 -4
  355. package/singlestore-core/db.js +0 -1
  356. package/singlestore-core/db.js.map +1 -1
  357. package/singlestore-core/dialect.cjs +5 -4
  358. package/singlestore-core/dialect.cjs.map +1 -1
  359. package/singlestore-core/dialect.js +5 -4
  360. package/singlestore-core/dialect.js.map +1 -1
  361. package/singlestore-core/query-builders/delete.cjs +1 -9
  362. package/singlestore-core/query-builders/delete.cjs.map +1 -1
  363. package/singlestore-core/query-builders/delete.js +1 -9
  364. package/singlestore-core/query-builders/delete.js.map +1 -1
  365. package/singlestore-core/query-builders/insert.cjs +1 -6
  366. package/singlestore-core/query-builders/insert.cjs.map +1 -1
  367. package/singlestore-core/query-builders/insert.js +1 -6
  368. package/singlestore-core/query-builders/insert.js.map +1 -1
  369. package/singlestore-core/query-builders/select.cjs +83 -42
  370. package/singlestore-core/query-builders/select.cjs.map +1 -1
  371. package/singlestore-core/query-builders/select.d.cts +78 -22
  372. package/singlestore-core/query-builders/select.d.ts +78 -22
  373. package/singlestore-core/query-builders/select.js +83 -42
  374. package/singlestore-core/query-builders/select.js.map +1 -1
  375. package/singlestore-core/query-builders/select.types.cjs.map +1 -1
  376. package/singlestore-core/query-builders/select.types.d.cts +1 -2
  377. package/singlestore-core/query-builders/select.types.d.ts +1 -2
  378. package/singlestore-core/query-builders/update.cjs +1 -9
  379. package/singlestore-core/query-builders/update.cjs.map +1 -1
  380. package/singlestore-core/query-builders/update.js +1 -9
  381. package/singlestore-core/query-builders/update.js.map +1 -1
  382. package/singlestore-core/session.cjs +0 -53
  383. package/singlestore-core/session.cjs.map +1 -1
  384. package/singlestore-core/session.d.cts +2 -14
  385. package/singlestore-core/session.d.ts +2 -14
  386. package/singlestore-core/session.js +1 -54
  387. package/singlestore-core/session.js.map +1 -1
  388. package/singlestore-core/utils.cjs +0 -16
  389. package/singlestore-core/utils.cjs.map +1 -1
  390. package/singlestore-core/utils.d.cts +0 -3
  391. package/singlestore-core/utils.d.ts +0 -3
  392. package/singlestore-core/utils.js +0 -15
  393. package/singlestore-core/utils.js.map +1 -1
  394. package/sql/sql.cjs +0 -10
  395. package/sql/sql.cjs.map +1 -1
  396. package/sql/sql.js +0 -10
  397. package/sql/sql.js.map +1 -1
  398. package/sqlite-core/db.cjs +0 -1
  399. package/sqlite-core/db.cjs.map +1 -1
  400. package/sqlite-core/db.d.cts +0 -4
  401. package/sqlite-core/db.d.ts +0 -4
  402. package/sqlite-core/db.js +0 -1
  403. package/sqlite-core/db.js.map +1 -1
  404. package/sqlite-core/dialect.cjs +3 -2
  405. package/sqlite-core/dialect.cjs.map +1 -1
  406. package/sqlite-core/dialect.js +3 -2
  407. package/sqlite-core/dialect.js.map +1 -1
  408. package/sqlite-core/query-builders/delete.cjs +1 -7
  409. package/sqlite-core/query-builders/delete.cjs.map +1 -1
  410. package/sqlite-core/query-builders/delete.js +1 -7
  411. package/sqlite-core/query-builders/delete.js.map +1 -1
  412. package/sqlite-core/query-builders/insert.cjs +1 -7
  413. package/sqlite-core/query-builders/insert.cjs.map +1 -1
  414. package/sqlite-core/query-builders/insert.js +1 -7
  415. package/sqlite-core/query-builders/insert.js.map +1 -1
  416. package/sqlite-core/query-builders/select.cjs +39 -39
  417. package/sqlite-core/query-builders/select.cjs.map +1 -1
  418. package/sqlite-core/query-builders/select.d.cts +40 -22
  419. package/sqlite-core/query-builders/select.d.ts +40 -22
  420. package/sqlite-core/query-builders/select.js +39 -39
  421. package/sqlite-core/query-builders/select.js.map +1 -1
  422. package/sqlite-core/query-builders/select.types.cjs.map +1 -1
  423. package/sqlite-core/query-builders/select.types.d.cts +1 -1
  424. package/sqlite-core/query-builders/select.types.d.ts +1 -1
  425. package/sqlite-core/query-builders/update.cjs +1 -7
  426. package/sqlite-core/query-builders/update.cjs.map +1 -1
  427. package/sqlite-core/query-builders/update.js +1 -7
  428. package/sqlite-core/query-builders/update.js.map +1 -1
  429. package/sqlite-core/session.cjs +3 -62
  430. package/sqlite-core/session.cjs.map +1 -1
  431. package/sqlite-core/session.d.cts +4 -18
  432. package/sqlite-core/session.d.ts +4 -18
  433. package/sqlite-core/session.js +4 -63
  434. package/sqlite-core/session.js.map +1 -1
  435. package/sqlite-core/utils.cjs +0 -16
  436. package/sqlite-core/utils.cjs.map +1 -1
  437. package/sqlite-core/utils.d.cts +2 -6
  438. package/sqlite-core/utils.d.ts +2 -6
  439. package/sqlite-core/utils.js +0 -15
  440. package/sqlite-core/utils.js.map +1 -1
  441. package/sqlite-proxy/driver.cjs +2 -9
  442. package/sqlite-proxy/driver.cjs.map +1 -1
  443. package/sqlite-proxy/driver.js +2 -9
  444. package/sqlite-proxy/driver.js.map +1 -1
  445. package/sqlite-proxy/session.cjs +8 -22
  446. package/sqlite-proxy/session.cjs.map +1 -1
  447. package/sqlite-proxy/session.d.cts +2 -12
  448. package/sqlite-proxy/session.d.ts +2 -12
  449. package/sqlite-proxy/session.js +8 -22
  450. package/sqlite-proxy/session.js.map +1 -1
  451. package/subquery.cjs +3 -4
  452. package/subquery.cjs.map +1 -1
  453. package/subquery.d.cts +1 -2
  454. package/subquery.d.ts +1 -2
  455. package/subquery.js +3 -4
  456. package/subquery.js.map +1 -1
  457. package/tidb-serverless/driver.cjs +1 -5
  458. package/tidb-serverless/driver.cjs.map +1 -1
  459. package/tidb-serverless/driver.d.cts +0 -1
  460. package/tidb-serverless/driver.d.ts +0 -1
  461. package/tidb-serverless/driver.js +1 -5
  462. package/tidb-serverless/driver.js.map +1 -1
  463. package/tidb-serverless/session.cjs +5 -15
  464. package/tidb-serverless/session.cjs.map +1 -1
  465. package/tidb-serverless/session.d.cts +2 -12
  466. package/tidb-serverless/session.d.ts +2 -12
  467. package/tidb-serverless/session.js +5 -15
  468. package/tidb-serverless/session.js.map +1 -1
  469. package/utils.cjs +0 -22
  470. package/utils.cjs.map +1 -1
  471. package/utils.d.cts +0 -3
  472. package/utils.d.ts +0 -3
  473. package/utils.js +0 -11
  474. package/utils.js.map +1 -1
  475. package/vercel-postgres/driver.cjs +2 -9
  476. package/vercel-postgres/driver.cjs.map +1 -1
  477. package/vercel-postgres/driver.d.cts +0 -2
  478. package/vercel-postgres/driver.d.ts +0 -2
  479. package/vercel-postgres/driver.js +2 -9
  480. package/vercel-postgres/driver.js.map +1 -1
  481. package/vercel-postgres/session.cjs +7 -21
  482. package/vercel-postgres/session.cjs.map +1 -1
  483. package/vercel-postgres/session.d.cts +2 -12
  484. package/vercel-postgres/session.d.ts +2 -12
  485. package/vercel-postgres/session.js +7 -21
  486. package/vercel-postgres/session.js.map +1 -1
  487. package/version.cjs +1 -1
  488. package/version.d.cts +1 -1
  489. package/version.d.ts +1 -1
  490. package/version.js +1 -1
  491. package/xata-http/driver.cjs +2 -7
  492. package/xata-http/driver.cjs.map +1 -1
  493. package/xata-http/driver.d.cts +0 -2
  494. package/xata-http/driver.d.ts +0 -2
  495. package/xata-http/driver.js +2 -7
  496. package/xata-http/driver.js.map +1 -1
  497. package/xata-http/session.cjs +7 -21
  498. package/xata-http/session.cjs.map +1 -1
  499. package/xata-http/session.d.cts +2 -12
  500. package/xata-http/session.d.ts +2 -12
  501. package/xata-http/session.js +7 -21
  502. package/xata-http/session.js.map +1 -1
  503. package/cache/core/cache.cjs +0 -47
  504. package/cache/core/cache.cjs.map +0 -1
  505. package/cache/core/cache.d.cts +0 -35
  506. package/cache/core/cache.d.ts +0 -35
  507. package/cache/core/cache.js +0 -22
  508. package/cache/core/cache.js.map +0 -1
  509. package/cache/core/index.cjs +0 -23
  510. package/cache/core/index.cjs.map +0 -1
  511. package/cache/core/index.d.cts +0 -1
  512. package/cache/core/index.d.ts +0 -1
  513. package/cache/core/index.js +0 -2
  514. package/cache/core/index.js.map +0 -1
  515. package/cache/core/types.cjs +0 -17
  516. package/cache/core/types.cjs.map +0 -1
  517. package/cache/core/types.d.cts +0 -33
  518. package/cache/core/types.d.ts +0 -33
  519. package/cache/core/types.js +0 -1
  520. package/cache/core/types.js.map +0 -1
  521. package/cache/upstash/cache.cjs +0 -148
  522. package/cache/upstash/cache.cjs.map +0 -1
  523. package/cache/upstash/cache.d.cts +0 -29
  524. package/cache/upstash/cache.d.ts +0 -29
  525. package/cache/upstash/cache.js +0 -123
  526. package/cache/upstash/cache.js.map +0 -1
  527. package/cache/upstash/index.cjs +0 -23
  528. package/cache/upstash/index.cjs.map +0 -1
  529. package/cache/upstash/index.d.cts +0 -1
  530. package/cache/upstash/index.d.ts +0 -1
  531. package/cache/upstash/index.js +0 -2
  532. package/cache/upstash/index.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/mysql-core/query-builders/insert.ts"],"sourcesContent":["import type { WithCacheConfig } from '~/cache/core/types.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport type { MySqlDialect } from '~/mysql-core/dialect.ts';\nimport type {\n\tAnyMySqlQueryResultHKT,\n\tMySqlPreparedQueryConfig,\n\tMySqlQueryResultHKT,\n\tMySqlQueryResultKind,\n\tMySqlSession,\n\tPreparedQueryHKTBase,\n\tPreparedQueryKind,\n} from '~/mysql-core/session.ts';\nimport type { MySqlTable } from '~/mysql-core/table.ts';\nimport type { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport type { Placeholder, Query, SQLWrapper } from '~/sql/sql.ts';\nimport { Param, SQL, sql } from '~/sql/sql.ts';\nimport type { InferModelFromColumns } from '~/table.ts';\nimport { Columns, Table } from '~/table.ts';\nimport { haveSameKeys, mapUpdateSet } from '~/utils.ts';\nimport type { AnyMySqlColumn } from '../columns/common.ts';\nimport { extractUsedTable } from '../utils.ts';\nimport { QueryBuilder } from './query-builder.ts';\nimport type { SelectedFieldsOrdered } from './select.types.ts';\nimport type { MySqlUpdateSetSource } from './update.ts';\n\nexport interface MySqlInsertConfig<TTable extends MySqlTable = MySqlTable> {\n\ttable: TTable;\n\tvalues: Record<string, Param | SQL>[] | MySqlInsertSelectQueryBuilder<TTable> | SQL;\n\tignore: boolean;\n\tonConflict?: SQL;\n\treturning?: SelectedFieldsOrdered;\n\tselect?: boolean;\n}\n\nexport type AnyMySqlInsertConfig = MySqlInsertConfig<MySqlTable>;\n\nexport type MySqlInsertValue<TTable extends MySqlTable> =\n\t& {\n\t\t[Key in keyof TTable['$inferInsert']]: TTable['$inferInsert'][Key] | SQL | Placeholder;\n\t}\n\t& {};\n\nexport type MySqlInsertSelectQueryBuilder<TTable extends MySqlTable> = TypedQueryBuilder<\n\t{ [K in keyof TTable['$inferInsert']]: AnyMySqlColumn | SQL | SQL.Aliased | TTable['$inferInsert'][K] }\n>;\n\nexport class MySqlInsertBuilder<\n\tTTable extends MySqlTable,\n\tTQueryResult extends MySqlQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n> {\n\tstatic readonly [entityKind]: string = 'MySqlInsertBuilder';\n\n\tprivate shouldIgnore = false;\n\n\tconstructor(\n\t\tprivate table: TTable,\n\t\tprivate session: MySqlSession,\n\t\tprivate dialect: MySqlDialect,\n\t) {}\n\n\tignore(): this {\n\t\tthis.shouldIgnore = true;\n\t\treturn this;\n\t}\n\n\tvalues(value: MySqlInsertValue<TTable>): MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tvalues(values: MySqlInsertValue<TTable>[]): MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tvalues(\n\t\tvalues: MySqlInsertValue<TTable> | MySqlInsertValue<TTable>[],\n\t): MySqlInsertBase<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 MySqlInsertBase(this.table, mappedValues, this.shouldIgnore, this.session, this.dialect);\n\t}\n\n\tselect(\n\t\tselectQuery: (qb: QueryBuilder) => MySqlInsertSelectQueryBuilder<TTable>,\n\t): MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tselect(selectQuery: (qb: QueryBuilder) => SQL): MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tselect(selectQuery: SQL): MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tselect(selectQuery: MySqlInsertSelectQueryBuilder<TTable>): MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tselect(\n\t\tselectQuery:\n\t\t\t| SQL\n\t\t\t| MySqlInsertSelectQueryBuilder<TTable>\n\t\t\t| ((qb: QueryBuilder) => MySqlInsertSelectQueryBuilder<TTable> | SQL),\n\t): MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT> {\n\t\tconst select = typeof selectQuery === 'function' ? selectQuery(new QueryBuilder()) : selectQuery;\n\n\t\tif (\n\t\t\t!is(select, SQL)\n\t\t\t&& !haveSameKeys(this.table[Columns], select._.selectedFields)\n\t\t) {\n\t\t\tthrow new Error(\n\t\t\t\t'Insert select error: selected fields are not the same or are in a different order compared to the table definition',\n\t\t\t);\n\t\t}\n\n\t\treturn new MySqlInsertBase(this.table, select, this.shouldIgnore, this.session, this.dialect, true);\n\t}\n}\n\nexport type MySqlInsertWithout<T extends AnyMySqlInsert, TDynamic extends boolean, K extends keyof T & string> =\n\tTDynamic extends true ? T\n\t\t: Omit<\n\t\t\tMySqlInsertBase<\n\t\t\t\tT['_']['table'],\n\t\t\t\tT['_']['queryResult'],\n\t\t\t\tT['_']['preparedQueryHKT'],\n\t\t\t\tT['_']['returning'],\n\t\t\t\tTDynamic,\n\t\t\t\tT['_']['excludedMethods'] | '$returning'\n\t\t\t>,\n\t\t\tT['_']['excludedMethods'] | K\n\t\t>;\n\nexport type MySqlInsertDynamic<T extends AnyMySqlInsert> = MySqlInsert<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['preparedQueryHKT'],\n\tT['_']['returning']\n>;\n\nexport type MySqlInsertPrepare<\n\tT extends AnyMySqlInsert,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n> = PreparedQueryKind<\n\tT['_']['preparedQueryHKT'],\n\tMySqlPreparedQueryConfig & {\n\t\texecute: TReturning extends undefined ? MySqlQueryResultKind<T['_']['queryResult'], never> : TReturning[];\n\t\titerator: never;\n\t},\n\ttrue\n>;\n\nexport type MySqlInsertOnDuplicateKeyUpdateConfig<T extends AnyMySqlInsert> = {\n\tset: MySqlUpdateSetSource<T['_']['table']>;\n};\n\nexport type MySqlInsert<\n\tTTable extends MySqlTable = MySqlTable,\n\tTQueryResult extends MySqlQueryResultHKT = AnyMySqlQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase = PreparedQueryHKTBase,\n\tTReturning extends Record<string, unknown> | undefined = Record<string, unknown> | undefined,\n> = MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT, TReturning, true, never>;\n\nexport type MySqlInsertReturning<\n\tT extends AnyMySqlInsert,\n\tTDynamic extends boolean,\n> = MySqlInsertBase<\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 AnyMySqlInsert = MySqlInsertBase<any, any, any, any, any, any>;\n\nexport interface MySqlInsertBase<\n\tTTable extends MySqlTable,\n\tTQueryResult extends MySqlQueryResultHKT,\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 ? MySqlQueryResultKind<TQueryResult, never> : TReturning[]>,\n\tRunnableQuery<TReturning extends undefined ? MySqlQueryResultKind<TQueryResult, never> : TReturning[], 'mysql'>,\n\tSQLWrapper\n{\n\treadonly _: {\n\t\treadonly dialect: 'mysql';\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 ? MySqlQueryResultKind<TQueryResult, never> : TReturning[];\n\t};\n}\n\nexport type PrimaryKeyKeys<T extends Record<string, AnyMySqlColumn>> = {\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, AnyMySqlColumn>> = {\n\t[K in PrimaryKeyKeys<T>]: T[K];\n};\n\nexport class MySqlInsertBase<\n\tTTable extends MySqlTable,\n\tTQueryResult extends MySqlQueryResultHKT,\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 ? MySqlQueryResultKind<TQueryResult, never> : TReturning[]>\n\timplements\n\t\tRunnableQuery<TReturning extends undefined ? MySqlQueryResultKind<TQueryResult, never> : TReturning[], 'mysql'>,\n\t\tSQLWrapper\n{\n\tstatic override readonly [entityKind]: string = 'MySqlInsert';\n\n\tdeclare protected $table: TTable;\n\n\tprivate config: MySqlInsertConfig<TTable>;\n\tprotected cacheConfig?: WithCacheConfig;\n\n\tconstructor(\n\t\ttable: TTable,\n\t\tvalues: MySqlInsertConfig['values'],\n\t\tignore: boolean,\n\t\tprivate session: MySqlSession,\n\t\tprivate dialect: MySqlDialect,\n\t\tselect?: boolean,\n\t) {\n\t\tsuper();\n\t\tthis.config = { table, values: values as any, select, 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 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: MySqlInsertOnDuplicateKeyUpdateConfig<this>,\n\t): MySqlInsertWithout<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(): MySqlInsertWithout<\n\t\tMySqlInsertReturning<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 = returning;\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(): MySqlInsertPrepare<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: 'insert',\n\t\t\t\ttables: extractUsedTable(this.config.table),\n\t\t\t},\n\t\t\tthis.cacheConfig,\n\t\t) as MySqlInsertPrepare<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(): MySqlInsertDynamic<this> {\n\t\treturn this as any;\n\t}\n}\n"],"mappings":"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","names":["sql"]}
1
+ {"version":3,"sources":["../../../src/mysql-core/query-builders/insert.ts"],"sourcesContent":["import { entityKind, is } from '~/entity.ts';\nimport type { MySqlDialect } from '~/mysql-core/dialect.ts';\nimport type {\n\tAnyMySqlQueryResultHKT,\n\tMySqlPreparedQueryConfig,\n\tMySqlQueryResultHKT,\n\tMySqlQueryResultKind,\n\tMySqlSession,\n\tPreparedQueryHKTBase,\n\tPreparedQueryKind,\n} from '~/mysql-core/session.ts';\nimport type { MySqlTable } from '~/mysql-core/table.ts';\nimport type { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport type { Placeholder, Query, SQLWrapper } from '~/sql/sql.ts';\nimport { Param, SQL, sql } from '~/sql/sql.ts';\nimport type { InferModelFromColumns } from '~/table.ts';\nimport { Columns, Table } from '~/table.ts';\nimport { haveSameKeys, mapUpdateSet } from '~/utils.ts';\nimport type { AnyMySqlColumn } from '../columns/common.ts';\nimport { QueryBuilder } from './query-builder.ts';\nimport type { SelectedFieldsOrdered } from './select.types.ts';\nimport type { MySqlUpdateSetSource } from './update.ts';\n\nexport interface MySqlInsertConfig<TTable extends MySqlTable = MySqlTable> {\n\ttable: TTable;\n\tvalues: Record<string, Param | SQL>[] | MySqlInsertSelectQueryBuilder<TTable> | SQL;\n\tignore: boolean;\n\tonConflict?: SQL;\n\treturning?: SelectedFieldsOrdered;\n\tselect?: boolean;\n}\n\nexport type AnyMySqlInsertConfig = MySqlInsertConfig<MySqlTable>;\n\nexport type MySqlInsertValue<TTable extends MySqlTable> =\n\t& {\n\t\t[Key in keyof TTable['$inferInsert']]: TTable['$inferInsert'][Key] | SQL | Placeholder;\n\t}\n\t& {};\n\nexport type MySqlInsertSelectQueryBuilder<TTable extends MySqlTable> = TypedQueryBuilder<\n\t{ [K in keyof TTable['$inferInsert']]: AnyMySqlColumn | SQL | SQL.Aliased | TTable['$inferInsert'][K] }\n>;\n\nexport class MySqlInsertBuilder<\n\tTTable extends MySqlTable,\n\tTQueryResult extends MySqlQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase,\n> {\n\tstatic readonly [entityKind]: string = 'MySqlInsertBuilder';\n\n\tprivate shouldIgnore = false;\n\n\tconstructor(\n\t\tprivate table: TTable,\n\t\tprivate session: MySqlSession,\n\t\tprivate dialect: MySqlDialect,\n\t) {}\n\n\tignore(): this {\n\t\tthis.shouldIgnore = true;\n\t\treturn this;\n\t}\n\n\tvalues(value: MySqlInsertValue<TTable>): MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tvalues(values: MySqlInsertValue<TTable>[]): MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tvalues(\n\t\tvalues: MySqlInsertValue<TTable> | MySqlInsertValue<TTable>[],\n\t): MySqlInsertBase<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 MySqlInsertBase(this.table, mappedValues, this.shouldIgnore, this.session, this.dialect);\n\t}\n\n\tselect(\n\t\tselectQuery: (qb: QueryBuilder) => MySqlInsertSelectQueryBuilder<TTable>,\n\t): MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tselect(selectQuery: (qb: QueryBuilder) => SQL): MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tselect(selectQuery: SQL): MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tselect(selectQuery: MySqlInsertSelectQueryBuilder<TTable>): MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT>;\n\tselect(\n\t\tselectQuery:\n\t\t\t| SQL\n\t\t\t| MySqlInsertSelectQueryBuilder<TTable>\n\t\t\t| ((qb: QueryBuilder) => MySqlInsertSelectQueryBuilder<TTable> | SQL),\n\t): MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT> {\n\t\tconst select = typeof selectQuery === 'function' ? selectQuery(new QueryBuilder()) : selectQuery;\n\n\t\tif (\n\t\t\t!is(select, SQL)\n\t\t\t&& !haveSameKeys(this.table[Columns], select._.selectedFields)\n\t\t) {\n\t\t\tthrow new Error(\n\t\t\t\t'Insert select error: selected fields are not the same or are in a different order compared to the table definition',\n\t\t\t);\n\t\t}\n\n\t\treturn new MySqlInsertBase(this.table, select, this.shouldIgnore, this.session, this.dialect, true);\n\t}\n}\n\nexport type MySqlInsertWithout<T extends AnyMySqlInsert, TDynamic extends boolean, K extends keyof T & string> =\n\tTDynamic extends true ? T\n\t\t: Omit<\n\t\t\tMySqlInsertBase<\n\t\t\t\tT['_']['table'],\n\t\t\t\tT['_']['queryResult'],\n\t\t\t\tT['_']['preparedQueryHKT'],\n\t\t\t\tT['_']['returning'],\n\t\t\t\tTDynamic,\n\t\t\t\tT['_']['excludedMethods'] | '$returning'\n\t\t\t>,\n\t\t\tT['_']['excludedMethods'] | K\n\t\t>;\n\nexport type MySqlInsertDynamic<T extends AnyMySqlInsert> = MySqlInsert<\n\tT['_']['table'],\n\tT['_']['queryResult'],\n\tT['_']['preparedQueryHKT'],\n\tT['_']['returning']\n>;\n\nexport type MySqlInsertPrepare<\n\tT extends AnyMySqlInsert,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n> = PreparedQueryKind<\n\tT['_']['preparedQueryHKT'],\n\tMySqlPreparedQueryConfig & {\n\t\texecute: TReturning extends undefined ? MySqlQueryResultKind<T['_']['queryResult'], never> : TReturning[];\n\t\titerator: never;\n\t},\n\ttrue\n>;\n\nexport type MySqlInsertOnDuplicateKeyUpdateConfig<T extends AnyMySqlInsert> = {\n\tset: MySqlUpdateSetSource<T['_']['table']>;\n};\n\nexport type MySqlInsert<\n\tTTable extends MySqlTable = MySqlTable,\n\tTQueryResult extends MySqlQueryResultHKT = AnyMySqlQueryResultHKT,\n\tTPreparedQueryHKT extends PreparedQueryHKTBase = PreparedQueryHKTBase,\n\tTReturning extends Record<string, unknown> | undefined = Record<string, unknown> | undefined,\n> = MySqlInsertBase<TTable, TQueryResult, TPreparedQueryHKT, TReturning, true, never>;\n\nexport type MySqlInsertReturning<\n\tT extends AnyMySqlInsert,\n\tTDynamic extends boolean,\n> = MySqlInsertBase<\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 AnyMySqlInsert = MySqlInsertBase<any, any, any, any, any, any>;\n\nexport interface MySqlInsertBase<\n\tTTable extends MySqlTable,\n\tTQueryResult extends MySqlQueryResultHKT,\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 ? MySqlQueryResultKind<TQueryResult, never> : TReturning[]>,\n\tRunnableQuery<TReturning extends undefined ? MySqlQueryResultKind<TQueryResult, never> : TReturning[], 'mysql'>,\n\tSQLWrapper\n{\n\treadonly _: {\n\t\treadonly dialect: 'mysql';\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 ? MySqlQueryResultKind<TQueryResult, never> : TReturning[];\n\t};\n}\n\nexport type PrimaryKeyKeys<T extends Record<string, AnyMySqlColumn>> = {\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, AnyMySqlColumn>> = {\n\t[K in PrimaryKeyKeys<T>]: T[K];\n};\n\nexport class MySqlInsertBase<\n\tTTable extends MySqlTable,\n\tTQueryResult extends MySqlQueryResultHKT,\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 ? MySqlQueryResultKind<TQueryResult, never> : TReturning[]>\n\timplements\n\t\tRunnableQuery<TReturning extends undefined ? MySqlQueryResultKind<TQueryResult, never> : TReturning[], 'mysql'>,\n\t\tSQLWrapper\n{\n\tstatic override readonly [entityKind]: string = 'MySqlInsert';\n\n\tdeclare protected $table: TTable;\n\n\tprivate config: MySqlInsertConfig<TTable>;\n\n\tconstructor(\n\t\ttable: TTable,\n\t\tvalues: MySqlInsertConfig['values'],\n\t\tignore: boolean,\n\t\tprivate session: MySqlSession,\n\t\tprivate dialect: MySqlDialect,\n\t\tselect?: boolean,\n\t) {\n\t\tsuper();\n\t\tthis.config = { table, values: values as any, select, 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 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: MySqlInsertOnDuplicateKeyUpdateConfig<this>,\n\t): MySqlInsertWithout<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(): MySqlInsertWithout<\n\t\tMySqlInsertReturning<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 = returning;\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(): MySqlInsertPrepare<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) as MySqlInsertPrepare<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(): MySqlInsertDynamic<this> {\n\t\treturn this as any;\n\t}\n}\n"],"mappings":"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","names":["sql"]}
@@ -113,8 +113,6 @@ class MySqlSelectQueryBuilderBase extends import_query_builder.TypedQueryBuilder
113
113
  /** @internal */
114
114
  session;
115
115
  dialect;
116
- cacheConfig = void 0;
117
- usedTables = /* @__PURE__ */ new Set();
118
116
  constructor({ table, fields, isPartialSelect, session, dialect, withList, distinct, useIndex, forceIndex, ignoreIndex }) {
119
117
  super();
120
118
  this.config = {
@@ -131,24 +129,18 @@ class MySqlSelectQueryBuilderBase extends import_query_builder.TypedQueryBuilder
131
129
  this.session = session;
132
130
  this.dialect = dialect;
133
131
  this._ = {
134
- selectedFields: fields,
135
- config: this.config
132
+ selectedFields: fields
136
133
  };
137
134
  this.tableName = (0, import_utils.getTableLikeName)(table);
138
135
  this.joinsNotNullableMap = typeof this.tableName === "string" ? { [this.tableName]: true } : {};
139
- for (const item of (0, import_utils2.extractUsedTable)(table))
140
- this.usedTables.add(item);
141
136
  }
142
- /** @internal */
143
- getUsedTables() {
144
- return [...this.usedTables];
145
- }
146
- createJoin(joinType) {
147
- return (table, on, onIndex) => {
137
+ createJoin(joinType, lateral) {
138
+ return (table, a, b) => {
139
+ const isCrossJoin = joinType === "cross";
140
+ let on = isCrossJoin ? void 0 : a;
141
+ const onIndex = isCrossJoin ? a : b;
148
142
  const baseTableName = this.tableName;
149
143
  const tableName = (0, import_utils.getTableLikeName)(table);
150
- for (const item of (0, import_utils2.extractUsedTable)(table))
151
- this.usedTables.add(item);
152
144
  if (typeof tableName === "string" && this.config.joins?.some((join) => join.alias === tableName)) {
153
145
  throw new Error(`Alias "${tableName}" is already used in this query`);
154
146
  }
@@ -188,7 +180,7 @@ class MySqlSelectQueryBuilderBase extends import_query_builder.TypedQueryBuilder
188
180
  ignoreIndex = (0, import_utils2.convertIndexToString)((0, import_utils2.toArray)(onIndex.ignoreIndex));
189
181
  }
190
182
  }
191
- this.config.joins.push({ on, table, joinType, alias: tableName, useIndex, forceIndex, ignoreIndex });
183
+ this.config.joins.push({ on, table, joinType, alias: tableName, useIndex, forceIndex, ignoreIndex, lateral });
192
184
  if (typeof tableName === "string") {
193
185
  switch (joinType) {
194
186
  case "left": {
@@ -202,17 +194,11 @@ class MySqlSelectQueryBuilderBase extends import_query_builder.TypedQueryBuilder
202
194
  this.joinsNotNullableMap[tableName] = true;
203
195
  break;
204
196
  }
197
+ case "cross":
205
198
  case "inner": {
206
199
  this.joinsNotNullableMap[tableName] = true;
207
200
  break;
208
201
  }
209
- case "full": {
210
- this.joinsNotNullableMap = Object.fromEntries(
211
- Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false])
212
- );
213
- this.joinsNotNullableMap[tableName] = false;
214
- break;
215
- }
216
202
  }
217
203
  }
218
204
  return this;
@@ -227,17 +213,18 @@ class MySqlSelectQueryBuilderBase extends import_query_builder.TypedQueryBuilder
227
213
  *
228
214
  * @param table the table to join.
229
215
  * @param on the `on` clause.
216
+ * @param onIndex index hint.
230
217
  *
231
218
  * @example
232
219
  *
233
220
  * ```ts
234
221
  * // Select all users and their pets
235
- * const usersWithPets: { user: User; pets: Pet | null }[] = await db.select()
222
+ * const usersWithPets: { user: User; pets: Pet | null; }[] = await db.select()
236
223
  * .from(users)
237
224
  * .leftJoin(pets, eq(users.id, pets.ownerId))
238
225
  *
239
226
  * // Select userId and petId
240
- * const usersIdsAndPetIds: { userId: number; petId: number | null }[] = await db.select({
227
+ * const usersIdsAndPetIds: { userId: number; petId: number | null; }[] = await db.select({
241
228
  * userId: users.id,
242
229
  * petId: pets.id,
243
230
  * })
@@ -245,7 +232,7 @@ class MySqlSelectQueryBuilderBase extends import_query_builder.TypedQueryBuilder
245
232
  * .leftJoin(pets, eq(users.id, pets.ownerId))
246
233
  *
247
234
  * // Select userId and petId with use index hint
248
- * const usersIdsAndPetIds: { userId: number; petId: number | null }[] = await db.select({
235
+ * const usersIdsAndPetIds: { userId: number; petId: number | null; }[] = await db.select({
249
236
  * userId: users.id,
250
237
  * petId: pets.id,
251
238
  * })
@@ -255,7 +242,20 @@ class MySqlSelectQueryBuilderBase extends import_query_builder.TypedQueryBuilder
255
242
  * })
256
243
  * ```
257
244
  */
258
- leftJoin = this.createJoin("left");
245
+ leftJoin = this.createJoin("left", false);
246
+ /**
247
+ * Executes a `left join lateral` operation by adding subquery to the current query.
248
+ *
249
+ * A `lateral` join allows the right-hand expression to refer to columns from the left-hand side.
250
+ *
251
+ * 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.
252
+ *
253
+ * See docs: {@link https://orm.drizzle.team/docs/joins#left-join-lateral}
254
+ *
255
+ * @param table the subquery to join.
256
+ * @param on the `on` clause.
257
+ */
258
+ leftJoinLateral = this.createJoin("left", true);
259
259
  /**
260
260
  * Executes a `right join` operation by adding another table to the current query.
261
261
  *
@@ -265,17 +265,18 @@ class MySqlSelectQueryBuilderBase extends import_query_builder.TypedQueryBuilder
265
265
  *
266
266
  * @param table the table to join.
267
267
  * @param on the `on` clause.
268
+ * @param onIndex index hint.
268
269
  *
269
270
  * @example
270
271
  *
271
272
  * ```ts
272
273
  * // Select all users and their pets
273
- * const usersWithPets: { user: User | null; pets: Pet }[] = await db.select()
274
+ * const usersWithPets: { user: User | null; pets: Pet; }[] = await db.select()
274
275
  * .from(users)
275
276
  * .rightJoin(pets, eq(users.id, pets.ownerId))
276
277
  *
277
278
  * // Select userId and petId
278
- * const usersIdsAndPetIds: { userId: number | null; petId: number }[] = await db.select({
279
+ * const usersIdsAndPetIds: { userId: number | null; petId: number; }[] = await db.select({
279
280
  * userId: users.id,
280
281
  * petId: pets.id,
281
282
  * })
@@ -283,7 +284,7 @@ class MySqlSelectQueryBuilderBase extends import_query_builder.TypedQueryBuilder
283
284
  * .rightJoin(pets, eq(users.id, pets.ownerId))
284
285
  *
285
286
  * // Select userId and petId with use index hint
286
- * const usersIdsAndPetIds: { userId: number; petId: number | null }[] = await db.select({
287
+ * const usersIdsAndPetIds: { userId: number; petId: number | null; }[] = await db.select({
287
288
  * userId: users.id,
288
289
  * petId: pets.id,
289
290
  * })
@@ -293,7 +294,7 @@ class MySqlSelectQueryBuilderBase extends import_query_builder.TypedQueryBuilder
293
294
  * })
294
295
  * ```
295
296
  */
296
- rightJoin = this.createJoin("right");
297
+ rightJoin = this.createJoin("right", false);
297
298
  /**
298
299
  * Executes an `inner join` operation, creating a new table by combining rows from two tables that have matching values.
299
300
  *
@@ -303,17 +304,18 @@ class MySqlSelectQueryBuilderBase extends import_query_builder.TypedQueryBuilder
303
304
  *
304
305
  * @param table the table to join.
305
306
  * @param on the `on` clause.
307
+ * @param onIndex index hint.
306
308
  *
307
309
  * @example
308
310
  *
309
311
  * ```ts
310
312
  * // Select all users and their pets
311
- * const usersWithPets: { user: User; pets: Pet }[] = await db.select()
313
+ * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()
312
314
  * .from(users)
313
315
  * .innerJoin(pets, eq(users.id, pets.ownerId))
314
316
  *
315
317
  * // Select userId and petId
316
- * const usersIdsAndPetIds: { userId: number; petId: number }[] = await db.select({
318
+ * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({
317
319
  * userId: users.id,
318
320
  * petId: pets.id,
319
321
  * })
@@ -321,7 +323,7 @@ class MySqlSelectQueryBuilderBase extends import_query_builder.TypedQueryBuilder
321
323
  * .innerJoin(pets, eq(users.id, pets.ownerId))
322
324
  *
323
325
  * // Select userId and petId with use index hint
324
- * const usersIdsAndPetIds: { userId: number; petId: number | null }[] = await db.select({
326
+ * const usersIdsAndPetIds: { userId: number; petId: number | null; }[] = await db.select({
325
327
  * userId: users.id,
326
328
  * petId: pets.id,
327
329
  * })
@@ -331,45 +333,70 @@ class MySqlSelectQueryBuilderBase extends import_query_builder.TypedQueryBuilder
331
333
  * })
332
334
  * ```
333
335
  */
334
- innerJoin = this.createJoin("inner");
336
+ innerJoin = this.createJoin("inner", false);
335
337
  /**
336
- * Executes a `full join` operation by combining rows from two tables into a new table.
338
+ * Executes an `inner join lateral` operation, creating a new table by combining rows from two queries that have matching values.
337
339
  *
338
- * 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.
340
+ * A `lateral` join allows the right-hand expression to refer to columns from the left-hand side.
339
341
  *
340
- * See docs: {@link https://orm.drizzle.team/docs/joins#full-join}
342
+ * 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.
341
343
  *
342
- * @param table the table to join.
344
+ * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join-lateral}
345
+ *
346
+ * @param table the subquery to join.
343
347
  * @param on the `on` clause.
348
+ */
349
+ innerJoinLateral = this.createJoin("inner", true);
350
+ /**
351
+ * Executes a `cross join` operation by combining rows from two tables into a new table.
352
+ *
353
+ * Calling this method retrieves all rows from both main and joined tables, merging all rows from each table.
354
+ *
355
+ * See docs: {@link https://orm.drizzle.team/docs/joins#cross-join}
356
+ *
357
+ * @param table the table to join.
358
+ * @param onIndex index hint.
344
359
  *
345
360
  * @example
346
361
  *
347
362
  * ```ts
348
- * // Select all users and their pets
349
- * const usersWithPets: { user: User | null; pets: Pet | null }[] = await db.select()
363
+ * // Select all users, each user with every pet
364
+ * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()
350
365
  * .from(users)
351
- * .fullJoin(pets, eq(users.id, pets.ownerId))
366
+ * .crossJoin(pets)
352
367
  *
353
368
  * // Select userId and petId
354
- * const usersIdsAndPetIds: { userId: number | null; petId: number | null }[] = await db.select({
369
+ * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({
355
370
  * userId: users.id,
356
371
  * petId: pets.id,
357
372
  * })
358
373
  * .from(users)
359
- * .fullJoin(pets, eq(users.id, pets.ownerId))
374
+ * .crossJoin(pets)
360
375
  *
361
376
  * // Select userId and petId with use index hint
362
- * const usersIdsAndPetIds: { userId: number; petId: number | null }[] = await db.select({
377
+ * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({
363
378
  * userId: users.id,
364
379
  * petId: pets.id,
365
380
  * })
366
381
  * .from(users)
367
- * .leftJoin(pets, eq(users.id, pets.ownerId), {
382
+ * .crossJoin(pets, {
368
383
  * useIndex: ['pets_owner_id_index']
369
384
  * })
370
385
  * ```
371
386
  */
372
- fullJoin = this.createJoin("full");
387
+ crossJoin = this.createJoin("cross", false);
388
+ /**
389
+ * Executes a `cross join lateral` operation by combining rows from two queries into a new table.
390
+ *
391
+ * A `lateral` join allows the right-hand expression to refer to columns from the left-hand side.
392
+ *
393
+ * Calling this method retrieves all rows from both main and joined queries, merging all rows from each query.
394
+ *
395
+ * See docs: {@link https://orm.drizzle.team/docs/joins#cross-join-lateral}
396
+ *
397
+ * @param table the query to join.
398
+ */
399
+ crossJoinLateral = this.createJoin("cross", true);
373
400
  createSetOperator(type, isAll) {
374
401
  return (rightSelection) => {
375
402
  const rightSelect = typeof rightSelection === "function" ? rightSelection(getMySqlSetOperators()) : rightSelection;
@@ -757,14 +784,8 @@ class MySqlSelectQueryBuilderBase extends import_query_builder.TypedQueryBuilder
757
784
  return rest;
758
785
  }
759
786
  as(alias) {
760
- const usedTables = [];
761
- usedTables.push(...(0, import_utils2.extractUsedTable)(this.config.table));
762
- if (this.config.joins) {
763
- for (const it of this.config.joins)
764
- usedTables.push(...(0, import_utils2.extractUsedTable)(it.table));
765
- }
766
787
  return new Proxy(
767
- new import_subquery.Subquery(this.getSQL(), this.config.fields, alias, false, [...new Set(usedTables)]),
788
+ new import_subquery.Subquery(this.getSQL(), this.config.fields, alias),
768
789
  new import_selection_proxy.SelectionProxyHandler({ alias, sqlAliasedBehavior: "alias", sqlBehavior: "error" })
769
790
  );
770
791
  }
@@ -778,10 +799,6 @@ class MySqlSelectQueryBuilderBase extends import_query_builder.TypedQueryBuilder
778
799
  $dynamic() {
779
800
  return this;
780
801
  }
781
- $withCache(config) {
782
- this.cacheConfig = config === void 0 ? { config: {}, enable: true, autoInvalidate: true } : config === false ? { enable: false } : { enable: true, autoInvalidate: true, ...config };
783
- return this;
784
- }
785
802
  }
786
803
  class MySqlSelectBase extends MySqlSelectQueryBuilderBase {
787
804
  static [import_entity.entityKind] = "MySqlSelect";
@@ -790,10 +807,7 @@ class MySqlSelectBase extends MySqlSelectQueryBuilderBase {
790
807
  throw new Error("Cannot execute a query on a query builder. Please use a database instance instead.");
791
808
  }
792
809
  const fieldsList = (0, import_utils.orderSelectedFields)(this.config.fields);
793
- const query = this.session.prepareQuery(this.dialect.sqlToQuery(this.getSQL()), fieldsList, void 0, void 0, void 0, {
794
- type: "select",
795
- tables: [...this.usedTables]
796
- }, this.cacheConfig);
810
+ const query = this.session.prepareQuery(this.dialect.sqlToQuery(this.getSQL()), fieldsList);
797
811
  query.joinsNotNullableMap = this.joinsNotNullableMap;
798
812
  return query;
799
813
  }