query-builder.cjs 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. "use strict";
  2. var __defProp = Object.defineProperty;
  3. var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
  4. var __getOwnPropNames = Object.getOwnPropertyNames;
  5. var __hasOwnProp = Object.prototype.hasOwnProperty;
  6. var __export = (target, all) => {
  7. for (var name in all)
  8. __defProp(target, name, { get: all[name], enumerable: true });
  9. };
  10. var __copyProps = (to, from, except, desc) => {
  11. if (from && typeof from === "object" || typeof from === "function") {
  12. for (let key of __getOwnPropNames(from))
  13. if (!__hasOwnProp.call(to, key) && key !== except)
  14. __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
  15. }
  16. return to;
  17. };
  18. var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
  19. var query_builder_exports = {};
  20. __export(query_builder_exports, {
  21. QueryBuilder: () => QueryBuilder
  22. });
  23. module.exports = __toCommonJS(query_builder_exports);
  24. var import_entity = require("../../entity.cjs");
  25. var import_selection_proxy = require("../../selection-proxy.cjs");
  26. var import_dialect = require("../dialect.cjs");
  27. var import_subquery = require("../../subquery.cjs");
  28. var import_select = require("./select.cjs");
  29. class QueryBuilder {
  30. static [import_entity.entityKind] = "SQLiteQueryBuilder";
  31. dialect;
  32. dialectConfig;
  33. constructor(dialect) {
  34. this.dialect = (0, import_entity.is)(dialect, import_dialect.SQLiteDialect) ? dialect : void 0;
  35. this.dialectConfig = (0, import_entity.is)(dialect, import_dialect.SQLiteDialect) ? void 0 : dialect;
  36. }
  37. $with = (alias, selection) => {
  38. const queryBuilder = this;
  39. const as = (qb) => {
  40. if (typeof qb === "function") {
  41. qb = qb(queryBuilder);
  42. }
  43. return new Proxy(
  44. new import_subquery.WithSubquery(
  45. qb.getSQL(),
  46. selection ?? ("getSelectedFields" in qb ? qb.getSelectedFields() ?? {} : {}),
  47. alias,
  48. true
  49. ),
  50. new import_selection_proxy.SelectionProxyHandler({ alias, sqlAliasedBehavior: "alias", sqlBehavior: "error" })
  51. );
  52. };
  53. return { as };
  54. };
  55. with(...queries) {
  56. const self = this;
  57. function select(fields) {
  58. return new import_select.SQLiteSelectBuilder({
  59. fields: fields ?? void 0,
  60. session: void 0,
  61. dialect: self.getDialect(),
  62. withList: queries
  63. });
  64. }
  65. function selectDistinct(fields) {
  66. return new import_select.SQLiteSelectBuilder({
  67. fields: fields ?? void 0,
  68. session: void 0,
  69. dialect: self.getDialect(),
  70. withList: queries,
  71. distinct: true
  72. });
  73. }
  74. return { select, selectDistinct };
  75. }
  76. select(fields) {
  77. return new import_select.SQLiteSelectBuilder({ fields: fields ?? void 0, session: void 0, dialect: this.getDialect() });
  78. }
  79. selectDistinct(fields) {
  80. return new import_select.SQLiteSelectBuilder({
  81. fields: fields ?? void 0,
  82. session: void 0,
  83. dialect: this.getDialect(),
  84. distinct: true
  85. });
  86. }
  87. // Lazy load dialect to avoid circular dependency
  88. getDialect() {
  89. if (!this.dialect) {
  90. this.dialect = new import_dialect.SQLiteSyncDialect(this.dialectConfig);
  91. }
  92. return this.dialect;
  93. }
  94. }
  95. // Annotate the CommonJS export names for ESM import in node:
  96. 0 && (module.exports = {
  97. QueryBuilder
  98. });
  99. //# sourceMappingURL=query-builder.cjs.map