UNPKG

drizzle-orm

Version:

Drizzle ORM package for SQL databases

126 lines 3.93 kB
"use strict"; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var query_exports = {}; __export(query_exports, { RelationalQueryBuilder: () => RelationalQueryBuilder, SingleStoreRelationalQuery: () => SingleStoreRelationalQuery }); module.exports = __toCommonJS(query_exports); var import_entity = require("../../entity.cjs"); var import_query_promise = require("../../query-promise.cjs"); var import_relations = require("../../relations.cjs"); class RelationalQueryBuilder { constructor(fullSchema, schema, tableNamesMap, table, tableConfig, dialect, session) { this.fullSchema = fullSchema; this.schema = schema; this.tableNamesMap = tableNamesMap; this.table = table; this.tableConfig = tableConfig; this.dialect = dialect; this.session = session; } static [import_entity.entityKind] = "SingleStoreRelationalQueryBuilder"; findMany(config) { return new SingleStoreRelationalQuery( this.fullSchema, this.schema, this.tableNamesMap, this.table, this.tableConfig, this.dialect, this.session, config ? config : {}, "many" ); } findFirst(config) { return new SingleStoreRelationalQuery( this.fullSchema, this.schema, this.tableNamesMap, this.table, this.tableConfig, this.dialect, this.session, config ? { ...config, limit: 1 } : { limit: 1 }, "first" ); } } class SingleStoreRelationalQuery extends import_query_promise.QueryPromise { constructor(fullSchema, schema, tableNamesMap, table, tableConfig, dialect, session, config, queryMode) { super(); this.fullSchema = fullSchema; this.schema = schema; this.tableNamesMap = tableNamesMap; this.table = table; this.tableConfig = tableConfig; this.dialect = dialect; this.session = session; this.config = config; this.queryMode = queryMode; } static [import_entity.entityKind] = "SingleStoreRelationalQuery"; prepare() { const { query, builtQuery } = this._toSQL(); return this.session.prepareQuery( builtQuery, void 0, (rawRows) => { const rows = rawRows.map((row) => (0, import_relations.mapRelationalRow)(this.schema, this.tableConfig, row, query.selection)); if (this.queryMode === "first") { return rows[0]; } return rows; } ); } _getQuery() { return this.dialect.buildRelationalQuery({ fullSchema: this.fullSchema, schema: this.schema, tableNamesMap: this.tableNamesMap, table: this.table, tableConfig: this.tableConfig, queryConfig: this.config, tableAlias: this.tableConfig.tsName }); } _toSQL() { const query = this._getQuery(); const builtQuery = this.dialect.sqlToQuery(query.sql); return { builtQuery, query }; } /** @internal */ getSQL() { return this._getQuery().sql; } toSQL() { return this._toSQL().builtQuery; } execute() { return this.prepare().execute(); } } // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { RelationalQueryBuilder, SingleStoreRelationalQuery }); //# sourceMappingURL=query.cjs.map