UNPKG

drizzle-orm

Version:

Drizzle ORM package for SQL databases

149 lines 4.43 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 indexes_exports = {}; __export(indexes_exports, { Index: () => Index, IndexBuilder: () => IndexBuilder, IndexBuilderOn: () => IndexBuilderOn, index: () => index, uniqueIndex: () => uniqueIndex }); module.exports = __toCommonJS(indexes_exports); var import_sql = require("../sql/sql.cjs"); var import_entity = require("../entity.cjs"); var import_columns = require("./columns/index.cjs"); class IndexBuilderOn { constructor(unique, name) { this.unique = unique; this.name = name; } static [import_entity.entityKind] = "PgIndexBuilderOn"; on(...columns) { return new IndexBuilder( columns.map((it) => { if ((0, import_entity.is)(it, import_sql.SQL)) { return it; } it = it; const clonedIndexedColumn = new import_columns.IndexedColumn(it.name, !!it.keyAsName, it.columnType, it.indexConfig); it.indexConfig = JSON.parse(JSON.stringify(it.defaultConfig)); return clonedIndexedColumn; }), this.unique, false, this.name ); } onOnly(...columns) { return new IndexBuilder( columns.map((it) => { if ((0, import_entity.is)(it, import_sql.SQL)) { return it; } it = it; const clonedIndexedColumn = new import_columns.IndexedColumn(it.name, !!it.keyAsName, it.columnType, it.indexConfig); it.indexConfig = it.defaultConfig; return clonedIndexedColumn; }), this.unique, true, this.name ); } /** * Specify what index method to use. Choices are `btree`, `hash`, `gist`, `spgist`, `gin`, `brin`, or user-installed access methods like `bloom`. The default method is `btree. * * If you have the `pg_vector` extension installed in your database, you can use the `hnsw` and `ivfflat` options, which are predefined types. * * **You can always specify any string you want in the method, in case Drizzle doesn't have it natively in its types** * * @param method The name of the index method to be used * @param columns * @returns */ using(method, ...columns) { return new IndexBuilder( columns.map((it) => { if ((0, import_entity.is)(it, import_sql.SQL)) { return it; } it = it; const clonedIndexedColumn = new import_columns.IndexedColumn(it.name, !!it.keyAsName, it.columnType, it.indexConfig); it.indexConfig = JSON.parse(JSON.stringify(it.defaultConfig)); return clonedIndexedColumn; }), this.unique, true, this.name, method ); } } class IndexBuilder { static [import_entity.entityKind] = "PgIndexBuilder"; /** @internal */ config; constructor(columns, unique, only, name, method = "btree") { this.config = { name, columns, unique, only, method }; } concurrently() { this.config.concurrently = true; return this; } with(obj) { this.config.with = obj; return this; } where(condition) { this.config.where = condition; return this; } /** @internal */ build(table) { return new Index(this.config, table); } } class Index { static [import_entity.entityKind] = "PgIndex"; config; constructor(config, table) { this.config = { ...config, table }; } } function index(name) { return new IndexBuilderOn(false, name); } function uniqueIndex(name) { return new IndexBuilderOn(true, name); } // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { Index, IndexBuilder, IndexBuilderOn, index, uniqueIndex }); //# sourceMappingURL=indexes.cjs.map