@fragno-dev/db 0.1.2 → 0.1.5

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 (176) hide show
  1. package/.turbo/turbo-build.log +210 -146
  2. package/CHANGELOG.md +19 -0
  3. package/LICENSE.md +16 -0
  4. package/dist/adapters/adapters.js +1 -0
  5. package/dist/adapters/drizzle/drizzle-adapter.d.ts.map +1 -1
  6. package/dist/adapters/drizzle/drizzle-adapter.js +4 -2
  7. package/dist/adapters/drizzle/drizzle-adapter.js.map +1 -1
  8. package/dist/adapters/drizzle/drizzle-query.js +2 -2
  9. package/dist/adapters/drizzle/drizzle-query.js.map +1 -1
  10. package/dist/adapters/drizzle/drizzle-uow-compiler.js +4 -4
  11. package/dist/adapters/drizzle/drizzle-uow-decoder.js +14 -4
  12. package/dist/adapters/drizzle/drizzle-uow-decoder.js.map +1 -1
  13. package/dist/adapters/drizzle/drizzle-uow-executor.js +78 -60
  14. package/dist/adapters/drizzle/drizzle-uow-executor.js.map +1 -1
  15. package/dist/adapters/drizzle/generate.js +5 -4
  16. package/dist/adapters/drizzle/generate.js.map +1 -1
  17. package/dist/adapters/kysely/kysely-adapter.d.ts.map +1 -1
  18. package/dist/adapters/kysely/kysely-adapter.js +33 -22
  19. package/dist/adapters/kysely/kysely-adapter.js.map +1 -1
  20. package/dist/adapters/kysely/migration/execute-base.js +128 -0
  21. package/dist/adapters/kysely/migration/execute-base.js.map +1 -0
  22. package/dist/adapters/kysely/migration/execute-factory.js +27 -0
  23. package/dist/adapters/kysely/migration/execute-factory.js.map +1 -0
  24. package/dist/adapters/kysely/migration/execute-mssql.js +112 -0
  25. package/dist/adapters/kysely/migration/execute-mssql.js.map +1 -0
  26. package/dist/adapters/kysely/migration/execute-mysql.js +93 -0
  27. package/dist/adapters/kysely/migration/execute-mysql.js.map +1 -0
  28. package/dist/adapters/kysely/migration/execute-postgres.js +104 -0
  29. package/dist/adapters/kysely/migration/execute-postgres.js.map +1 -0
  30. package/dist/adapters/kysely/migration/execute-sqlite.js +123 -0
  31. package/dist/adapters/kysely/migration/execute-sqlite.js.map +1 -0
  32. package/dist/adapters/kysely/migration/execute.js +23 -168
  33. package/dist/adapters/kysely/migration/execute.js.map +1 -1
  34. package/dist/migration-engine/shared.d.ts +24 -5
  35. package/dist/migration-engine/shared.d.ts.map +1 -1
  36. package/dist/migration-engine/shared.js.map +1 -1
  37. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/alias.js +77 -0
  38. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/alias.js.map +1 -0
  39. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/casing.js +49 -0
  40. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/casing.js.map +1 -0
  41. package/dist/node_modules/{.bun/drizzle-orm@0.44.6_4fae081eecb963e2 → .pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8}/node_modules/drizzle-orm/column-builder.js +1 -1
  42. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/column-builder.js.map +1 -0
  43. package/dist/node_modules/{.bun/drizzle-orm@0.44.6_4fae081eecb963e2 → .pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8}/node_modules/drizzle-orm/column.js +1 -1
  44. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/column.js.map +1 -0
  45. package/dist/node_modules/{.bun/drizzle-orm@0.44.6_4fae081eecb963e2 → .pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8}/node_modules/drizzle-orm/entity.js +1 -1
  46. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/entity.js.map +1 -0
  47. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/errors.js +21 -0
  48. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/errors.js.map +1 -0
  49. package/dist/node_modules/{.bun/drizzle-orm@0.44.6_4fae081eecb963e2 → .pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8}/node_modules/drizzle-orm/pg-core/columns/common.js +1 -1
  50. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/pg-core/columns/common.js.map +1 -0
  51. package/dist/node_modules/{.bun/drizzle-orm@0.44.6_4fae081eecb963e2 → .pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8}/node_modules/drizzle-orm/pg-core/columns/enum.js +1 -1
  52. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/pg-core/columns/enum.js.map +1 -0
  53. package/dist/node_modules/{.bun/drizzle-orm@0.44.6_4fae081eecb963e2 → .pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8}/node_modules/drizzle-orm/pg-core/foreign-keys.js +1 -1
  54. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/pg-core/foreign-keys.js.map +1 -0
  55. package/dist/node_modules/{.bun/drizzle-orm@0.44.6_4fae081eecb963e2 → .pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8}/node_modules/drizzle-orm/pg-core/unique-constraint.js +1 -1
  56. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/pg-core/unique-constraint.js.map +1 -0
  57. package/dist/node_modules/{.bun/drizzle-orm@0.44.6_4fae081eecb963e2 → .pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8}/node_modules/drizzle-orm/pg-core/utils/array.js +1 -1
  58. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/pg-core/utils/array.js.map +1 -0
  59. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/query-builders/query-builder.js +14 -0
  60. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/query-builders/query-builder.js.map +1 -0
  61. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/query-promise.js +26 -0
  62. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/query-promise.js.map +1 -0
  63. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/relations.js +127 -0
  64. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/relations.js.map +1 -0
  65. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/selection-proxy.js +47 -0
  66. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/selection-proxy.js.map +1 -0
  67. package/dist/node_modules/{.bun/drizzle-orm@0.44.6_4fae081eecb963e2 → .pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8}/node_modules/drizzle-orm/sql/expressions/conditions.js +20 -2
  68. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sql/expressions/conditions.js.map +1 -0
  69. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sql/expressions/select.js +13 -0
  70. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sql/expressions/select.js.map +1 -0
  71. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sql/functions/aggregate.js +10 -0
  72. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sql/functions/aggregate.js.map +1 -0
  73. package/dist/node_modules/{.bun/drizzle-orm@0.44.6_4fae081eecb963e2 → .pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8}/node_modules/drizzle-orm/sql/sql.js +1 -1
  74. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sql/sql.js.map +1 -0
  75. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/columns/common.js +60 -0
  76. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/columns/common.js.map +1 -0
  77. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/db.js +269 -0
  78. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/db.js.map +1 -0
  79. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/dialect.js +457 -0
  80. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/dialect.js.map +1 -0
  81. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/foreign-keys.js +68 -0
  82. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/foreign-keys.js.map +1 -0
  83. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/count.js +41 -0
  84. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/count.js.map +1 -0
  85. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/delete.js +119 -0
  86. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/delete.js.map +1 -0
  87. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/insert.js +170 -0
  88. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/insert.js.map +1 -0
  89. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/query-builder.js +75 -0
  90. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/query-builder.js.map +1 -0
  91. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/query.js +107 -0
  92. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/query.js.map +1 -0
  93. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/raw.js +37 -0
  94. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/raw.js.map +1 -0
  95. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/select.js +621 -0
  96. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/select.js.map +1 -0
  97. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/update.js +170 -0
  98. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/update.js.map +1 -0
  99. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/table.js +20 -0
  100. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/table.js.map +1 -0
  101. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/unique-constraint.js +48 -0
  102. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/unique-constraint.js.map +1 -0
  103. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/utils.js +17 -0
  104. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/utils.js.map +1 -0
  105. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/view-base.js +11 -0
  106. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/view-base.js.map +1 -0
  107. package/dist/node_modules/{.bun/drizzle-orm@0.44.6_4fae081eecb963e2 → .pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8}/node_modules/drizzle-orm/subquery.js +2 -2
  108. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/subquery.js.map +1 -0
  109. package/dist/node_modules/{.bun/drizzle-orm@0.44.6_4fae081eecb963e2 → .pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8}/node_modules/drizzle-orm/table.js +8 -2
  110. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/table.js.map +1 -0
  111. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/table.utils.js +6 -0
  112. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/table.utils.js.map +1 -0
  113. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/tracing-utils.js +8 -0
  114. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/tracing-utils.js.map +1 -0
  115. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/tracing.js +8 -0
  116. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/tracing.js.map +1 -0
  117. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/utils.js +53 -0
  118. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/utils.js.map +1 -0
  119. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/view-common.js +6 -0
  120. package/dist/node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql_pglite@0.3.11_@types_better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/view-common.js.map +1 -0
  121. package/dist/query/query.d.ts +4 -4
  122. package/dist/query/query.d.ts.map +1 -1
  123. package/dist/query/unit-of-work.d.ts +22 -22
  124. package/dist/query/unit-of-work.d.ts.map +1 -1
  125. package/dist/schema/create.d.ts +41 -41
  126. package/dist/schema/create.d.ts.map +1 -1
  127. package/dist/schema/serialize.js +3 -0
  128. package/dist/schema/serialize.js.map +1 -1
  129. package/package.json +20 -24
  130. package/src/adapters/drizzle/drizzle-adapter-sqlite.test.ts +585 -0
  131. package/src/adapters/drizzle/drizzle-adapter.test.ts +2 -2
  132. package/src/adapters/drizzle/drizzle-adapter.ts +11 -4
  133. package/src/adapters/drizzle/drizzle-query.ts +2 -2
  134. package/src/adapters/drizzle/drizzle-uow-compiler.test.ts +1 -1
  135. package/src/adapters/drizzle/drizzle-uow-decoder.ts +21 -4
  136. package/src/adapters/drizzle/drizzle-uow-executor.ts +155 -115
  137. package/src/adapters/drizzle/generate.test.ts +111 -14
  138. package/src/adapters/drizzle/generate.ts +12 -7
  139. package/src/adapters/kysely/kysely-adapter.ts +46 -27
  140. package/src/adapters/kysely/migration/execute-base.ts +256 -0
  141. package/src/adapters/kysely/migration/execute-factory.ts +30 -0
  142. package/src/adapters/kysely/migration/execute-mssql.ts +250 -0
  143. package/src/adapters/kysely/migration/execute-mysql.ts +211 -0
  144. package/src/adapters/kysely/migration/execute-postgres.ts +234 -0
  145. package/src/adapters/kysely/migration/execute-sqlite.test.ts +1363 -0
  146. package/src/adapters/kysely/migration/execute-sqlite.ts +247 -0
  147. package/src/adapters/kysely/migration/execute.ts +33 -396
  148. package/src/adapters/kysely/migration/kysely-migrator.test.ts +84 -2
  149. package/src/migration-engine/shared.ts +29 -11
  150. package/src/schema/serialize.test.ts +1 -0
  151. package/src/schema/serialize.ts +7 -0
  152. package/tsdown.config.ts +1 -0
  153. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/column-builder.js.map +0 -1
  154. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/column.js.map +0 -1
  155. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/entity.js.map +0 -1
  156. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/pg-core/columns/common.js.map +0 -1
  157. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/pg-core/columns/enum.js.map +0 -1
  158. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/pg-core/foreign-keys.js.map +0 -1
  159. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/pg-core/unique-constraint.js.map +0 -1
  160. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/pg-core/utils/array.js.map +0 -1
  161. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/sql/expressions/conditions.js.map +0 -1
  162. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/sql/expressions/select.js +0 -13
  163. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/sql/expressions/select.js.map +0 -1
  164. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/sql/functions/aggregate.js +0 -10
  165. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/sql/functions/aggregate.js.map +0 -1
  166. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/sql/sql.js.map +0 -1
  167. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/subquery.js.map +0 -1
  168. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/table.js.map +0 -1
  169. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/table.utils.js +0 -6
  170. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/table.utils.js.map +0 -1
  171. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/tracing-utils.js +0 -8
  172. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/tracing-utils.js.map +0 -1
  173. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/tracing.js +0 -8
  174. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/tracing.js.map +0 -1
  175. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/view-common.js +0 -6
  176. package/dist/node_modules/.bun/drizzle-orm@0.44.6_4fae081eecb963e2/node_modules/drizzle-orm/view-common.js.map +0 -1
@@ -0,0 +1,621 @@
1
+ import { entityKind, is } from "../../entity.js";
2
+ import { Subquery } from "../../subquery.js";
3
+ import { ViewBaseConfig } from "../../view-common.js";
4
+ import { Table } from "../../table.js";
5
+ import { SQL, View } from "../../sql/sql.js";
6
+ import { QueryPromise } from "../../query-promise.js";
7
+ import { applyMixins, getTableColumns, getTableLikeName, haveSameKeys, orderSelectedFields } from "../../utils.js";
8
+ import { SelectionProxyHandler } from "../../selection-proxy.js";
9
+ import { extractUsedTable } from "../utils.js";
10
+ import { SQLiteViewBase } from "../view-base.js";
11
+ import { TypedQueryBuilder } from "../../query-builders/query-builder.js";
12
+
13
+ //#region ../../node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql+pglite@0.3.11_@types+better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/select.js
14
+ var SQLiteSelectBuilder = class {
15
+ static [entityKind] = "SQLiteSelectBuilder";
16
+ fields;
17
+ session;
18
+ dialect;
19
+ withList;
20
+ distinct;
21
+ constructor(config) {
22
+ this.fields = config.fields;
23
+ this.session = config.session;
24
+ this.dialect = config.dialect;
25
+ this.withList = config.withList;
26
+ this.distinct = config.distinct;
27
+ }
28
+ from(source) {
29
+ const isPartialSelect = !!this.fields;
30
+ let fields;
31
+ if (this.fields) fields = this.fields;
32
+ else if (is(source, Subquery)) fields = Object.fromEntries(Object.keys(source._.selectedFields).map((key) => [key, source[key]]));
33
+ else if (is(source, SQLiteViewBase)) fields = source[ViewBaseConfig].selectedFields;
34
+ else if (is(source, SQL)) fields = {};
35
+ else fields = getTableColumns(source);
36
+ return new SQLiteSelectBase({
37
+ table: source,
38
+ fields,
39
+ isPartialSelect,
40
+ session: this.session,
41
+ dialect: this.dialect,
42
+ withList: this.withList,
43
+ distinct: this.distinct
44
+ });
45
+ }
46
+ };
47
+ var SQLiteSelectQueryBuilderBase = class extends TypedQueryBuilder {
48
+ static [entityKind] = "SQLiteSelectQueryBuilder";
49
+ _;
50
+ /** @internal */
51
+ config;
52
+ joinsNotNullableMap;
53
+ tableName;
54
+ isPartialSelect;
55
+ session;
56
+ dialect;
57
+ cacheConfig = void 0;
58
+ usedTables = /* @__PURE__ */ new Set();
59
+ constructor({ table, fields, isPartialSelect, session, dialect, withList, distinct }) {
60
+ super();
61
+ this.config = {
62
+ withList,
63
+ table,
64
+ fields: { ...fields },
65
+ distinct,
66
+ setOperators: []
67
+ };
68
+ this.isPartialSelect = isPartialSelect;
69
+ this.session = session;
70
+ this.dialect = dialect;
71
+ this._ = {
72
+ selectedFields: fields,
73
+ config: this.config
74
+ };
75
+ this.tableName = getTableLikeName(table);
76
+ this.joinsNotNullableMap = typeof this.tableName === "string" ? { [this.tableName]: true } : {};
77
+ for (const item of extractUsedTable(table)) this.usedTables.add(item);
78
+ }
79
+ /** @internal */
80
+ getUsedTables() {
81
+ return [...this.usedTables];
82
+ }
83
+ createJoin(joinType) {
84
+ return (table, on) => {
85
+ const baseTableName = this.tableName;
86
+ const tableName = getTableLikeName(table);
87
+ for (const item of extractUsedTable(table)) this.usedTables.add(item);
88
+ if (typeof tableName === "string" && this.config.joins?.some((join) => join.alias === tableName)) throw new Error(`Alias "${tableName}" is already used in this query`);
89
+ if (!this.isPartialSelect) {
90
+ if (Object.keys(this.joinsNotNullableMap).length === 1 && typeof baseTableName === "string") this.config.fields = { [baseTableName]: this.config.fields };
91
+ if (typeof tableName === "string" && !is(table, SQL)) {
92
+ const selection = is(table, Subquery) ? table._.selectedFields : is(table, View) ? table[ViewBaseConfig].selectedFields : table[Table.Symbol.Columns];
93
+ this.config.fields[tableName] = selection;
94
+ }
95
+ }
96
+ if (typeof on === "function") on = on(new Proxy(this.config.fields, new SelectionProxyHandler({
97
+ sqlAliasedBehavior: "sql",
98
+ sqlBehavior: "sql"
99
+ })));
100
+ if (!this.config.joins) this.config.joins = [];
101
+ this.config.joins.push({
102
+ on,
103
+ table,
104
+ joinType,
105
+ alias: tableName
106
+ });
107
+ if (typeof tableName === "string") switch (joinType) {
108
+ case "left":
109
+ this.joinsNotNullableMap[tableName] = false;
110
+ break;
111
+ case "right":
112
+ this.joinsNotNullableMap = Object.fromEntries(Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false]));
113
+ this.joinsNotNullableMap[tableName] = true;
114
+ break;
115
+ case "cross":
116
+ case "inner":
117
+ this.joinsNotNullableMap[tableName] = true;
118
+ break;
119
+ case "full":
120
+ this.joinsNotNullableMap = Object.fromEntries(Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false]));
121
+ this.joinsNotNullableMap[tableName] = false;
122
+ break;
123
+ }
124
+ return this;
125
+ };
126
+ }
127
+ /**
128
+ * Executes a `left join` operation by adding another table to the current query.
129
+ *
130
+ * 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.
131
+ *
132
+ * See docs: {@link https://orm.drizzle.team/docs/joins#left-join}
133
+ *
134
+ * @param table the table to join.
135
+ * @param on the `on` clause.
136
+ *
137
+ * @example
138
+ *
139
+ * ```ts
140
+ * // Select all users and their pets
141
+ * const usersWithPets: { user: User; pets: Pet | null; }[] = await db.select()
142
+ * .from(users)
143
+ * .leftJoin(pets, eq(users.id, pets.ownerId))
144
+ *
145
+ * // Select userId and petId
146
+ * const usersIdsAndPetIds: { userId: number; petId: number | null; }[] = await db.select({
147
+ * userId: users.id,
148
+ * petId: pets.id,
149
+ * })
150
+ * .from(users)
151
+ * .leftJoin(pets, eq(users.id, pets.ownerId))
152
+ * ```
153
+ */
154
+ leftJoin = this.createJoin("left");
155
+ /**
156
+ * Executes a `right join` operation by adding another table to the current query.
157
+ *
158
+ * 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.
159
+ *
160
+ * See docs: {@link https://orm.drizzle.team/docs/joins#right-join}
161
+ *
162
+ * @param table the table to join.
163
+ * @param on the `on` clause.
164
+ *
165
+ * @example
166
+ *
167
+ * ```ts
168
+ * // Select all users and their pets
169
+ * const usersWithPets: { user: User | null; pets: Pet; }[] = await db.select()
170
+ * .from(users)
171
+ * .rightJoin(pets, eq(users.id, pets.ownerId))
172
+ *
173
+ * // Select userId and petId
174
+ * const usersIdsAndPetIds: { userId: number | null; petId: number; }[] = await db.select({
175
+ * userId: users.id,
176
+ * petId: pets.id,
177
+ * })
178
+ * .from(users)
179
+ * .rightJoin(pets, eq(users.id, pets.ownerId))
180
+ * ```
181
+ */
182
+ rightJoin = this.createJoin("right");
183
+ /**
184
+ * Executes an `inner join` operation, creating a new table by combining rows from two tables that have matching values.
185
+ *
186
+ * 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.
187
+ *
188
+ * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join}
189
+ *
190
+ * @param table the table to join.
191
+ * @param on the `on` clause.
192
+ *
193
+ * @example
194
+ *
195
+ * ```ts
196
+ * // Select all users and their pets
197
+ * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()
198
+ * .from(users)
199
+ * .innerJoin(pets, eq(users.id, pets.ownerId))
200
+ *
201
+ * // Select userId and petId
202
+ * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({
203
+ * userId: users.id,
204
+ * petId: pets.id,
205
+ * })
206
+ * .from(users)
207
+ * .innerJoin(pets, eq(users.id, pets.ownerId))
208
+ * ```
209
+ */
210
+ innerJoin = this.createJoin("inner");
211
+ /**
212
+ * Executes a `full join` operation by combining rows from two tables into a new table.
213
+ *
214
+ * 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.
215
+ *
216
+ * See docs: {@link https://orm.drizzle.team/docs/joins#full-join}
217
+ *
218
+ * @param table the table to join.
219
+ * @param on the `on` clause.
220
+ *
221
+ * @example
222
+ *
223
+ * ```ts
224
+ * // Select all users and their pets
225
+ * const usersWithPets: { user: User | null; pets: Pet | null; }[] = await db.select()
226
+ * .from(users)
227
+ * .fullJoin(pets, eq(users.id, pets.ownerId))
228
+ *
229
+ * // Select userId and petId
230
+ * const usersIdsAndPetIds: { userId: number | null; petId: number | null; }[] = await db.select({
231
+ * userId: users.id,
232
+ * petId: pets.id,
233
+ * })
234
+ * .from(users)
235
+ * .fullJoin(pets, eq(users.id, pets.ownerId))
236
+ * ```
237
+ */
238
+ fullJoin = this.createJoin("full");
239
+ /**
240
+ * Executes a `cross join` operation by combining rows from two tables into a new table.
241
+ *
242
+ * Calling this method retrieves all rows from both main and joined tables, merging all rows from each table.
243
+ *
244
+ * See docs: {@link https://orm.drizzle.team/docs/joins#cross-join}
245
+ *
246
+ * @param table the table to join.
247
+ *
248
+ * @example
249
+ *
250
+ * ```ts
251
+ * // Select all users, each user with every pet
252
+ * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()
253
+ * .from(users)
254
+ * .crossJoin(pets)
255
+ *
256
+ * // Select userId and petId
257
+ * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({
258
+ * userId: users.id,
259
+ * petId: pets.id,
260
+ * })
261
+ * .from(users)
262
+ * .crossJoin(pets)
263
+ * ```
264
+ */
265
+ crossJoin = this.createJoin("cross");
266
+ createSetOperator(type, isAll) {
267
+ return (rightSelection) => {
268
+ const rightSelect = typeof rightSelection === "function" ? rightSelection(getSQLiteSetOperators()) : rightSelection;
269
+ if (!haveSameKeys(this.getSelectedFields(), rightSelect.getSelectedFields())) throw new Error("Set operator error (union / intersect / except): selected fields are not the same or are in a different order");
270
+ this.config.setOperators.push({
271
+ type,
272
+ isAll,
273
+ rightSelect
274
+ });
275
+ return this;
276
+ };
277
+ }
278
+ /**
279
+ * Adds `union` set operator to the query.
280
+ *
281
+ * Calling this method will combine the result sets of the `select` statements and remove any duplicate rows that appear across them.
282
+ *
283
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#union}
284
+ *
285
+ * @example
286
+ *
287
+ * ```ts
288
+ * // Select all unique names from customers and users tables
289
+ * await db.select({ name: users.name })
290
+ * .from(users)
291
+ * .union(
292
+ * db.select({ name: customers.name }).from(customers)
293
+ * );
294
+ * // or
295
+ * import { union } from 'drizzle-orm/sqlite-core'
296
+ *
297
+ * await union(
298
+ * db.select({ name: users.name }).from(users),
299
+ * db.select({ name: customers.name }).from(customers)
300
+ * );
301
+ * ```
302
+ */
303
+ union = this.createSetOperator("union", false);
304
+ /**
305
+ * Adds `union all` set operator to the query.
306
+ *
307
+ * Calling this method will combine the result-set of the `select` statements and keep all duplicate rows that appear across them.
308
+ *
309
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#union-all}
310
+ *
311
+ * @example
312
+ *
313
+ * ```ts
314
+ * // Select all transaction ids from both online and in-store sales
315
+ * await db.select({ transaction: onlineSales.transactionId })
316
+ * .from(onlineSales)
317
+ * .unionAll(
318
+ * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)
319
+ * );
320
+ * // or
321
+ * import { unionAll } from 'drizzle-orm/sqlite-core'
322
+ *
323
+ * await unionAll(
324
+ * db.select({ transaction: onlineSales.transactionId }).from(onlineSales),
325
+ * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)
326
+ * );
327
+ * ```
328
+ */
329
+ unionAll = this.createSetOperator("union", true);
330
+ /**
331
+ * Adds `intersect` set operator to the query.
332
+ *
333
+ * Calling this method will retain only the rows that are present in both result sets and eliminate duplicates.
334
+ *
335
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect}
336
+ *
337
+ * @example
338
+ *
339
+ * ```ts
340
+ * // Select course names that are offered in both departments A and B
341
+ * await db.select({ courseName: depA.courseName })
342
+ * .from(depA)
343
+ * .intersect(
344
+ * db.select({ courseName: depB.courseName }).from(depB)
345
+ * );
346
+ * // or
347
+ * import { intersect } from 'drizzle-orm/sqlite-core'
348
+ *
349
+ * await intersect(
350
+ * db.select({ courseName: depA.courseName }).from(depA),
351
+ * db.select({ courseName: depB.courseName }).from(depB)
352
+ * );
353
+ * ```
354
+ */
355
+ intersect = this.createSetOperator("intersect", false);
356
+ /**
357
+ * Adds `except` set operator to the query.
358
+ *
359
+ * 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.
360
+ *
361
+ * See docs: {@link https://orm.drizzle.team/docs/set-operations#except}
362
+ *
363
+ * @example
364
+ *
365
+ * ```ts
366
+ * // Select all courses offered in department A but not in department B
367
+ * await db.select({ courseName: depA.courseName })
368
+ * .from(depA)
369
+ * .except(
370
+ * db.select({ courseName: depB.courseName }).from(depB)
371
+ * );
372
+ * // or
373
+ * import { except } from 'drizzle-orm/sqlite-core'
374
+ *
375
+ * await except(
376
+ * db.select({ courseName: depA.courseName }).from(depA),
377
+ * db.select({ courseName: depB.courseName }).from(depB)
378
+ * );
379
+ * ```
380
+ */
381
+ except = this.createSetOperator("except", false);
382
+ /** @internal */
383
+ addSetOperators(setOperators) {
384
+ this.config.setOperators.push(...setOperators);
385
+ return this;
386
+ }
387
+ /**
388
+ * Adds a `where` clause to the query.
389
+ *
390
+ * Calling this method will select only those rows that fulfill a specified condition.
391
+ *
392
+ * See docs: {@link https://orm.drizzle.team/docs/select#filtering}
393
+ *
394
+ * @param where the `where` clause.
395
+ *
396
+ * @example
397
+ * You can use conditional operators and `sql function` to filter the rows to be selected.
398
+ *
399
+ * ```ts
400
+ * // Select all cars with green color
401
+ * await db.select().from(cars).where(eq(cars.color, 'green'));
402
+ * // or
403
+ * await db.select().from(cars).where(sql`${cars.color} = 'green'`)
404
+ * ```
405
+ *
406
+ * You can logically combine conditional operators with `and()` and `or()` operators:
407
+ *
408
+ * ```ts
409
+ * // Select all BMW cars with a green color
410
+ * await db.select().from(cars).where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));
411
+ *
412
+ * // Select all cars with the green or blue color
413
+ * await db.select().from(cars).where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));
414
+ * ```
415
+ */
416
+ where(where) {
417
+ if (typeof where === "function") where = where(new Proxy(this.config.fields, new SelectionProxyHandler({
418
+ sqlAliasedBehavior: "sql",
419
+ sqlBehavior: "sql"
420
+ })));
421
+ this.config.where = where;
422
+ return this;
423
+ }
424
+ /**
425
+ * Adds a `having` clause to the query.
426
+ *
427
+ * 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.
428
+ *
429
+ * See docs: {@link https://orm.drizzle.team/docs/select#aggregations}
430
+ *
431
+ * @param having the `having` clause.
432
+ *
433
+ * @example
434
+ *
435
+ * ```ts
436
+ * // Select all brands with more than one car
437
+ * await db.select({
438
+ * brand: cars.brand,
439
+ * count: sql<number>`cast(count(${cars.id}) as int)`,
440
+ * })
441
+ * .from(cars)
442
+ * .groupBy(cars.brand)
443
+ * .having(({ count }) => gt(count, 1));
444
+ * ```
445
+ */
446
+ having(having) {
447
+ if (typeof having === "function") having = having(new Proxy(this.config.fields, new SelectionProxyHandler({
448
+ sqlAliasedBehavior: "sql",
449
+ sqlBehavior: "sql"
450
+ })));
451
+ this.config.having = having;
452
+ return this;
453
+ }
454
+ groupBy(...columns) {
455
+ if (typeof columns[0] === "function") {
456
+ const groupBy = columns[0](new Proxy(this.config.fields, new SelectionProxyHandler({
457
+ sqlAliasedBehavior: "alias",
458
+ sqlBehavior: "sql"
459
+ })));
460
+ this.config.groupBy = Array.isArray(groupBy) ? groupBy : [groupBy];
461
+ } else this.config.groupBy = columns;
462
+ return this;
463
+ }
464
+ orderBy(...columns) {
465
+ if (typeof columns[0] === "function") {
466
+ const orderBy = columns[0](new Proxy(this.config.fields, new SelectionProxyHandler({
467
+ sqlAliasedBehavior: "alias",
468
+ sqlBehavior: "sql"
469
+ })));
470
+ const orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];
471
+ if (this.config.setOperators.length > 0) this.config.setOperators.at(-1).orderBy = orderByArray;
472
+ else this.config.orderBy = orderByArray;
473
+ } else {
474
+ const orderByArray = columns;
475
+ if (this.config.setOperators.length > 0) this.config.setOperators.at(-1).orderBy = orderByArray;
476
+ else this.config.orderBy = orderByArray;
477
+ }
478
+ return this;
479
+ }
480
+ /**
481
+ * Adds a `limit` clause to the query.
482
+ *
483
+ * Calling this method will set the maximum number of rows that will be returned by this query.
484
+ *
485
+ * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}
486
+ *
487
+ * @param limit the `limit` clause.
488
+ *
489
+ * @example
490
+ *
491
+ * ```ts
492
+ * // Get the first 10 people from this query.
493
+ * await db.select().from(people).limit(10);
494
+ * ```
495
+ */
496
+ limit(limit) {
497
+ if (this.config.setOperators.length > 0) this.config.setOperators.at(-1).limit = limit;
498
+ else this.config.limit = limit;
499
+ return this;
500
+ }
501
+ /**
502
+ * Adds an `offset` clause to the query.
503
+ *
504
+ * Calling this method will skip a number of rows when returning results from this query.
505
+ *
506
+ * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}
507
+ *
508
+ * @param offset the `offset` clause.
509
+ *
510
+ * @example
511
+ *
512
+ * ```ts
513
+ * // Get the 10th-20th people from this query.
514
+ * await db.select().from(people).offset(10).limit(10);
515
+ * ```
516
+ */
517
+ offset(offset) {
518
+ if (this.config.setOperators.length > 0) this.config.setOperators.at(-1).offset = offset;
519
+ else this.config.offset = offset;
520
+ return this;
521
+ }
522
+ /** @internal */
523
+ getSQL() {
524
+ return this.dialect.buildSelectQuery(this.config);
525
+ }
526
+ toSQL() {
527
+ const { typings: _typings,...rest } = this.dialect.sqlToQuery(this.getSQL());
528
+ return rest;
529
+ }
530
+ as(alias) {
531
+ const usedTables = [];
532
+ usedTables.push(...extractUsedTable(this.config.table));
533
+ if (this.config.joins) for (const it of this.config.joins) usedTables.push(...extractUsedTable(it.table));
534
+ return new Proxy(new Subquery(this.getSQL(), this.config.fields, alias, false, [...new Set(usedTables)]), new SelectionProxyHandler({
535
+ alias,
536
+ sqlAliasedBehavior: "alias",
537
+ sqlBehavior: "error"
538
+ }));
539
+ }
540
+ /** @internal */
541
+ getSelectedFields() {
542
+ return new Proxy(this.config.fields, new SelectionProxyHandler({
543
+ alias: this.tableName,
544
+ sqlAliasedBehavior: "alias",
545
+ sqlBehavior: "error"
546
+ }));
547
+ }
548
+ $dynamic() {
549
+ return this;
550
+ }
551
+ };
552
+ var SQLiteSelectBase = class extends SQLiteSelectQueryBuilderBase {
553
+ static [entityKind] = "SQLiteSelect";
554
+ /** @internal */
555
+ _prepare(isOneTimeQuery = true) {
556
+ if (!this.session) throw new Error("Cannot execute a query on a query builder. Please use a database instance instead.");
557
+ const fieldsList = orderSelectedFields(this.config.fields);
558
+ const query = this.session[isOneTimeQuery ? "prepareOneTimeQuery" : "prepareQuery"](this.dialect.sqlToQuery(this.getSQL()), fieldsList, "all", true, void 0, {
559
+ type: "select",
560
+ tables: [...this.usedTables]
561
+ }, this.cacheConfig);
562
+ query.joinsNotNullableMap = this.joinsNotNullableMap;
563
+ return query;
564
+ }
565
+ $withCache(config) {
566
+ this.cacheConfig = config === void 0 ? {
567
+ config: {},
568
+ enable: true,
569
+ autoInvalidate: true
570
+ } : config === false ? { enable: false } : {
571
+ enable: true,
572
+ autoInvalidate: true,
573
+ ...config
574
+ };
575
+ return this;
576
+ }
577
+ prepare() {
578
+ return this._prepare(false);
579
+ }
580
+ run = (placeholderValues) => {
581
+ return this._prepare().run(placeholderValues);
582
+ };
583
+ all = (placeholderValues) => {
584
+ return this._prepare().all(placeholderValues);
585
+ };
586
+ get = (placeholderValues) => {
587
+ return this._prepare().get(placeholderValues);
588
+ };
589
+ values = (placeholderValues) => {
590
+ return this._prepare().values(placeholderValues);
591
+ };
592
+ async execute() {
593
+ return this.all();
594
+ }
595
+ };
596
+ applyMixins(SQLiteSelectBase, [QueryPromise]);
597
+ function createSetOperator(type, isAll) {
598
+ return (leftSelect, rightSelect, ...restSelects) => {
599
+ const setOperators = [rightSelect, ...restSelects].map((select) => ({
600
+ type,
601
+ isAll,
602
+ rightSelect: select
603
+ }));
604
+ for (const setOperator of setOperators) if (!haveSameKeys(leftSelect.getSelectedFields(), setOperator.rightSelect.getSelectedFields())) throw new Error("Set operator error (union / intersect / except): selected fields are not the same or are in a different order");
605
+ return leftSelect.addSetOperators(setOperators);
606
+ };
607
+ }
608
+ const getSQLiteSetOperators = () => ({
609
+ union,
610
+ unionAll,
611
+ intersect,
612
+ except
613
+ });
614
+ const union = createSetOperator("union", false);
615
+ const unionAll = createSetOperator("union", true);
616
+ const intersect = createSetOperator("intersect", false);
617
+ const except = createSetOperator("except", false);
618
+
619
+ //#endregion
620
+ export { SQLiteSelectBuilder };
621
+ //# sourceMappingURL=select.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"select.js","names":[],"sources":["../../../../../../../../../../node_modules/.pnpm/drizzle-orm@0.44.7_@electric-sql+pglite@0.3.11_@types+better-sqlite3@7.6.13_better-sqlite3@12.4.1_kysely@0.28.8/node_modules/drizzle-orm/sqlite-core/query-builders/select.js"],"sourcesContent":["import { entityKind, is } from \"../../entity.js\";\nimport { TypedQueryBuilder } from \"../../query-builders/query-builder.js\";\nimport { QueryPromise } from \"../../query-promise.js\";\nimport { SelectionProxyHandler } from \"../../selection-proxy.js\";\nimport { SQL, View } from \"../../sql/sql.js\";\nimport { Subquery } from \"../../subquery.js\";\nimport { Table } from \"../../table.js\";\nimport {\n applyMixins,\n getTableColumns,\n getTableLikeName,\n haveSameKeys,\n orderSelectedFields\n} from \"../../utils.js\";\nimport { ViewBaseConfig } from \"../../view-common.js\";\nimport { extractUsedTable } from \"../utils.js\";\nimport { SQLiteViewBase } from \"../view-base.js\";\nclass SQLiteSelectBuilder {\n static [entityKind] = \"SQLiteSelectBuilder\";\n fields;\n session;\n dialect;\n withList;\n distinct;\n constructor(config) {\n this.fields = config.fields;\n this.session = config.session;\n this.dialect = config.dialect;\n this.withList = config.withList;\n this.distinct = config.distinct;\n }\n from(source) {\n const isPartialSelect = !!this.fields;\n let fields;\n if (this.fields) {\n fields = this.fields;\n } else if (is(source, Subquery)) {\n fields = Object.fromEntries(\n Object.keys(source._.selectedFields).map((key) => [key, source[key]])\n );\n } else if (is(source, SQLiteViewBase)) {\n fields = source[ViewBaseConfig].selectedFields;\n } else if (is(source, SQL)) {\n fields = {};\n } else {\n fields = getTableColumns(source);\n }\n return new SQLiteSelectBase({\n table: source,\n fields,\n isPartialSelect,\n session: this.session,\n dialect: this.dialect,\n withList: this.withList,\n distinct: this.distinct\n });\n }\n}\nclass SQLiteSelectQueryBuilderBase extends TypedQueryBuilder {\n static [entityKind] = \"SQLiteSelectQueryBuilder\";\n _;\n /** @internal */\n config;\n joinsNotNullableMap;\n tableName;\n isPartialSelect;\n session;\n dialect;\n cacheConfig = void 0;\n usedTables = /* @__PURE__ */ new Set();\n constructor({ table, fields, isPartialSelect, session, dialect, withList, distinct }) {\n super();\n this.config = {\n withList,\n table,\n fields: { ...fields },\n distinct,\n setOperators: []\n };\n this.isPartialSelect = isPartialSelect;\n this.session = session;\n this.dialect = dialect;\n this._ = {\n selectedFields: fields,\n config: this.config\n };\n this.tableName = getTableLikeName(table);\n this.joinsNotNullableMap = typeof this.tableName === \"string\" ? { [this.tableName]: true } : {};\n for (const item of extractUsedTable(table)) this.usedTables.add(item);\n }\n /** @internal */\n getUsedTables() {\n return [...this.usedTables];\n }\n createJoin(joinType) {\n return (table, on) => {\n const baseTableName = this.tableName;\n const tableName = getTableLikeName(table);\n for (const item of extractUsedTable(table)) this.usedTables.add(item);\n if (typeof tableName === \"string\" && this.config.joins?.some((join) => join.alias === tableName)) {\n throw new Error(`Alias \"${tableName}\" is already used in this query`);\n }\n if (!this.isPartialSelect) {\n if (Object.keys(this.joinsNotNullableMap).length === 1 && typeof baseTableName === \"string\") {\n this.config.fields = {\n [baseTableName]: this.config.fields\n };\n }\n if (typeof tableName === \"string\" && !is(table, SQL)) {\n const selection = is(table, Subquery) ? table._.selectedFields : is(table, View) ? table[ViewBaseConfig].selectedFields : table[Table.Symbol.Columns];\n this.config.fields[tableName] = selection;\n }\n }\n if (typeof on === \"function\") {\n on = on(\n new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n )\n );\n }\n if (!this.config.joins) {\n this.config.joins = [];\n }\n this.config.joins.push({ on, table, joinType, alias: tableName });\n if (typeof tableName === \"string\") {\n switch (joinType) {\n case \"left\": {\n this.joinsNotNullableMap[tableName] = false;\n break;\n }\n case \"right\": {\n this.joinsNotNullableMap = Object.fromEntries(\n Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false])\n );\n this.joinsNotNullableMap[tableName] = true;\n break;\n }\n case \"cross\":\n case \"inner\": {\n this.joinsNotNullableMap[tableName] = true;\n break;\n }\n case \"full\": {\n this.joinsNotNullableMap = Object.fromEntries(\n Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false])\n );\n this.joinsNotNullableMap[tableName] = false;\n break;\n }\n }\n }\n return this;\n };\n }\n /**\n * Executes a `left join` operation by adding another table to the current query.\n *\n * 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 *\n * See docs: {@link https://orm.drizzle.team/docs/joins#left-join}\n *\n * @param table the table to join.\n * @param on the `on` clause.\n *\n * @example\n *\n * ```ts\n * // Select all users and their pets\n * const usersWithPets: { user: User; pets: Pet | null; }[] = await db.select()\n * .from(users)\n * .leftJoin(pets, eq(users.id, pets.ownerId))\n *\n * // Select userId and petId\n * const usersIdsAndPetIds: { userId: number; petId: number | null; }[] = await db.select({\n * userId: users.id,\n * petId: pets.id,\n * })\n * .from(users)\n * .leftJoin(pets, eq(users.id, pets.ownerId))\n * ```\n */\n leftJoin = this.createJoin(\"left\");\n /**\n * Executes a `right join` operation by adding another table to the current query.\n *\n * 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 *\n * See docs: {@link https://orm.drizzle.team/docs/joins#right-join}\n *\n * @param table the table to join.\n * @param on the `on` clause.\n *\n * @example\n *\n * ```ts\n * // Select all users and their pets\n * const usersWithPets: { user: User | null; pets: Pet; }[] = await db.select()\n * .from(users)\n * .rightJoin(pets, eq(users.id, pets.ownerId))\n *\n * // Select userId and petId\n * const usersIdsAndPetIds: { userId: number | null; petId: number; }[] = await db.select({\n * userId: users.id,\n * petId: pets.id,\n * })\n * .from(users)\n * .rightJoin(pets, eq(users.id, pets.ownerId))\n * ```\n */\n rightJoin = this.createJoin(\"right\");\n /**\n * Executes an `inner join` operation, creating a new table by combining rows from two tables that have matching values.\n *\n * 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 *\n * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join}\n *\n * @param table the table to join.\n * @param on the `on` clause.\n *\n * @example\n *\n * ```ts\n * // Select all users and their pets\n * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()\n * .from(users)\n * .innerJoin(pets, eq(users.id, pets.ownerId))\n *\n * // Select userId and petId\n * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({\n * userId: users.id,\n * petId: pets.id,\n * })\n * .from(users)\n * .innerJoin(pets, eq(users.id, pets.ownerId))\n * ```\n */\n innerJoin = this.createJoin(\"inner\");\n /**\n * Executes a `full join` operation by combining rows from two tables into a new table.\n *\n * 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 *\n * See docs: {@link https://orm.drizzle.team/docs/joins#full-join}\n *\n * @param table the table to join.\n * @param on the `on` clause.\n *\n * @example\n *\n * ```ts\n * // Select all users and their pets\n * const usersWithPets: { user: User | null; pets: Pet | null; }[] = await db.select()\n * .from(users)\n * .fullJoin(pets, eq(users.id, pets.ownerId))\n *\n * // Select userId and petId\n * const usersIdsAndPetIds: { userId: number | null; petId: number | null; }[] = await db.select({\n * userId: users.id,\n * petId: pets.id,\n * })\n * .from(users)\n * .fullJoin(pets, eq(users.id, pets.ownerId))\n * ```\n */\n fullJoin = this.createJoin(\"full\");\n /**\n * Executes a `cross join` operation by combining rows from two tables into a new table.\n *\n * Calling this method retrieves all rows from both main and joined tables, merging all rows from each table.\n *\n * See docs: {@link https://orm.drizzle.team/docs/joins#cross-join}\n *\n * @param table the table to join.\n *\n * @example\n *\n * ```ts\n * // Select all users, each user with every pet\n * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()\n * .from(users)\n * .crossJoin(pets)\n *\n * // Select userId and petId\n * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({\n * userId: users.id,\n * petId: pets.id,\n * })\n * .from(users)\n * .crossJoin(pets)\n * ```\n */\n crossJoin = this.createJoin(\"cross\");\n createSetOperator(type, isAll) {\n return (rightSelection) => {\n const rightSelect = typeof rightSelection === \"function\" ? rightSelection(getSQLiteSetOperators()) : rightSelection;\n if (!haveSameKeys(this.getSelectedFields(), rightSelect.getSelectedFields())) {\n throw new Error(\n \"Set operator error (union / intersect / except): selected fields are not the same or are in a different order\"\n );\n }\n this.config.setOperators.push({ type, isAll, rightSelect });\n return this;\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 * await db.select({ name: users.name })\n * .from(users)\n * .union(\n * db.select({ name: customers.name }).from(customers)\n * );\n * // or\n * import { union } from 'drizzle-orm/sqlite-core'\n *\n * await union(\n * db.select({ name: users.name }).from(users),\n * db.select({ name: customers.name }).from(customers)\n * );\n * ```\n */\n union = this.createSetOperator(\"union\", false);\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 * await db.select({ transaction: onlineSales.transactionId })\n * .from(onlineSales)\n * .unionAll(\n * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n * );\n * // or\n * import { unionAll } from 'drizzle-orm/sqlite-core'\n *\n * await unionAll(\n * db.select({ transaction: onlineSales.transactionId }).from(onlineSales),\n * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n * );\n * ```\n */\n unionAll = this.createSetOperator(\"union\", true);\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 * await db.select({ courseName: depA.courseName })\n * .from(depA)\n * .intersect(\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * // or\n * import { intersect } from 'drizzle-orm/sqlite-core'\n *\n * await intersect(\n * db.select({ courseName: depA.courseName }).from(depA),\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * ```\n */\n intersect = this.createSetOperator(\"intersect\", false);\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 * await db.select({ courseName: depA.courseName })\n * .from(depA)\n * .except(\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * // or\n * import { except } from 'drizzle-orm/sqlite-core'\n *\n * await except(\n * db.select({ courseName: depA.courseName }).from(depA),\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * ```\n */\n except = this.createSetOperator(\"except\", false);\n /** @internal */\n addSetOperators(setOperators) {\n this.config.setOperators.push(...setOperators);\n return this;\n }\n /**\n * Adds a `where` clause to the query.\n *\n * Calling this method will select only those rows that fulfill a specified condition.\n *\n * See docs: {@link https://orm.drizzle.team/docs/select#filtering}\n *\n * @param where the `where` clause.\n *\n * @example\n * You can use conditional operators and `sql function` to filter the rows to be selected.\n *\n * ```ts\n * // Select all cars with green color\n * await db.select().from(cars).where(eq(cars.color, 'green'));\n * // or\n * await db.select().from(cars).where(sql`${cars.color} = 'green'`)\n * ```\n *\n * You can logically combine conditional operators with `and()` and `or()` operators:\n *\n * ```ts\n * // Select all BMW cars with a green color\n * await db.select().from(cars).where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n *\n * // Select all cars with the green or blue color\n * await db.select().from(cars).where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n * ```\n */\n where(where) {\n if (typeof where === \"function\") {\n where = where(\n new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n )\n );\n }\n this.config.where = where;\n return this;\n }\n /**\n * Adds a `having` clause to the query.\n *\n * 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 *\n * See docs: {@link https://orm.drizzle.team/docs/select#aggregations}\n *\n * @param having the `having` clause.\n *\n * @example\n *\n * ```ts\n * // Select all brands with more than one car\n * await db.select({\n * \tbrand: cars.brand,\n * \tcount: sql<number>`cast(count(${cars.id}) as int)`,\n * })\n * .from(cars)\n * .groupBy(cars.brand)\n * .having(({ count }) => gt(count, 1));\n * ```\n */\n having(having) {\n if (typeof having === \"function\") {\n having = having(\n new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n )\n );\n }\n this.config.having = having;\n return this;\n }\n groupBy(...columns) {\n if (typeof columns[0] === \"function\") {\n const groupBy = columns[0](\n new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"alias\", sqlBehavior: \"sql\" })\n )\n );\n this.config.groupBy = Array.isArray(groupBy) ? groupBy : [groupBy];\n } else {\n this.config.groupBy = columns;\n }\n return this;\n }\n orderBy(...columns) {\n if (typeof columns[0] === \"function\") {\n const orderBy = columns[0](\n new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"alias\", sqlBehavior: \"sql\" })\n )\n );\n const orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];\n if (this.config.setOperators.length > 0) {\n this.config.setOperators.at(-1).orderBy = orderByArray;\n } else {\n this.config.orderBy = orderByArray;\n }\n } else {\n const orderByArray = columns;\n if (this.config.setOperators.length > 0) {\n this.config.setOperators.at(-1).orderBy = orderByArray;\n } else {\n this.config.orderBy = orderByArray;\n }\n }\n return this;\n }\n /**\n * Adds a `limit` clause to the query.\n *\n * Calling this method will set the maximum number of rows that will be returned by this query.\n *\n * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}\n *\n * @param limit the `limit` clause.\n *\n * @example\n *\n * ```ts\n * // Get the first 10 people from this query.\n * await db.select().from(people).limit(10);\n * ```\n */\n limit(limit) {\n if (this.config.setOperators.length > 0) {\n this.config.setOperators.at(-1).limit = limit;\n } else {\n this.config.limit = limit;\n }\n return this;\n }\n /**\n * Adds an `offset` clause to the query.\n *\n * Calling this method will skip a number of rows when returning results from this query.\n *\n * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}\n *\n * @param offset the `offset` clause.\n *\n * @example\n *\n * ```ts\n * // Get the 10th-20th people from this query.\n * await db.select().from(people).offset(10).limit(10);\n * ```\n */\n offset(offset) {\n if (this.config.setOperators.length > 0) {\n this.config.setOperators.at(-1).offset = offset;\n } else {\n this.config.offset = offset;\n }\n return this;\n }\n /** @internal */\n getSQL() {\n return this.dialect.buildSelectQuery(this.config);\n }\n toSQL() {\n const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n return rest;\n }\n as(alias) {\n const usedTables = [];\n usedTables.push(...extractUsedTable(this.config.table));\n if (this.config.joins) {\n for (const it of this.config.joins) usedTables.push(...extractUsedTable(it.table));\n }\n return new Proxy(\n new Subquery(this.getSQL(), this.config.fields, alias, false, [...new Set(usedTables)]),\n new SelectionProxyHandler({ alias, sqlAliasedBehavior: \"alias\", sqlBehavior: \"error\" })\n );\n }\n /** @internal */\n getSelectedFields() {\n return new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ alias: this.tableName, sqlAliasedBehavior: \"alias\", sqlBehavior: \"error\" })\n );\n }\n $dynamic() {\n return this;\n }\n}\nclass SQLiteSelectBase extends SQLiteSelectQueryBuilderBase {\n static [entityKind] = \"SQLiteSelect\";\n /** @internal */\n _prepare(isOneTimeQuery = true) {\n if (!this.session) {\n throw new Error(\"Cannot execute a query on a query builder. Please use a database instance instead.\");\n }\n const fieldsList = orderSelectedFields(this.config.fields);\n const query = this.session[isOneTimeQuery ? \"prepareOneTimeQuery\" : \"prepareQuery\"](\n this.dialect.sqlToQuery(this.getSQL()),\n fieldsList,\n \"all\",\n true,\n void 0,\n {\n type: \"select\",\n tables: [...this.usedTables]\n },\n this.cacheConfig\n );\n query.joinsNotNullableMap = this.joinsNotNullableMap;\n return query;\n }\n $withCache(config) {\n this.cacheConfig = config === void 0 ? { config: {}, enable: true, autoInvalidate: true } : config === false ? { enable: false } : { enable: true, autoInvalidate: true, ...config };\n return this;\n }\n prepare() {\n return this._prepare(false);\n }\n run = (placeholderValues) => {\n return this._prepare().run(placeholderValues);\n };\n all = (placeholderValues) => {\n return this._prepare().all(placeholderValues);\n };\n get = (placeholderValues) => {\n return this._prepare().get(placeholderValues);\n };\n values = (placeholderValues) => {\n return this._prepare().values(placeholderValues);\n };\n async execute() {\n return this.all();\n }\n}\napplyMixins(SQLiteSelectBase, [QueryPromise]);\nfunction createSetOperator(type, isAll) {\n return (leftSelect, rightSelect, ...restSelects) => {\n const setOperators = [rightSelect, ...restSelects].map((select) => ({\n type,\n isAll,\n rightSelect: select\n }));\n for (const setOperator of setOperators) {\n if (!haveSameKeys(leftSelect.getSelectedFields(), setOperator.rightSelect.getSelectedFields())) {\n throw new Error(\n \"Set operator error (union / intersect / except): selected fields are not the same or are in a different order\"\n );\n }\n }\n return leftSelect.addSetOperators(setOperators);\n };\n}\nconst getSQLiteSetOperators = () => ({\n union,\n unionAll,\n intersect,\n except\n});\nconst union = createSetOperator(\"union\", false);\nconst unionAll = createSetOperator(\"union\", true);\nconst intersect = createSetOperator(\"intersect\", false);\nconst except = createSetOperator(\"except\", false);\nexport {\n SQLiteSelectBase,\n SQLiteSelectBuilder,\n SQLiteSelectQueryBuilderBase,\n except,\n intersect,\n union,\n unionAll\n};\n//# sourceMappingURL=select.js.map"],"x_google_ignoreList":[0],"mappings":"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"}