@jiggai/kitchen 0.4.3 → 0.4.4
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.
- package/.next/BUILD_ID +1 -1
- package/.next/build-manifest.json +2 -2
- package/.next/prerender-manifest.json +3 -3
- package/.next/server/app/_global-error.html +2 -2
- package/.next/server/app/_global-error.rsc +1 -1
- package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/_not-found.html +1 -1
- package/.next/server/app/_not-found.rsc +2 -2
- package/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
- package/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/api/plugins/[pluginId]/[...path]/route.js +1 -1
- package/.next/server/app/api/plugins/[pluginId]/[...path]/route.js.nft.json +1 -1
- package/.next/server/app/api/plugins/[pluginId]/tabs/[tabId]/route.js +1 -1
- package/.next/server/app/api/plugins/[pluginId]/tabs/[tabId]/route.js.nft.json +1 -1
- package/.next/server/app/api/plugins/route.js +1 -1
- package/.next/server/app/api/plugins/route.js.nft.json +1 -1
- package/.next/server/app/api/plugins/test/route.js +1 -1
- package/.next/server/app/api/plugins/test/route.js.nft.json +1 -1
- package/.next/server/app/api/teams/[teamId]/tickets/assignees/route.js +2 -2
- package/.next/server/app/api/teams/plugins/route.js +1 -1
- package/.next/server/app/api/teams/plugins/route.js.nft.json +1 -1
- package/.next/server/app/channels.html +2 -2
- package/.next/server/app/channels.rsc +2 -2
- package/.next/server/app/channels.segments/_full.segment.rsc +2 -2
- package/.next/server/app/channels.segments/_head.segment.rsc +1 -1
- package/.next/server/app/channels.segments/_index.segment.rsc +1 -1
- package/.next/server/app/channels.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/channels.segments/channels/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/channels.segments/channels.segment.rsc +1 -1
- package/.next/server/app/goals/new.html +2 -2
- package/.next/server/app/goals/new.rsc +2 -2
- package/.next/server/app/goals/new.segments/_full.segment.rsc +2 -2
- package/.next/server/app/goals/new.segments/_head.segment.rsc +1 -1
- package/.next/server/app/goals/new.segments/_index.segment.rsc +1 -1
- package/.next/server/app/goals/new.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/goals/new.segments/goals/new/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/goals/new.segments/goals/new.segment.rsc +1 -1
- package/.next/server/app/goals/new.segments/goals.segment.rsc +1 -1
- package/.next/server/app/goals.html +1 -1
- package/.next/server/app/goals.rsc +2 -2
- package/.next/server/app/goals.segments/_full.segment.rsc +2 -2
- package/.next/server/app/goals.segments/_head.segment.rsc +1 -1
- package/.next/server/app/goals.segments/_index.segment.rsc +1 -1
- package/.next/server/app/goals.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/goals.segments/goals/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/goals.segments/goals.segment.rsc +1 -1
- package/.next/server/app/settings.html +1 -1
- package/.next/server/app/settings.rsc +2 -2
- package/.next/server/app/settings.segments/_full.segment.rsc +2 -2
- package/.next/server/app/settings.segments/_head.segment.rsc +1 -1
- package/.next/server/app/settings.segments/_index.segment.rsc +1 -1
- package/.next/server/app/settings.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/settings.segments/settings/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/settings.segments/settings.segment.rsc +1 -1
- package/.next/server/chunks/[root-of-the-server]__1e0ade2e._.js +22 -0
- package/.next/server/chunks/[root-of-the-server]__1e0ade2e._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__5aa1dc93._.js +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__3b880807._.js +1 -1
- package/.next/server/chunks/ssr/[root-of-the-server]__3b880807._.js.map +1 -1
- package/.next/server/pages/404.html +1 -1
- package/.next/server/pages/500.html +2 -2
- package/.next/server/server-reference-manifest.js +1 -1
- package/.next/server/server-reference-manifest.json +1 -1
- package/openclaw.plugin.json +1 -1
- package/package.json +1 -1
- package/.next/server/chunks/[root-of-the-server]__497e7a9d._.js +0 -22
- package/.next/server/chunks/[root-of-the-server]__497e7a9d._.js.map +0 -1
- /package/.next/static/{VKFMk3pnq7Ap2maFSb7KP → Qrq3jqLaWMj-CoWdszvsX}/_buildManifest.js +0 -0
- /package/.next/static/{VKFMk3pnq7Ap2maFSb7KP → Qrq3jqLaWMj-CoWdszvsX}/_clientMiddlewareManifest.json +0 -0
- /package/.next/static/{VKFMk3pnq7Ap2maFSb7KP → Qrq3jqLaWMj-CoWdszvsX}/_ssgManifest.js +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../node_modules/src/entity.ts","../../../node_modules/src/logger.ts","../../../node_modules/src/table.utils.ts","../../../node_modules/src/table.ts","../../../node_modules/src/column.ts","../../../node_modules/src/column-builder.ts","../../../node_modules/src/pg-core/foreign-keys.ts","../../../node_modules/src/tracing-utils.ts","../../../node_modules/src/pg-core/unique-constraint.ts","../../../node_modules/src/pg-core/utils/array.ts","../../../node_modules/src/pg-core/columns/common.ts","../../../node_modules/src/pg-core/columns/enum.ts","../../../node_modules/src/subquery.ts","../../../node_modules/drizzle-orm/version.cjs","../../../node_modules/src/tracing.ts","../../../node_modules/src/view-common.ts","../../../node_modules/src/sql/sql.ts","../../../node_modules/src/utils.ts","../../../node_modules/src/pg-core/columns/int.common.ts","../../../node_modules/src/pg-core/columns/bigint.ts","../../../node_modules/src/pg-core/columns/bigserial.ts","../../../node_modules/src/pg-core/columns/boolean.ts","../../../node_modules/src/pg-core/columns/char.ts","../../../node_modules/src/pg-core/columns/cidr.ts","../../../node_modules/src/pg-core/columns/custom.ts","../../../node_modules/src/pg-core/columns/date.common.ts","../../../node_modules/src/pg-core/columns/date.ts","../../../node_modules/src/pg-core/columns/double-precision.ts","../../../node_modules/src/pg-core/columns/inet.ts","../../../node_modules/src/pg-core/columns/integer.ts","../../../node_modules/src/pg-core/columns/interval.ts","../../../node_modules/src/pg-core/columns/json.ts","../../../node_modules/src/pg-core/columns/jsonb.ts","../../../node_modules/src/pg-core/columns/line.ts","../../../node_modules/src/pg-core/columns/macaddr.ts","../../../node_modules/src/pg-core/columns/macaddr8.ts","../../../node_modules/src/pg-core/columns/numeric.ts","../../../node_modules/src/pg-core/columns/point.ts","../../../node_modules/src/pg-core/columns/postgis_extension/utils.ts","../../../node_modules/src/pg-core/columns/postgis_extension/geometry.ts","../../../node_modules/src/pg-core/columns/real.ts","../../../node_modules/src/pg-core/columns/serial.ts","../../../node_modules/src/pg-core/columns/smallint.ts","../../../node_modules/src/pg-core/columns/smallserial.ts","../../../node_modules/src/pg-core/columns/text.ts","../../../node_modules/src/pg-core/columns/time.ts","../../../node_modules/src/pg-core/columns/timestamp.ts","../../../node_modules/src/pg-core/columns/uuid.ts","../../../node_modules/src/pg-core/columns/varchar.ts","../../../node_modules/src/pg-core/columns/vector_extension/bit.ts","../../../node_modules/src/pg-core/columns/vector_extension/halfvec.ts","../../../node_modules/src/pg-core/columns/vector_extension/sparsevec.ts","../../../node_modules/src/pg-core/columns/vector_extension/vector.ts","../../../node_modules/src/pg-core/columns/all.ts","../../../node_modules/src/pg-core/table.ts","../../../node_modules/src/pg-core/primary-keys.ts","../../../node_modules/src/sql/expressions/conditions.ts","../../../node_modules/src/sql/expressions/select.ts","../../../node_modules/src/sql/expressions/index.ts","../../../node_modules/src/relations.ts","../../../node_modules/src/alias.ts","../../../node_modules/src/selection-proxy.ts","../../../node_modules/src/query-promise.ts","../../../node_modules/src/sqlite-core/foreign-keys.ts","../../../node_modules/src/sqlite-core/unique-constraint.ts","../../../node_modules/src/sqlite-core/columns/common.ts","../../../node_modules/src/sqlite-core/columns/blob.ts","../../../node_modules/src/sqlite-core/columns/custom.ts","../../../node_modules/src/sqlite-core/columns/integer.ts","../../../node_modules/src/sqlite-core/columns/numeric.ts","../../../node_modules/src/sqlite-core/columns/real.ts","../../../node_modules/src/sqlite-core/columns/text.ts","../../../node_modules/src/sqlite-core/columns/all.ts","../../../node_modules/src/sqlite-core/table.ts","../../../node_modules/src/sqlite-core/checks.ts","../../../node_modules/src/sqlite-core/indexes.ts","../../../node_modules/src/sqlite-core/primary-keys.ts","../../../node_modules/src/sqlite-core/utils.ts","../../../node_modules/src/sqlite-core/query-builders/delete.ts","../../../node_modules/src/casing.ts","../../../node_modules/src/errors.ts","../../../node_modules/src/sql/functions/aggregate.ts","../../../node_modules/src/sql/functions/vector.ts","../../../node_modules/src/sql/functions/index.ts","../../../node_modules/src/sql/index.ts","../../../node_modules/src/sqlite-core/columns/index.ts","../../../node_modules/src/sqlite-core/view-base.ts","../../../node_modules/src/sqlite-core/dialect.ts","../../../node_modules/src/query-builders/query-builder.ts","../../../node_modules/src/sqlite-core/query-builders/select.ts","../../../node_modules/src/sqlite-core/query-builders/query-builder.ts","../../../node_modules/src/sqlite-core/query-builders/insert.ts","../../../node_modules/src/sqlite-core/query-builders/select.types.ts","../../../node_modules/src/sqlite-core/query-builders/update.ts","../../../node_modules/src/sqlite-core/query-builders/index.ts","../../../node_modules/src/sqlite-core/query-builders/count.ts","../../../node_modules/src/sqlite-core/query-builders/query.ts","../../../node_modules/src/sqlite-core/query-builders/raw.ts","../../../node_modules/src/sqlite-core/db.ts","../../../node_modules/src/cache/core/cache.ts","../../../node_modules/src/cache/core/index.ts","../../../node_modules/src/sqlite-core/alias.ts","../../../node_modules/src/sqlite-core/session.ts","../../../node_modules/src/sqlite-core/subquery.ts","../../../node_modules/src/sqlite-core/view.ts","../../../node_modules/src/sqlite-core/index.ts","../../../node_modules/src/better-sqlite3/session.ts","../../../node_modules/src/better-sqlite3/driver.ts","../../../node_modules/src/better-sqlite3/index.ts","../../../node_modules/drizzle-orm/pg-core/utils/array.js","../../../node_modules/drizzle-orm/entity.js","../../../node_modules/drizzle-orm/table.utils.js","../../../node_modules/drizzle-orm/tracing-utils.js","../../../node_modules/drizzle-orm/version.js","../../../node_modules/drizzle-orm/view-common.js","../../../src/lib/kitchen-plugins.ts","../../../node_modules/drizzle-orm/column.js","../../../node_modules/drizzle-orm/subquery.js","../../../node_modules/drizzle-orm/column-builder.js","../../../node_modules/drizzle-orm/table.js","../../../node_modules/drizzle-orm/pg-core/columns/enum.js","../../../node_modules/drizzle-orm/pg-core/foreign-keys.js","../../../node_modules/drizzle-orm/pg-core/unique-constraint.js","../../../node_modules/drizzle-orm/tracing.js","../../../node_modules/drizzle-orm/sqlite-core/foreign-keys.js","../../../node_modules/drizzle-orm/sqlite-core/unique-constraint.js","../../../node_modules/drizzle-orm/sqlite-core/columns/real.js","../../../node_modules/drizzle-orm/sqlite-core/columns/blob.js","../../../node_modules/drizzle-orm/sqlite-core/columns/custom.js","../../../node_modules/drizzle-orm/sqlite-core/columns/numeric.js","../../../node_modules/drizzle-orm/sqlite-core/columns/text.js","../../../node_modules/drizzle-orm/sqlite-core/table.js","../../../node_modules/drizzle-orm/sqlite-core/columns/integer.js","../../../node_modules/drizzle-orm/sqlite-core/columns/common.js","../../../node_modules/drizzle-orm/utils.js","../../../node_modules/drizzle-orm/sqlite-core/columns/all.js","../../../node_modules/drizzle-orm/pg-core/columns/common.js","../../../node_modules/drizzle-orm/sql/sql.js","../../../node_modules/drizzle-orm/sql/expressions/conditions.js"],"sourcesContent":["export const entityKind = Symbol.for('drizzle:entityKind');\nexport const hasOwnEntityKind = Symbol.for('drizzle:hasOwnEntityKind');\n\nexport interface DrizzleEntity {\n\t[entityKind]: string;\n}\n\nexport type DrizzleEntityClass<T> =\n\t& ((abstract new(...args: any[]) => T) | (new(...args: any[]) => T))\n\t& DrizzleEntity;\n\nexport function is<T extends DrizzleEntityClass<any>>(value: any, type: T): value is InstanceType<T> {\n\tif (!value || typeof value !== 'object') {\n\t\treturn false;\n\t}\n\n\tif (value instanceof type) { // eslint-disable-line no-instanceof/no-instanceof\n\t\treturn true;\n\t}\n\n\tif (!Object.prototype.hasOwnProperty.call(type, entityKind)) {\n\t\tthrow new Error(\n\t\t\t`Class \"${\n\t\t\t\ttype.name ?? '<unknown>'\n\t\t\t}\" doesn't look like a Drizzle entity. If this is incorrect and the class is provided by Drizzle, please report this as a bug.`,\n\t\t);\n\t}\n\n\tlet cls = Object.getPrototypeOf(value).constructor;\n\tif (cls) {\n\t\t// Traverse the prototype chain to find the entityKind\n\t\twhile (cls) {\n\t\t\tif (entityKind in cls && cls[entityKind] === type[entityKind]) {\n\t\t\t\treturn true;\n\t\t\t}\n\n\t\t\tcls = Object.getPrototypeOf(cls);\n\t\t}\n\t}\n\n\treturn false;\n}\n","import { entityKind } from '~/entity.ts';\n\nexport interface Logger {\n\tlogQuery(query: string, params: unknown[]): void;\n}\n\nexport interface LogWriter {\n\twrite(message: string): void;\n}\n\nexport class ConsoleLogWriter implements LogWriter {\n\tstatic readonly [entityKind]: string = 'ConsoleLogWriter';\n\n\twrite(message: string) {\n\t\tconsole.log(message);\n\t}\n}\n\nexport class DefaultLogger implements Logger {\n\tstatic readonly [entityKind]: string = 'DefaultLogger';\n\n\treadonly writer: LogWriter;\n\n\tconstructor(config?: { writer: LogWriter }) {\n\t\tthis.writer = config?.writer ?? new ConsoleLogWriter();\n\t}\n\n\tlogQuery(query: string, params: unknown[]): void {\n\t\tconst stringifiedParams = params.map((p) => {\n\t\t\ttry {\n\t\t\t\treturn JSON.stringify(p);\n\t\t\t} catch {\n\t\t\t\treturn String(p);\n\t\t\t}\n\t\t});\n\t\tconst paramsStr = stringifiedParams.length ? ` -- params: [${stringifiedParams.join(', ')}]` : '';\n\t\tthis.writer.write(`Query: ${query}${paramsStr}`);\n\t}\n}\n\nexport class NoopLogger implements Logger {\n\tstatic readonly [entityKind]: string = 'NoopLogger';\n\n\tlogQuery(): void {\n\t\t// noop\n\t}\n}\n","/** @internal */\nexport const TableName = Symbol.for('drizzle:Name');\n","import type { Column, GetColumnData } from './column.ts';\nimport { entityKind } from './entity.ts';\nimport type { OptionalKeyOnly, RequiredKeyOnly } from './operations.ts';\nimport type { SQLWrapper } from './sql/sql.ts';\nimport { TableName } from './table.utils.ts';\nimport type { Simplify, Update } from './utils.ts';\n\nexport interface TableConfig<TColumn extends Column = Column<any>> {\n\tname: string;\n\tschema: string | undefined;\n\tcolumns: Record<string, TColumn>;\n\tdialect: string;\n}\n\nexport type UpdateTableConfig<T extends TableConfig, TUpdate extends Partial<TableConfig>> = Required<\n\tUpdate<T, TUpdate>\n>;\n\n/** @internal */\nexport const Schema = Symbol.for('drizzle:Schema');\n\n/** @internal */\nexport const Columns = Symbol.for('drizzle:Columns');\n\n/** @internal */\nexport const ExtraConfigColumns = Symbol.for('drizzle:ExtraConfigColumns');\n\n/** @internal */\nexport const OriginalName = Symbol.for('drizzle:OriginalName');\n\n/** @internal */\nexport const BaseName = Symbol.for('drizzle:BaseName');\n\n/** @internal */\nexport const IsAlias = Symbol.for('drizzle:IsAlias');\n\n/** @internal */\nexport const ExtraConfigBuilder = Symbol.for('drizzle:ExtraConfigBuilder');\n\nconst IsDrizzleTable = Symbol.for('drizzle:IsDrizzleTable');\n\nexport interface Table<\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tT extends TableConfig = TableConfig,\n> extends SQLWrapper {\n\t// SQLWrapper runtime implementation is defined in 'sql/sql.ts'\n}\n\nexport class Table<T extends TableConfig = TableConfig> implements SQLWrapper {\n\tstatic readonly [entityKind]: string = 'Table';\n\n\tdeclare readonly _: {\n\t\treadonly brand: 'Table';\n\t\treadonly config: T;\n\t\treadonly name: T['name'];\n\t\treadonly schema: T['schema'];\n\t\treadonly columns: T['columns'];\n\t\treadonly inferSelect: InferSelectModel<Table<T>>;\n\t\treadonly inferInsert: InferInsertModel<Table<T>>;\n\t};\n\n\tdeclare readonly $inferSelect: InferSelectModel<Table<T>>;\n\tdeclare readonly $inferInsert: InferInsertModel<Table<T>>;\n\n\t/** @internal */\n\tstatic readonly Symbol = {\n\t\tName: TableName as typeof TableName,\n\t\tSchema: Schema as typeof Schema,\n\t\tOriginalName: OriginalName as typeof OriginalName,\n\t\tColumns: Columns as typeof Columns,\n\t\tExtraConfigColumns: ExtraConfigColumns as typeof ExtraConfigColumns,\n\t\tBaseName: BaseName as typeof BaseName,\n\t\tIsAlias: IsAlias as typeof IsAlias,\n\t\tExtraConfigBuilder: ExtraConfigBuilder as typeof ExtraConfigBuilder,\n\t};\n\n\t/**\n\t * @internal\n\t * Can be changed if the table is aliased.\n\t */\n\t[TableName]: string;\n\n\t/**\n\t * @internal\n\t * Used to store the original name of the table, before any aliasing.\n\t */\n\t[OriginalName]: string;\n\n\t/** @internal */\n\t[Schema]: string | undefined;\n\n\t/** @internal */\n\t[Columns]!: T['columns'];\n\n\t/** @internal */\n\t[ExtraConfigColumns]!: Record<string, unknown>;\n\n\t/**\n\t * @internal\n\t * Used to store the table name before the transformation via the `tableCreator` functions.\n\t */\n\t[BaseName]: string;\n\n\t/** @internal */\n\t[IsAlias] = false;\n\n\t/** @internal */\n\t[IsDrizzleTable] = true;\n\n\t/** @internal */\n\t[ExtraConfigBuilder]: ((self: any) => Record<string, unknown> | unknown[]) | undefined = undefined;\n\n\tconstructor(name: string, schema: string | undefined, baseName: string) {\n\t\tthis[TableName] = this[OriginalName] = name;\n\t\tthis[Schema] = schema;\n\t\tthis[BaseName] = baseName;\n\t}\n}\n\nexport function isTable(table: unknown): table is Table {\n\treturn typeof table === 'object' && table !== null && IsDrizzleTable in table;\n}\n\n/**\n * Any table with a specified boundary.\n *\n * @example\n\t```ts\n\t// Any table with a specific name\n\ttype AnyUsersTable = AnyTable<{ name: 'users' }>;\n\t```\n *\n * To describe any table with any config, simply use `Table` without any type arguments, like this:\n *\n\t```ts\n\tfunction needsTable(table: Table) {\n\t\t...\n\t}\n\t```\n */\nexport type AnyTable<TPartial extends Partial<TableConfig>> = Table<UpdateTableConfig<TableConfig, TPartial>>;\n\nexport function getTableName<T extends Table>(table: T): T['_']['name'] {\n\treturn table[TableName];\n}\n\nexport function getTableUniqueName<T extends Table>(table: T): `${T['_']['schema']}.${T['_']['name']}` {\n\treturn `${table[Schema] ?? 'public'}.${table[TableName]}`;\n}\n\nexport type MapColumnName<TName extends string, TColumn extends Column, TDBColumNames extends boolean> =\n\tTDBColumNames extends true ? TColumn['_']['name']\n\t\t: TName;\n\nexport type InferModelFromColumns<\n\tTColumns extends Record<string, Column>,\n\tTInferMode extends 'select' | 'insert' = 'select',\n\tTConfig extends { dbColumnNames: boolean; override?: boolean } = { dbColumnNames: false; override: false },\n> = Simplify<\n\tTInferMode extends 'insert' ?\n\t\t\t& {\n\t\t\t\t[\n\t\t\t\t\tKey in keyof TColumns & string as RequiredKeyOnly<\n\t\t\t\t\t\tMapColumnName<Key, TColumns[Key], TConfig['dbColumnNames']>,\n\t\t\t\t\t\tTColumns[Key]\n\t\t\t\t\t>\n\t\t\t\t]: GetColumnData<TColumns[Key], 'query'>;\n\t\t\t}\n\t\t\t& {\n\t\t\t\t[\n\t\t\t\t\tKey in keyof TColumns & string as OptionalKeyOnly<\n\t\t\t\t\t\tMapColumnName<Key, TColumns[Key], TConfig['dbColumnNames']>,\n\t\t\t\t\t\tTColumns[Key],\n\t\t\t\t\t\tTConfig['override']\n\t\t\t\t\t>\n\t\t\t\t]?: GetColumnData<TColumns[Key], 'query'> | undefined;\n\t\t\t}\n\t\t: {\n\t\t\t[\n\t\t\t\tKey in keyof TColumns & string as MapColumnName<\n\t\t\t\t\tKey,\n\t\t\t\t\tTColumns[Key],\n\t\t\t\t\tTConfig['dbColumnNames']\n\t\t\t\t>\n\t\t\t]: GetColumnData<TColumns[Key], 'query'>;\n\t\t}\n>;\n\n/** @deprecated Use one of the alternatives: {@link InferSelectModel} / {@link InferInsertModel}, or `table.$inferSelect` / `table.$inferInsert`\n */\nexport type InferModel<\n\tTTable extends Table,\n\tTInferMode extends 'select' | 'insert' = 'select',\n\tTConfig extends { dbColumnNames: boolean } = { dbColumnNames: false },\n> = InferModelFromColumns<TTable['_']['columns'], TInferMode, TConfig>;\n\nexport type InferSelectModel<\n\tTTable extends Table,\n\tTConfig extends { dbColumnNames: boolean } = { dbColumnNames: false },\n> = InferModelFromColumns<TTable['_']['columns'], 'select', TConfig>;\n\nexport type InferInsertModel<\n\tTTable extends Table,\n\tTConfig extends { dbColumnNames: boolean; override?: boolean } = { dbColumnNames: false; override: false },\n> = InferModelFromColumns<TTable['_']['columns'], 'insert', TConfig>;\n\nexport type InferEnum<T> = T extends { enumValues: readonly (infer U)[] } ? U\n\t: never;\n","import type {\n\tColumnBuilderBaseConfig,\n\tColumnBuilderRuntimeConfig,\n\tColumnDataType,\n\tGeneratedColumnConfig,\n\tGeneratedIdentityConfig,\n} from './column-builder.ts';\nimport { entityKind } from './entity.ts';\nimport type { DriverValueMapper, SQL, SQLWrapper } from './sql/sql.ts';\nimport type { Table } from './table.ts';\nimport type { Update } from './utils.ts';\n\nexport interface ColumnBaseConfig<\n\tTDataType extends ColumnDataType,\n\tTColumnType extends string,\n> extends ColumnBuilderBaseConfig<TDataType, TColumnType> {\n\ttableName: string;\n\tnotNull: boolean;\n\thasDefault: boolean;\n\tisPrimaryKey: boolean;\n\tisAutoincrement: boolean;\n\thasRuntimeDefault: boolean;\n}\n\nexport type ColumnTypeConfig<T extends ColumnBaseConfig<ColumnDataType, string>, TTypeConfig extends object> = T & {\n\tbrand: 'Column';\n\ttableName: T['tableName'];\n\tname: T['name'];\n\tdataType: T['dataType'];\n\tcolumnType: T['columnType'];\n\tdata: T['data'];\n\tdriverParam: T['driverParam'];\n\tnotNull: T['notNull'];\n\thasDefault: T['hasDefault'];\n\tisPrimaryKey: T['isPrimaryKey'];\n\tisAutoincrement: T['isAutoincrement'];\n\thasRuntimeDefault: T['hasRuntimeDefault'];\n\tenumValues: T['enumValues'];\n\tbaseColumn: T extends { baseColumn: infer U } ? U : unknown;\n\tgenerated: GeneratedColumnConfig<T['data']> | undefined;\n\tidentity: undefined | 'always' | 'byDefault';\n} & TTypeConfig;\n\nexport type ColumnRuntimeConfig<TData, TRuntimeConfig extends object> = ColumnBuilderRuntimeConfig<\n\tTData,\n\tTRuntimeConfig\n>;\n\nexport interface Column<\n\tT extends ColumnBaseConfig<ColumnDataType, string> = ColumnBaseConfig<ColumnDataType, string>,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTRuntimeConfig extends object = object,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTTypeConfig extends object = object,\n> extends DriverValueMapper<T['data'], T['driverParam']>, SQLWrapper {\n\t// SQLWrapper runtime implementation is defined in 'sql/sql.ts'\n}\n/*\n\t`Column` only accepts a full `ColumnConfig` as its generic.\n\tTo infer parts of the config, use `AnyColumn` that accepts a partial config.\n\tSee `GetColumnData` for example usage of inferring.\n*/\nexport abstract class Column<\n\tT extends ColumnBaseConfig<ColumnDataType, string> = ColumnBaseConfig<ColumnDataType, string>,\n\tTRuntimeConfig extends object = object,\n\tTTypeConfig extends object = object,\n> implements DriverValueMapper<T['data'], T['driverParam']>, SQLWrapper {\n\tstatic readonly [entityKind]: string = 'Column';\n\n\tdeclare readonly _: ColumnTypeConfig<T, TTypeConfig>;\n\n\treadonly name: string;\n\treadonly keyAsName: boolean;\n\treadonly primary: boolean;\n\treadonly notNull: boolean;\n\treadonly default: T['data'] | SQL | undefined;\n\treadonly defaultFn: (() => T['data'] | SQL) | undefined;\n\treadonly onUpdateFn: (() => T['data'] | SQL) | undefined;\n\treadonly hasDefault: boolean;\n\treadonly isUnique: boolean;\n\treadonly uniqueName: string | undefined;\n\treadonly uniqueType: string | undefined;\n\treadonly dataType: T['dataType'];\n\treadonly columnType: T['columnType'];\n\treadonly enumValues: T['enumValues'] = undefined;\n\treadonly generated: GeneratedColumnConfig<T['data']> | undefined = undefined;\n\treadonly generatedIdentity: GeneratedIdentityConfig | undefined = undefined;\n\n\tprotected config: ColumnRuntimeConfig<T['data'], TRuntimeConfig>;\n\n\tconstructor(\n\t\treadonly table: Table,\n\t\tconfig: ColumnRuntimeConfig<T['data'], TRuntimeConfig>,\n\t) {\n\t\tthis.config = config;\n\t\tthis.name = config.name;\n\t\tthis.keyAsName = config.keyAsName;\n\t\tthis.notNull = config.notNull;\n\t\tthis.default = config.default;\n\t\tthis.defaultFn = config.defaultFn;\n\t\tthis.onUpdateFn = config.onUpdateFn;\n\t\tthis.hasDefault = config.hasDefault;\n\t\tthis.primary = config.primaryKey;\n\t\tthis.isUnique = config.isUnique;\n\t\tthis.uniqueName = config.uniqueName;\n\t\tthis.uniqueType = config.uniqueType;\n\t\tthis.dataType = config.dataType as T['dataType'];\n\t\tthis.columnType = config.columnType;\n\t\tthis.generated = config.generated;\n\t\tthis.generatedIdentity = config.generatedIdentity;\n\t}\n\n\tabstract getSQLType(): string;\n\n\tmapFromDriverValue(value: unknown): unknown {\n\t\treturn value;\n\t}\n\n\tmapToDriverValue(value: unknown): unknown {\n\t\treturn value;\n\t}\n\n\t// ** @internal */\n\tshouldDisableInsert(): boolean {\n\t\treturn this.config.generated !== undefined && this.config.generated.type !== 'byDefault';\n\t}\n}\n\nexport type UpdateColConfig<\n\tT extends ColumnBaseConfig<ColumnDataType, string>,\n\tTUpdate extends Partial<ColumnBaseConfig<ColumnDataType, string>>,\n> = Update<T, TUpdate>;\n\nexport type AnyColumn<TPartial extends Partial<ColumnBaseConfig<ColumnDataType, string>> = {}> = Column<\n\tRequired<Update<ColumnBaseConfig<ColumnDataType, string>, TPartial>>\n>;\n\nexport type GetColumnData<TColumn extends Column, TInferMode extends 'query' | 'raw' = 'query'> =\n\t// dprint-ignore\n\tTInferMode extends 'raw' // Raw mode\n\t\t? TColumn['_']['data'] // Just return the underlying type\n\t\t: TColumn['_']['notNull'] extends true // Query mode\n\t\t? TColumn['_']['data'] // Query mode, not null\n\t\t: TColumn['_']['data'] | null; // Query mode, nullable\n\nexport type InferColumnsDataTypes<TColumns extends Record<string, Column>> = {\n\t[Key in keyof TColumns]: GetColumnData<TColumns[Key], 'query'>;\n};\n","import { entityKind } from '~/entity.ts';\nimport type { Column } from './column.ts';\nimport type { GelColumn, GelExtraConfigColumn } from './gel-core/index.ts';\nimport type { MySqlColumn } from './mysql-core/index.ts';\nimport type { ExtraConfigColumn, PgColumn, PgSequenceOptions } from './pg-core/index.ts';\nimport type { SingleStoreColumn } from './singlestore-core/index.ts';\nimport type { SQL } from './sql/sql.ts';\nimport type { SQLiteColumn } from './sqlite-core/index.ts';\nimport type { Assume, Simplify } from './utils.ts';\n\nexport type ColumnDataType =\n\t| 'string'\n\t| 'number'\n\t| 'boolean'\n\t| 'array'\n\t| 'json'\n\t| 'date'\n\t| 'bigint'\n\t| 'custom'\n\t| 'buffer'\n\t| 'dateDuration'\n\t| 'duration'\n\t| 'relDuration'\n\t| 'localTime'\n\t| 'localDate'\n\t| 'localDateTime';\n\nexport type Dialect = 'pg' | 'mysql' | 'sqlite' | 'singlestore' | 'common' | 'gel';\n\nexport type GeneratedStorageMode = 'virtual' | 'stored';\n\nexport type GeneratedType = 'always' | 'byDefault';\n\nexport type GeneratedColumnConfig<TDataType> = {\n\tas: TDataType | SQL | (() => SQL);\n\ttype?: GeneratedType;\n\tmode?: GeneratedStorageMode;\n};\n\nexport type GeneratedIdentityConfig = {\n\tsequenceName?: string;\n\tsequenceOptions?: PgSequenceOptions;\n\ttype: 'always' | 'byDefault';\n};\n\nexport interface ColumnBuilderBaseConfig<TDataType extends ColumnDataType, TColumnType extends string> {\n\tname: string;\n\tdataType: TDataType;\n\tcolumnType: TColumnType;\n\tdata: unknown;\n\tdriverParam: unknown;\n\tenumValues: string[] | undefined;\n}\n\nexport type MakeColumnConfig<\n\tT extends ColumnBuilderBaseConfig<ColumnDataType, string>,\n\tTTableName extends string,\n\tTData = T extends { $type: infer U } ? U : T['data'],\n> = {\n\tname: T['name'];\n\ttableName: TTableName;\n\tdataType: T['dataType'];\n\tcolumnType: T['columnType'];\n\tdata: TData;\n\tdriverParam: T['driverParam'];\n\tnotNull: T extends { notNull: true } ? true : false;\n\thasDefault: T extends { hasDefault: true } ? true : false;\n\tisPrimaryKey: T extends { isPrimaryKey: true } ? true : false;\n\tisAutoincrement: T extends { isAutoincrement: true } ? true : false;\n\thasRuntimeDefault: T extends { hasRuntimeDefault: true } ? true : false;\n\tenumValues: T['enumValues'];\n\tbaseColumn: T extends { baseBuilder: infer U extends ColumnBuilderBase } ? BuildColumn<TTableName, U, 'common'>\n\t\t: never;\n\tidentity: T extends { identity: 'always' } ? 'always' : T extends { identity: 'byDefault' } ? 'byDefault' : undefined;\n\tgenerated: T extends { generated: infer G } ? unknown extends G ? undefined\n\t\t: G extends undefined ? undefined\n\t\t: G\n\t\t: undefined;\n} & {};\n\nexport type ColumnBuilderTypeConfig<\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tT extends ColumnBuilderBaseConfig<ColumnDataType, string>,\n\tTTypeConfig extends object = object,\n> = Simplify<\n\t& {\n\t\tbrand: 'ColumnBuilder';\n\t\tname: T['name'];\n\t\tdataType: T['dataType'];\n\t\tcolumnType: T['columnType'];\n\t\tdata: T['data'];\n\t\tdriverParam: T['driverParam'];\n\t\tnotNull: T extends { notNull: infer U } ? U : boolean;\n\t\thasDefault: T extends { hasDefault: infer U } ? U : boolean;\n\t\tenumValues: T['enumValues'];\n\t\tidentity: T extends { identity: infer U } ? U : unknown;\n\t\tgenerated: T extends { generated: infer G } ? G extends undefined ? unknown : G : unknown;\n\t}\n\t& TTypeConfig\n>;\n\nexport type ColumnBuilderRuntimeConfig<TData, TRuntimeConfig extends object = object> = {\n\tname: string;\n\tkeyAsName: boolean;\n\tnotNull: boolean;\n\tdefault: TData | SQL | undefined;\n\tdefaultFn: (() => TData | SQL) | undefined;\n\tonUpdateFn: (() => TData | SQL) | undefined;\n\thasDefault: boolean;\n\tprimaryKey: boolean;\n\tisUnique: boolean;\n\tuniqueName: string | undefined;\n\tuniqueType: string | undefined;\n\tdataType: string;\n\tcolumnType: string;\n\tgenerated: GeneratedColumnConfig<TData> | undefined;\n\tgeneratedIdentity: GeneratedIdentityConfig | undefined;\n} & TRuntimeConfig;\n\nexport interface ColumnBuilderExtraConfig {\n\tprimaryKeyHasDefault?: boolean;\n}\n\nexport type NotNull<T extends ColumnBuilderBase> = T & {\n\t_: {\n\t\tnotNull: true;\n\t};\n};\n\nexport type HasDefault<T extends ColumnBuilderBase> = T & {\n\t_: {\n\t\thasDefault: true;\n\t};\n};\n\nexport type IsPrimaryKey<T extends ColumnBuilderBase> = T & {\n\t_: {\n\t\tisPrimaryKey: true;\n\t};\n};\n\nexport type IsAutoincrement<T extends ColumnBuilderBase> = T & {\n\t_: {\n\t\tisAutoincrement: true;\n\t};\n};\n\nexport type HasRuntimeDefault<T extends ColumnBuilderBase> = T & {\n\t_: {\n\t\thasRuntimeDefault: true;\n\t};\n};\n\nexport type $Type<T extends ColumnBuilderBase, TType> = T & {\n\t_: {\n\t\t$type: TType;\n\t};\n};\n\nexport type HasGenerated<T extends ColumnBuilderBase, TGenerated extends {} = {}> = T & {\n\t_: {\n\t\thasDefault: true;\n\t\tgenerated: TGenerated;\n\t};\n};\n\nexport type IsIdentity<\n\tT extends ColumnBuilderBase,\n\tTType extends 'always' | 'byDefault',\n> = T & {\n\t_: {\n\t\tnotNull: true;\n\t\thasDefault: true;\n\t\tidentity: TType;\n\t};\n};\nexport interface ColumnBuilderBase<\n\tT extends ColumnBuilderBaseConfig<ColumnDataType, string> = ColumnBuilderBaseConfig<ColumnDataType, string>,\n\tTTypeConfig extends object = object,\n> {\n\t_: ColumnBuilderTypeConfig<T, TTypeConfig>;\n}\n\n// To understand how to use `ColumnBuilder` and `AnyColumnBuilder`, see `Column` and `AnyColumn` documentation.\nexport abstract class ColumnBuilder<\n\tT extends ColumnBuilderBaseConfig<ColumnDataType, string> = ColumnBuilderBaseConfig<ColumnDataType, string>,\n\tTRuntimeConfig extends object = object,\n\tTTypeConfig extends object = object,\n\tTExtraConfig extends ColumnBuilderExtraConfig = ColumnBuilderExtraConfig,\n> implements ColumnBuilderBase<T, TTypeConfig> {\n\tstatic readonly [entityKind]: string = 'ColumnBuilder';\n\n\tdeclare _: ColumnBuilderTypeConfig<T, TTypeConfig>;\n\n\tprotected config: ColumnBuilderRuntimeConfig<T['data'], TRuntimeConfig>;\n\n\tconstructor(name: T['name'], dataType: T['dataType'], columnType: T['columnType']) {\n\t\tthis.config = {\n\t\t\tname,\n\t\t\tkeyAsName: name === '',\n\t\t\tnotNull: false,\n\t\t\tdefault: undefined,\n\t\t\thasDefault: false,\n\t\t\tprimaryKey: false,\n\t\t\tisUnique: false,\n\t\t\tuniqueName: undefined,\n\t\t\tuniqueType: undefined,\n\t\t\tdataType,\n\t\t\tcolumnType,\n\t\t\tgenerated: undefined,\n\t\t} as ColumnBuilderRuntimeConfig<T['data'], TRuntimeConfig>;\n\t}\n\n\t/**\n\t * Changes the data type of the column. Commonly used with `json` columns. Also, useful for branded types.\n\t *\n\t * @example\n\t * ```ts\n\t * const users = pgTable('users', {\n\t * \tid: integer('id').$type<UserId>().primaryKey(),\n\t * \tdetails: json('details').$type<UserDetails>().notNull(),\n\t * });\n\t * ```\n\t */\n\t$type<TType>(): $Type<this, TType> {\n\t\treturn this as $Type<this, TType>;\n\t}\n\n\t/**\n\t * Adds a `not null` clause to the column definition.\n\t *\n\t * Affects the `select` model of the table - columns *without* `not null` will be nullable on select.\n\t */\n\tnotNull(): NotNull<this> {\n\t\tthis.config.notNull = true;\n\t\treturn this as NotNull<this>;\n\t}\n\n\t/**\n\t * Adds a `default <value>` clause to the column definition.\n\t *\n\t * Affects the `insert` model of the table - columns *with* `default` are optional on insert.\n\t *\n\t * If you need to set a dynamic default value, use {@link $defaultFn} instead.\n\t */\n\tdefault(value: (this['_'] extends { $type: infer U } ? U : this['_']['data']) | SQL): HasDefault<this> {\n\t\tthis.config.default = value;\n\t\tthis.config.hasDefault = true;\n\t\treturn this as HasDefault<this>;\n\t}\n\n\t/**\n\t * Adds a dynamic default value to the column.\n\t * The function will be called when the row is inserted, and the returned value will be used as the column value.\n\t *\n\t * **Note:** This value does not affect the `drizzle-kit` behavior, it is only used at runtime in `drizzle-orm`.\n\t */\n\t$defaultFn(\n\t\tfn: () => (this['_'] extends { $type: infer U } ? U : this['_']['data']) | SQL,\n\t): HasRuntimeDefault<HasDefault<this>> {\n\t\tthis.config.defaultFn = fn;\n\t\tthis.config.hasDefault = true;\n\t\treturn this as HasRuntimeDefault<HasDefault<this>>;\n\t}\n\n\t/**\n\t * Alias for {@link $defaultFn}.\n\t */\n\t$default = this.$defaultFn;\n\n\t/**\n\t * Adds a dynamic update value to the column.\n\t * The function will be called when the row is updated, and the returned value will be used as the column value if none is provided.\n\t * If no `default` (or `$defaultFn`) value is provided, the function will be called when the row is inserted as well, and the returned value will be used as the column value.\n\t *\n\t * **Note:** This value does not affect the `drizzle-kit` behavior, it is only used at runtime in `drizzle-orm`.\n\t */\n\t$onUpdateFn(\n\t\tfn: () => (this['_'] extends { $type: infer U } ? U : this['_']['data']) | SQL,\n\t): HasDefault<this> {\n\t\tthis.config.onUpdateFn = fn;\n\t\tthis.config.hasDefault = true;\n\t\treturn this as HasDefault<this>;\n\t}\n\n\t/**\n\t * Alias for {@link $onUpdateFn}.\n\t */\n\t$onUpdate = this.$onUpdateFn;\n\n\t/**\n\t * Adds a `primary key` clause to the column definition. This implicitly makes the column `not null`.\n\t *\n\t * In SQLite, `integer primary key` implicitly makes the column auto-incrementing.\n\t */\n\tprimaryKey(): TExtraConfig['primaryKeyHasDefault'] extends true ? IsPrimaryKey<HasDefault<NotNull<this>>>\n\t\t: IsPrimaryKey<NotNull<this>>\n\t{\n\t\tthis.config.primaryKey = true;\n\t\tthis.config.notNull = true;\n\t\treturn this as TExtraConfig['primaryKeyHasDefault'] extends true ? IsPrimaryKey<HasDefault<NotNull<this>>>\n\t\t\t: IsPrimaryKey<NotNull<this>>;\n\t}\n\n\tabstract generatedAlwaysAs(\n\t\tas: SQL | T['data'] | (() => SQL),\n\t\tconfig?: Partial<GeneratedColumnConfig<unknown>>,\n\t): HasGenerated<this, {\n\t\ttype: 'always';\n\t}>;\n\n\t/** @internal Sets the name of the column to the key within the table definition if a name was not given. */\n\tsetName(name: string) {\n\t\tif (this.config.name !== '') return;\n\t\tthis.config.name = name;\n\t}\n}\n\nexport type BuildColumn<\n\tTTableName extends string,\n\tTBuilder extends ColumnBuilderBase,\n\tTDialect extends Dialect,\n> = TDialect extends 'pg' ? PgColumn<\n\t\tMakeColumnConfig<TBuilder['_'], TTableName>,\n\t\t{},\n\t\tSimplify<Omit<TBuilder['_'], keyof MakeColumnConfig<TBuilder['_'], TTableName> | 'brand' | 'dialect'>>\n\t>\n\t: TDialect extends 'mysql' ? MySqlColumn<\n\t\t\tMakeColumnConfig<TBuilder['_'], TTableName>,\n\t\t\t{},\n\t\t\tSimplify<\n\t\t\t\tOmit<\n\t\t\t\t\tTBuilder['_'],\n\t\t\t\t\t| keyof MakeColumnConfig<TBuilder['_'], TTableName>\n\t\t\t\t\t| 'brand'\n\t\t\t\t\t| 'dialect'\n\t\t\t\t\t| 'primaryKeyHasDefault'\n\t\t\t\t\t| 'mysqlColumnBuilderBrand'\n\t\t\t\t>\n\t\t\t>\n\t\t>\n\t: TDialect extends 'sqlite' ? SQLiteColumn<\n\t\t\tMakeColumnConfig<TBuilder['_'], TTableName>,\n\t\t\t{},\n\t\t\tSimplify<Omit<TBuilder['_'], keyof MakeColumnConfig<TBuilder['_'], TTableName> | 'brand' | 'dialect'>>\n\t\t>\n\t: TDialect extends 'common' ? Column<\n\t\t\tMakeColumnConfig<TBuilder['_'], TTableName>,\n\t\t\t{},\n\t\t\tSimplify<Omit<TBuilder['_'], keyof MakeColumnConfig<TBuilder['_'], TTableName> | 'brand' | 'dialect'>>\n\t\t>\n\t: TDialect extends 'singlestore' ? SingleStoreColumn<\n\t\t\tMakeColumnConfig<TBuilder['_'], TTableName>,\n\t\t\t{},\n\t\t\tSimplify<\n\t\t\t\tOmit<\n\t\t\t\t\tTBuilder['_'],\n\t\t\t\t\t| keyof MakeColumnConfig<TBuilder['_'], TTableName>\n\t\t\t\t\t| 'brand'\n\t\t\t\t\t| 'dialect'\n\t\t\t\t\t| 'primaryKeyHasDefault'\n\t\t\t\t\t| 'singlestoreColumnBuilderBrand'\n\t\t\t\t>\n\t\t\t>\n\t\t>\n\t: TDialect extends 'gel' ? GelColumn<\n\t\t\tMakeColumnConfig<TBuilder['_'], TTableName>,\n\t\t\t{},\n\t\t\tSimplify<Omit<TBuilder['_'], keyof MakeColumnConfig<TBuilder['_'], TTableName> | 'brand' | 'dialect'>>\n\t\t>\n\t: never;\n\nexport type BuildIndexColumn<\n\tTDialect extends Dialect,\n> = TDialect extends 'pg' ? ExtraConfigColumn\n\t: TDialect extends 'gel' ? GelExtraConfigColumn\n\t: never;\n\n// TODO\n// try to make sql as well + indexRaw\n\n// optional after everything will be working as expected\n// also try to leave only needed methods for extraConfig\n// make an error if I pass .asc() to fk and so on\n\nexport type BuildColumns<\n\tTTableName extends string,\n\tTConfigMap extends Record<string, ColumnBuilderBase>,\n\tTDialect extends Dialect,\n> =\n\t& {\n\t\t[Key in keyof TConfigMap]: BuildColumn<TTableName, {\n\t\t\t_:\n\t\t\t\t& Omit<TConfigMap[Key]['_'], 'name'>\n\t\t\t\t& { name: TConfigMap[Key]['_']['name'] extends '' ? Assume<Key, string> : TConfigMap[Key]['_']['name'] };\n\t\t}, TDialect>;\n\t}\n\t& {};\n\nexport type BuildExtraConfigColumns<\n\t_TTableName extends string,\n\tTConfigMap extends Record<string, ColumnBuilderBase>,\n\tTDialect extends Dialect,\n> =\n\t& {\n\t\t[Key in keyof TConfigMap]: BuildIndexColumn<TDialect>;\n\t}\n\t& {};\n\nexport type ChangeColumnTableName<TColumn extends Column, TAlias extends string, TDialect extends Dialect> =\n\tTDialect extends 'pg' ? PgColumn<MakeColumnConfig<TColumn['_'], TAlias>>\n\t\t: TDialect extends 'mysql' ? MySqlColumn<MakeColumnConfig<TColumn['_'], TAlias>>\n\t\t: TDialect extends 'singlestore' ? SingleStoreColumn<MakeColumnConfig<TColumn['_'], TAlias>>\n\t\t: TDialect extends 'sqlite' ? SQLiteColumn<MakeColumnConfig<TColumn['_'], TAlias>>\n\t\t: TDialect extends 'gel' ? GelColumn<MakeColumnConfig<TColumn['_'], TAlias>>\n\t\t: never;\n","import { entityKind } from '~/entity.ts';\nimport { TableName } from '~/table.utils.ts';\nimport type { AnyPgColumn, PgColumn } from './columns/index.ts';\nimport type { PgTable } from './table.ts';\n\nexport type UpdateDeleteAction = 'cascade' | 'restrict' | 'no action' | 'set null' | 'set default';\n\nexport type Reference = () => {\n\treadonly name?: string;\n\treadonly columns: PgColumn[];\n\treadonly foreignTable: PgTable;\n\treadonly foreignColumns: PgColumn[];\n};\n\nexport class ForeignKeyBuilder {\n\tstatic readonly [entityKind]: string = 'PgForeignKeyBuilder';\n\n\t/** @internal */\n\treference: Reference;\n\n\t/** @internal */\n\t_onUpdate: UpdateDeleteAction | undefined = 'no action';\n\n\t/** @internal */\n\t_onDelete: UpdateDeleteAction | undefined = 'no action';\n\n\tconstructor(\n\t\tconfig: () => {\n\t\t\tname?: string;\n\t\t\tcolumns: PgColumn[];\n\t\t\tforeignColumns: PgColumn[];\n\t\t},\n\t\tactions?: {\n\t\t\tonUpdate?: UpdateDeleteAction;\n\t\t\tonDelete?: UpdateDeleteAction;\n\t\t} | undefined,\n\t) {\n\t\tthis.reference = () => {\n\t\t\tconst { name, columns, foreignColumns } = config();\n\t\t\treturn { name, columns, foreignTable: foreignColumns[0]!.table as PgTable, foreignColumns };\n\t\t};\n\t\tif (actions) {\n\t\t\tthis._onUpdate = actions.onUpdate;\n\t\t\tthis._onDelete = actions.onDelete;\n\t\t}\n\t}\n\n\tonUpdate(action: UpdateDeleteAction): this {\n\t\tthis._onUpdate = action === undefined ? 'no action' : action;\n\t\treturn this;\n\t}\n\n\tonDelete(action: UpdateDeleteAction): this {\n\t\tthis._onDelete = action === undefined ? 'no action' : action;\n\t\treturn this;\n\t}\n\n\t/** @internal */\n\tbuild(table: PgTable): ForeignKey {\n\t\treturn new ForeignKey(table, this);\n\t}\n}\n\nexport type AnyForeignKeyBuilder = ForeignKeyBuilder;\n\nexport class ForeignKey {\n\tstatic readonly [entityKind]: string = 'PgForeignKey';\n\n\treadonly reference: Reference;\n\treadonly onUpdate: UpdateDeleteAction | undefined;\n\treadonly onDelete: UpdateDeleteAction | undefined;\n\n\tconstructor(readonly table: PgTable, builder: ForeignKeyBuilder) {\n\t\tthis.reference = builder.reference;\n\t\tthis.onUpdate = builder._onUpdate;\n\t\tthis.onDelete = builder._onDelete;\n\t}\n\n\tgetName(): string {\n\t\tconst { name, columns, foreignColumns } = this.reference();\n\t\tconst columnNames = columns.map((column) => column.name);\n\t\tconst foreignColumnNames = foreignColumns.map((column) => column.name);\n\t\tconst chunks = [\n\t\t\tthis.table[TableName],\n\t\t\t...columnNames,\n\t\t\tforeignColumns[0]!.table[TableName],\n\t\t\t...foreignColumnNames,\n\t\t];\n\t\treturn name ?? `${chunks.join('_')}_fk`;\n\t}\n}\n\ntype ColumnsWithTable<\n\tTTableName extends string,\n\tTColumns extends PgColumn[],\n> = { [Key in keyof TColumns]: AnyPgColumn<{ tableName: TTableName }> };\n\nexport function foreignKey<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends [AnyPgColumn<{ tableName: TTableName }>, ...AnyPgColumn<{ tableName: TTableName }>[]],\n>(\n\tconfig: {\n\t\tname?: string;\n\t\tcolumns: TColumns;\n\t\tforeignColumns: ColumnsWithTable<TForeignTableName, TColumns>;\n\t},\n): ForeignKeyBuilder {\n\tfunction mappedConfig() {\n\t\tconst { name, columns, foreignColumns } = config;\n\t\treturn {\n\t\t\tname,\n\t\t\tcolumns,\n\t\t\tforeignColumns,\n\t\t};\n\t}\n\n\treturn new ForeignKeyBuilder(mappedConfig);\n}\n","export function iife<T extends unknown[], U>(fn: (...args: T) => U, ...args: T): U {\n\treturn fn(...args);\n}\n","import { entityKind } from '~/entity.ts';\nimport { TableName } from '~/table.utils.ts';\nimport type { PgColumn } from './columns/index.ts';\nimport type { PgTable } from './table.ts';\n\nexport function unique(name?: string): UniqueOnConstraintBuilder {\n\treturn new UniqueOnConstraintBuilder(name);\n}\n\nexport function uniqueKeyName(table: PgTable, columns: string[]) {\n\treturn `${table[TableName]}_${columns.join('_')}_unique`;\n}\n\nexport class UniqueConstraintBuilder {\n\tstatic readonly [entityKind]: string = 'PgUniqueConstraintBuilder';\n\n\t/** @internal */\n\tcolumns: PgColumn[];\n\t/** @internal */\n\tnullsNotDistinctConfig = false;\n\n\tconstructor(\n\t\tcolumns: PgColumn[],\n\t\tprivate name?: string,\n\t) {\n\t\tthis.columns = columns;\n\t}\n\n\tnullsNotDistinct() {\n\t\tthis.nullsNotDistinctConfig = true;\n\t\treturn this;\n\t}\n\n\t/** @internal */\n\tbuild(table: PgTable): UniqueConstraint {\n\t\treturn new UniqueConstraint(table, this.columns, this.nullsNotDistinctConfig, this.name);\n\t}\n}\n\nexport class UniqueOnConstraintBuilder {\n\tstatic readonly [entityKind]: string = 'PgUniqueOnConstraintBuilder';\n\n\t/** @internal */\n\tname?: string;\n\n\tconstructor(\n\t\tname?: string,\n\t) {\n\t\tthis.name = name;\n\t}\n\n\ton(...columns: [PgColumn, ...PgColumn[]]) {\n\t\treturn new UniqueConstraintBuilder(columns, this.name);\n\t}\n}\n\nexport class UniqueConstraint {\n\tstatic readonly [entityKind]: string = 'PgUniqueConstraint';\n\n\treadonly columns: PgColumn[];\n\treadonly name?: string;\n\treadonly nullsNotDistinct: boolean = false;\n\n\tconstructor(readonly table: PgTable, columns: PgColumn[], nullsNotDistinct: boolean, name?: string) {\n\t\tthis.columns = columns;\n\t\tthis.name = name ?? uniqueKeyName(this.table, this.columns.map((column) => column.name));\n\t\tthis.nullsNotDistinct = nullsNotDistinct;\n\t}\n\n\tgetName() {\n\t\treturn this.name;\n\t}\n}\n","function parsePgArrayValue(arrayString: string, startFrom: number, inQuotes: boolean): [string, number] {\n\tfor (let i = startFrom; i < arrayString.length; i++) {\n\t\tconst char = arrayString[i];\n\n\t\tif (char === '\\\\') {\n\t\t\ti++;\n\t\t\tcontinue;\n\t\t}\n\n\t\tif (char === '\"') {\n\t\t\treturn [arrayString.slice(startFrom, i).replace(/\\\\/g, ''), i + 1];\n\t\t}\n\n\t\tif (inQuotes) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tif (char === ',' || char === '}') {\n\t\t\treturn [arrayString.slice(startFrom, i).replace(/\\\\/g, ''), i];\n\t\t}\n\t}\n\n\treturn [arrayString.slice(startFrom).replace(/\\\\/g, ''), arrayString.length];\n}\n\nexport function parsePgNestedArray(arrayString: string, startFrom = 0): [any[], number] {\n\tconst result: any[] = [];\n\tlet i = startFrom;\n\tlet lastCharIsComma = false;\n\n\twhile (i < arrayString.length) {\n\t\tconst char = arrayString[i];\n\n\t\tif (char === ',') {\n\t\t\tif (lastCharIsComma || i === startFrom) {\n\t\t\t\tresult.push('');\n\t\t\t}\n\t\t\tlastCharIsComma = true;\n\t\t\ti++;\n\t\t\tcontinue;\n\t\t}\n\n\t\tlastCharIsComma = false;\n\n\t\tif (char === '\\\\') {\n\t\t\ti += 2;\n\t\t\tcontinue;\n\t\t}\n\n\t\tif (char === '\"') {\n\t\t\tconst [value, startFrom] = parsePgArrayValue(arrayString, i + 1, true);\n\t\t\tresult.push(value);\n\t\t\ti = startFrom;\n\t\t\tcontinue;\n\t\t}\n\n\t\tif (char === '}') {\n\t\t\treturn [result, i + 1];\n\t\t}\n\n\t\tif (char === '{') {\n\t\t\tconst [value, startFrom] = parsePgNestedArray(arrayString, i + 1);\n\t\t\tresult.push(value);\n\t\t\ti = startFrom;\n\t\t\tcontinue;\n\t\t}\n\n\t\tconst [value, newStartFrom] = parsePgArrayValue(arrayString, i, false);\n\t\tresult.push(value);\n\t\ti = newStartFrom;\n\t}\n\n\treturn [result, i];\n}\n\nexport function parsePgArray(arrayString: string): any[] {\n\tconst [result] = parsePgNestedArray(arrayString, 1);\n\treturn result;\n}\n\nexport function makePgArray(array: any[]): string {\n\treturn `{${\n\t\tarray.map((item) => {\n\t\t\tif (Array.isArray(item)) {\n\t\t\t\treturn makePgArray(item);\n\t\t\t}\n\n\t\t\tif (typeof item === 'string') {\n\t\t\t\treturn `\"${item.replace(/\\\\/g, '\\\\\\\\').replace(/\"/g, '\\\\\"')}\"`;\n\t\t\t}\n\n\t\t\treturn `${item}`;\n\t\t}).join(',')\n\t}}`;\n}\n","import type {\n\tColumnBuilderBase,\n\tColumnBuilderBaseConfig,\n\tColumnBuilderExtraConfig,\n\tColumnBuilderRuntimeConfig,\n\tColumnDataType,\n\tHasGenerated,\n\tMakeColumnConfig,\n} from '~/column-builder.ts';\nimport { ColumnBuilder } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { Column } from '~/column.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport type { Simplify, Update } from '~/utils.ts';\n\nimport type { ForeignKey, UpdateDeleteAction } from '~/pg-core/foreign-keys.ts';\nimport { ForeignKeyBuilder } from '~/pg-core/foreign-keys.ts';\nimport type { AnyPgTable, PgTable } from '~/pg-core/table.ts';\nimport type { SQL } from '~/sql/sql.ts';\nimport { iife } from '~/tracing-utils.ts';\nimport type { PgIndexOpClass } from '../indexes.ts';\nimport { uniqueKeyName } from '../unique-constraint.ts';\nimport { makePgArray, parsePgArray } from '../utils/array.ts';\n\nexport interface ReferenceConfig {\n\tref: () => PgColumn;\n\tactions: {\n\t\tonUpdate?: UpdateDeleteAction;\n\t\tonDelete?: UpdateDeleteAction;\n\t};\n}\n\nexport interface PgColumnBuilderBase<\n\tT extends ColumnBuilderBaseConfig<ColumnDataType, string> = ColumnBuilderBaseConfig<ColumnDataType, string>,\n\tTTypeConfig extends object = object,\n> extends ColumnBuilderBase<T, TTypeConfig & { dialect: 'pg' }> {}\n\nexport abstract class PgColumnBuilder<\n\tT extends ColumnBuilderBaseConfig<ColumnDataType, string> = ColumnBuilderBaseConfig<ColumnDataType, string>,\n\tTRuntimeConfig extends object = object,\n\tTTypeConfig extends object = object,\n\tTExtraConfig extends ColumnBuilderExtraConfig = ColumnBuilderExtraConfig,\n> extends ColumnBuilder<T, TRuntimeConfig, TTypeConfig & { dialect: 'pg' }, TExtraConfig>\n\timplements PgColumnBuilderBase<T, TTypeConfig>\n{\n\tprivate foreignKeyConfigs: ReferenceConfig[] = [];\n\n\tstatic override readonly [entityKind]: string = 'PgColumnBuilder';\n\n\tarray<TSize extends number | undefined = undefined>(size?: TSize): PgArrayBuilder<\n\t\t& {\n\t\t\tname: T['name'];\n\t\t\tdataType: 'array';\n\t\t\tcolumnType: 'PgArray';\n\t\t\tdata: T['data'][];\n\t\t\tdriverParam: T['driverParam'][] | string;\n\t\t\tenumValues: T['enumValues'];\n\t\t\tsize: TSize;\n\t\t\tbaseBuilder: T;\n\t\t}\n\t\t& (T extends { notNull: true } ? { notNull: true } : {})\n\t\t& (T extends { hasDefault: true } ? { hasDefault: true } : {}),\n\t\tT\n\t> {\n\t\treturn new PgArrayBuilder(this.config.name, this as PgColumnBuilder<any, any>, size as any);\n\t}\n\n\treferences(\n\t\tref: ReferenceConfig['ref'],\n\t\tactions: ReferenceConfig['actions'] = {},\n\t): this {\n\t\tthis.foreignKeyConfigs.push({ ref, actions });\n\t\treturn this;\n\t}\n\n\tunique(\n\t\tname?: string,\n\t\tconfig?: { nulls: 'distinct' | 'not distinct' },\n\t): this {\n\t\tthis.config.isUnique = true;\n\t\tthis.config.uniqueName = name;\n\t\tthis.config.uniqueType = config?.nulls;\n\t\treturn this;\n\t}\n\n\tgeneratedAlwaysAs(as: SQL | T['data'] | (() => SQL)): HasGenerated<this, {\n\t\ttype: 'always';\n\t}> {\n\t\tthis.config.generated = {\n\t\t\tas,\n\t\t\ttype: 'always',\n\t\t\tmode: 'stored',\n\t\t};\n\t\treturn this as HasGenerated<this, {\n\t\t\ttype: 'always';\n\t\t}>;\n\t}\n\n\t/** @internal */\n\tbuildForeignKeys(column: PgColumn, table: PgTable): ForeignKey[] {\n\t\treturn this.foreignKeyConfigs.map(({ ref, actions }) => {\n\t\t\treturn iife(\n\t\t\t\t(ref, actions) => {\n\t\t\t\t\tconst builder = new ForeignKeyBuilder(() => {\n\t\t\t\t\t\tconst foreignColumn = ref();\n\t\t\t\t\t\treturn { columns: [column], foreignColumns: [foreignColumn] };\n\t\t\t\t\t});\n\t\t\t\t\tif (actions.onUpdate) {\n\t\t\t\t\t\tbuilder.onUpdate(actions.onUpdate);\n\t\t\t\t\t}\n\t\t\t\t\tif (actions.onDelete) {\n\t\t\t\t\t\tbuilder.onDelete(actions.onDelete);\n\t\t\t\t\t}\n\t\t\t\t\treturn builder.build(table);\n\t\t\t\t},\n\t\t\t\tref,\n\t\t\t\tactions,\n\t\t\t);\n\t\t});\n\t}\n\n\t/** @internal */\n\tabstract build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgColumn<MakeColumnConfig<T, TTableName>>;\n\n\t/** @internal */\n\tbuildExtraConfigColumn<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): ExtraConfigColumn {\n\t\treturn new ExtraConfigColumn(table, this.config);\n\t}\n}\n\n// To understand how to use `PgColumn` and `PgColumn`, see `Column` and `AnyColumn` documentation.\nexport abstract class PgColumn<\n\tT extends ColumnBaseConfig<ColumnDataType, string> = ColumnBaseConfig<ColumnDataType, string>,\n\tTRuntimeConfig extends object = {},\n\tTTypeConfig extends object = {},\n> extends Column<T, TRuntimeConfig, TTypeConfig & { dialect: 'pg' }> {\n\tstatic override readonly [entityKind]: string = 'PgColumn';\n\n\tconstructor(\n\t\toverride readonly table: PgTable,\n\t\tconfig: ColumnBuilderRuntimeConfig<T['data'], TRuntimeConfig>,\n\t) {\n\t\tif (!config.uniqueName) {\n\t\t\tconfig.uniqueName = uniqueKeyName(table, [config.name]);\n\t\t}\n\t\tsuper(table, config);\n\t}\n}\n\nexport type IndexedExtraConfigType = { order?: 'asc' | 'desc'; nulls?: 'first' | 'last'; opClass?: string };\n\nexport class ExtraConfigColumn<\n\tT extends ColumnBaseConfig<ColumnDataType, string> = ColumnBaseConfig<ColumnDataType, string>,\n> extends PgColumn<T, IndexedExtraConfigType> {\n\tstatic override readonly [entityKind]: string = 'ExtraConfigColumn';\n\n\toverride getSQLType(): string {\n\t\treturn this.getSQLType();\n\t}\n\n\tindexConfig: IndexedExtraConfigType = {\n\t\torder: this.config.order ?? 'asc',\n\t\tnulls: this.config.nulls ?? 'last',\n\t\topClass: this.config.opClass,\n\t};\n\tdefaultConfig: IndexedExtraConfigType = {\n\t\torder: 'asc',\n\t\tnulls: 'last',\n\t\topClass: undefined,\n\t};\n\n\tasc(): Omit<this, 'asc' | 'desc'> {\n\t\tthis.indexConfig.order = 'asc';\n\t\treturn this;\n\t}\n\n\tdesc(): Omit<this, 'asc' | 'desc'> {\n\t\tthis.indexConfig.order = 'desc';\n\t\treturn this;\n\t}\n\n\tnullsFirst(): Omit<this, 'nullsFirst' | 'nullsLast'> {\n\t\tthis.indexConfig.nulls = 'first';\n\t\treturn this;\n\t}\n\n\tnullsLast(): Omit<this, 'nullsFirst' | 'nullsLast'> {\n\t\tthis.indexConfig.nulls = 'last';\n\t\treturn this;\n\t}\n\n\t/**\n\t * ### PostgreSQL documentation quote\n\t *\n\t * > An operator class with optional parameters can be specified for each column of an index.\n\t * The operator class identifies the operators to be used by the index for that column.\n\t * For example, a B-tree index on four-byte integers would use the int4_ops class;\n\t * this operator class includes comparison functions for four-byte integers.\n\t * In practice the default operator class for the column's data type is usually sufficient.\n\t * The main point of having operator classes is that for some data types, there could be more than one meaningful ordering.\n\t * For example, we might want to sort a complex-number data type either by absolute value or by real part.\n\t * We could do this by defining two operator classes for the data type and then selecting the proper class when creating an index.\n\t * More information about operator classes check:\n\t *\n\t * ### Useful links\n\t * https://www.postgresql.org/docs/current/sql-createindex.html\n\t *\n\t * https://www.postgresql.org/docs/current/indexes-opclass.html\n\t *\n\t * https://www.postgresql.org/docs/current/xindex.html\n\t *\n\t * ### Additional types\n\t * If you have the `pg_vector` extension installed in your database, you can use the\n\t * `vector_l2_ops`, `vector_ip_ops`, `vector_cosine_ops`, `vector_l1_ops`, `bit_hamming_ops`, `bit_jaccard_ops`, `halfvec_l2_ops`, `sparsevec_l2_ops` options, which are predefined types.\n\t *\n\t * **You can always specify any string you want in the operator class, in case Drizzle doesn't have it natively in its types**\n\t *\n\t * @param opClass\n\t * @returns\n\t */\n\top(opClass: PgIndexOpClass): Omit<this, 'op'> {\n\t\tthis.indexConfig.opClass = opClass;\n\t\treturn this;\n\t}\n}\n\nexport class IndexedColumn {\n\tstatic readonly [entityKind]: string = 'IndexedColumn';\n\tconstructor(\n\t\tname: string | undefined,\n\t\tkeyAsName: boolean,\n\t\ttype: string,\n\t\tindexConfig: IndexedExtraConfigType,\n\t) {\n\t\tthis.name = name;\n\t\tthis.keyAsName = keyAsName;\n\t\tthis.type = type;\n\t\tthis.indexConfig = indexConfig;\n\t}\n\n\tname: string | undefined;\n\tkeyAsName: boolean;\n\ttype: string;\n\tindexConfig: IndexedExtraConfigType;\n}\n\nexport type AnyPgColumn<TPartial extends Partial<ColumnBaseConfig<ColumnDataType, string>> = {}> = PgColumn<\n\tRequired<Update<ColumnBaseConfig<ColumnDataType, string>, TPartial>>\n>;\n\nexport type PgArrayColumnBuilderBaseConfig = ColumnBuilderBaseConfig<'array', 'PgArray'> & {\n\tsize: number | undefined;\n\tbaseBuilder: ColumnBuilderBaseConfig<ColumnDataType, string>;\n};\n\nexport class PgArrayBuilder<\n\tT extends PgArrayColumnBuilderBaseConfig,\n\tTBase extends ColumnBuilderBaseConfig<ColumnDataType, string> | PgArrayColumnBuilderBaseConfig,\n> extends PgColumnBuilder<\n\tT,\n\t{\n\t\tbaseBuilder: TBase extends PgArrayColumnBuilderBaseConfig ? PgArrayBuilder<\n\t\t\t\tTBase,\n\t\t\t\tTBase extends { baseBuilder: infer TBaseBuilder extends ColumnBuilderBaseConfig<any, any> } ? TBaseBuilder\n\t\t\t\t\t: never\n\t\t\t>\n\t\t\t: PgColumnBuilder<TBase, {}, Simplify<Omit<TBase, keyof ColumnBuilderBaseConfig<any, any>>>>;\n\t\tsize: T['size'];\n\t},\n\t{\n\t\tbaseBuilder: TBase extends PgArrayColumnBuilderBaseConfig ? PgArrayBuilder<\n\t\t\t\tTBase,\n\t\t\t\tTBase extends { baseBuilder: infer TBaseBuilder extends ColumnBuilderBaseConfig<any, any> } ? TBaseBuilder\n\t\t\t\t\t: never\n\t\t\t>\n\t\t\t: PgColumnBuilder<TBase, {}, Simplify<Omit<TBase, keyof ColumnBuilderBaseConfig<any, any>>>>;\n\t\tsize: T['size'];\n\t}\n> {\n\tstatic override readonly [entityKind] = 'PgArrayBuilder';\n\n\tconstructor(\n\t\tname: string,\n\t\tbaseBuilder: PgArrayBuilder<T, TBase>['config']['baseBuilder'],\n\t\tsize: T['size'],\n\t) {\n\t\tsuper(name, 'array', 'PgArray');\n\t\tthis.config.baseBuilder = baseBuilder;\n\t\tthis.config.size = size;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgArray<MakeColumnConfig<T, TTableName> & { size: T['size']; baseBuilder: T['baseBuilder'] }, TBase> {\n\t\tconst baseColumn = this.config.baseBuilder.build(table);\n\t\treturn new PgArray<MakeColumnConfig<T, TTableName> & { size: T['size']; baseBuilder: T['baseBuilder'] }, TBase>(\n\t\t\ttable as AnyPgTable<{ name: MakeColumnConfig<T, TTableName>['tableName'] }>,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t\tbaseColumn,\n\t\t);\n\t}\n}\n\nexport class PgArray<\n\tT extends ColumnBaseConfig<'array', 'PgArray'> & {\n\t\tsize: number | undefined;\n\t\tbaseBuilder: ColumnBuilderBaseConfig<ColumnDataType, string>;\n\t},\n\tTBase extends ColumnBuilderBaseConfig<ColumnDataType, string>,\n> extends PgColumn<T, {}, { size: T['size']; baseBuilder: T['baseBuilder'] }> {\n\treadonly size: T['size'];\n\n\tstatic override readonly [entityKind]: string = 'PgArray';\n\n\tconstructor(\n\t\ttable: AnyPgTable<{ name: T['tableName'] }>,\n\t\tconfig: PgArrayBuilder<T, TBase>['config'],\n\t\treadonly baseColumn: PgColumn,\n\t\treadonly range?: [number | undefined, number | undefined],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.size = config.size;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn `${this.baseColumn.getSQLType()}[${typeof this.size === 'number' ? this.size : ''}]`;\n\t}\n\n\toverride mapFromDriverValue(value: unknown[] | string): T['data'] {\n\t\tif (typeof value === 'string') {\n\t\t\t// Thank you node-postgres for not parsing enum arrays\n\t\t\tvalue = parsePgArray(value);\n\t\t}\n\t\treturn value.map((v) => this.baseColumn.mapFromDriverValue(v));\n\t}\n\n\toverride mapToDriverValue(value: unknown[], isNestedArray = false): unknown[] | string {\n\t\tconst a = value.map((v) =>\n\t\t\tv === null\n\t\t\t\t? null\n\t\t\t\t: is(this.baseColumn, PgArray)\n\t\t\t\t? this.baseColumn.mapToDriverValue(v as unknown[], true)\n\t\t\t\t: this.baseColumn.mapToDriverValue(v)\n\t\t);\n\t\tif (isNestedArray) return a;\n\t\treturn makePgArray(a);\n\t}\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport type { NonArray, Writable } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\n// Enum as ts enum\n\nexport type PgEnumObjectColumnBuilderInitial<TName extends string, TValues extends object> = PgEnumObjectColumnBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgEnumObjectColumn';\n\tdata: TValues[keyof TValues];\n\tenumValues: string[];\n\tdriverParam: string;\n}>;\n\nexport interface PgEnumObject<TValues extends object> {\n\t(): PgEnumObjectColumnBuilderInitial<'', TValues>;\n\t<TName extends string>(name: TName): PgEnumObjectColumnBuilderInitial<TName, TValues>;\n\t<TName extends string>(name?: TName): PgEnumObjectColumnBuilderInitial<TName, TValues>;\n\n\treadonly enumName: string;\n\treadonly enumValues: string[];\n\treadonly schema: string | undefined;\n\t/** @internal */\n\t[isPgEnumSym]: true;\n}\n\nexport class PgEnumObjectColumnBuilder<\n\tT extends ColumnBuilderBaseConfig<'string', 'PgEnumObjectColumn'> & { enumValues: string[] },\n> extends PgColumnBuilder<T, { enum: PgEnumObject<any> }> {\n\tstatic override readonly [entityKind]: string = 'PgEnumObjectColumnBuilder';\n\n\tconstructor(name: T['name'], enumInstance: PgEnumObject<any>) {\n\t\tsuper(name, 'string', 'PgEnumObjectColumn');\n\t\tthis.config.enum = enumInstance;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgEnumObjectColumn<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgEnumObjectColumn<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgEnumObjectColumn<T extends ColumnBaseConfig<'string', 'PgEnumObjectColumn'> & { enumValues: object }>\n\textends PgColumn<T, { enum: PgEnumObject<object> }>\n{\n\tstatic override readonly [entityKind]: string = 'PgEnumObjectColumn';\n\n\treadonly enum;\n\toverride readonly enumValues = this.config.enum.enumValues;\n\n\tconstructor(\n\t\ttable: AnyPgTable<{ name: T['tableName'] }>,\n\t\tconfig: PgEnumObjectColumnBuilder<T>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.enum = config.enum;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.enum.enumName;\n\t}\n}\n\n// Enum as string union\n\nexport type PgEnumColumnBuilderInitial<TName extends string, TValues extends [string, ...string[]]> =\n\tPgEnumColumnBuilder<{\n\t\tname: TName;\n\t\tdataType: 'string';\n\t\tcolumnType: 'PgEnumColumn';\n\t\tdata: TValues[number];\n\t\tenumValues: TValues;\n\t\tdriverParam: string;\n\t}>;\n\nconst isPgEnumSym = Symbol.for('drizzle:isPgEnum');\nexport interface PgEnum<TValues extends [string, ...string[]]> {\n\t(): PgEnumColumnBuilderInitial<'', TValues>;\n\t<TName extends string>(name: TName): PgEnumColumnBuilderInitial<TName, TValues>;\n\t<TName extends string>(name?: TName): PgEnumColumnBuilderInitial<TName, TValues>;\n\n\treadonly enumName: string;\n\treadonly enumValues: TValues;\n\treadonly schema: string | undefined;\n\t/** @internal */\n\t[isPgEnumSym]: true;\n}\n\nexport function isPgEnum(obj: unknown): obj is PgEnum<[string, ...string[]]> {\n\treturn !!obj && typeof obj === 'function' && isPgEnumSym in obj && obj[isPgEnumSym] === true;\n}\n\nexport class PgEnumColumnBuilder<\n\tT extends ColumnBuilderBaseConfig<'string', 'PgEnumColumn'> & { enumValues: [string, ...string[]] },\n> extends PgColumnBuilder<T, { enum: PgEnum<T['enumValues']> }> {\n\tstatic override readonly [entityKind]: string = 'PgEnumColumnBuilder';\n\n\tconstructor(name: T['name'], enumInstance: PgEnum<T['enumValues']>) {\n\t\tsuper(name, 'string', 'PgEnumColumn');\n\t\tthis.config.enum = enumInstance;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgEnumColumn<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgEnumColumn<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgEnumColumn<T extends ColumnBaseConfig<'string', 'PgEnumColumn'> & { enumValues: [string, ...string[]] }>\n\textends PgColumn<T, { enum: PgEnum<T['enumValues']> }>\n{\n\tstatic override readonly [entityKind]: string = 'PgEnumColumn';\n\n\treadonly enum = this.config.enum;\n\toverride readonly enumValues = this.config.enum.enumValues;\n\n\tconstructor(\n\t\ttable: AnyPgTable<{ name: T['tableName'] }>,\n\t\tconfig: PgEnumColumnBuilder<T>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.enum = config.enum;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.enum.enumName;\n\t}\n}\n\nexport function pgEnum<U extends string, T extends Readonly<[U, ...U[]]>>(\n\tenumName: string,\n\tvalues: T | Writable<T>,\n): PgEnum<Writable<T>>;\n\nexport function pgEnum<E extends Record<string, string>>(\n\tenumName: string,\n\tenumObj: NonArray<E>,\n): PgEnumObject<E>;\n\nexport function pgEnum(\n\tenumName: any,\n\tinput: any,\n): any {\n\treturn Array.isArray(input)\n\t\t? pgEnumWithSchema(enumName, [...input] as [string, ...string[]], undefined)\n\t\t: pgEnumObjectWithSchema(enumName, input, undefined);\n}\n\n/** @internal */\nexport function pgEnumWithSchema<U extends string, T extends Readonly<[U, ...U[]]>>(\n\tenumName: string,\n\tvalues: T | Writable<T>,\n\tschema?: string,\n): PgEnum<Writable<T>> {\n\tconst enumInstance: PgEnum<Writable<T>> = Object.assign(\n\t\t<TName extends string>(name?: TName): PgEnumColumnBuilderInitial<TName, Writable<T>> =>\n\t\t\tnew PgEnumColumnBuilder(name ?? '' as TName, enumInstance),\n\t\t{\n\t\t\tenumName,\n\t\t\tenumValues: values,\n\t\t\tschema,\n\t\t\t[isPgEnumSym]: true,\n\t\t} as const,\n\t);\n\n\treturn enumInstance;\n}\n\n/** @internal */\nexport function pgEnumObjectWithSchema<T extends object>(\n\tenumName: string,\n\tvalues: T,\n\tschema?: string,\n): PgEnumObject<T> {\n\tconst enumInstance: PgEnumObject<T> = Object.assign(\n\t\t<TName extends string>(name?: TName): PgEnumObjectColumnBuilderInitial<TName, T> =>\n\t\t\tnew PgEnumObjectColumnBuilder(name ?? '' as TName, enumInstance),\n\t\t{\n\t\t\tenumName,\n\t\t\tenumValues: Object.values(values),\n\t\t\tschema,\n\t\t\t[isPgEnumSym]: true,\n\t\t} as const,\n\t);\n\n\treturn enumInstance;\n}\n","import { entityKind } from './entity.ts';\nimport type { SQL, SQLWrapper } from './sql/sql.ts';\n\nexport interface Subquery<\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTAlias extends string = string,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTSelectedFields extends Record<string, unknown> = Record<string, unknown>,\n> extends SQLWrapper {\n\t// SQLWrapper runtime implementation is defined in 'sql/sql.ts'\n}\nexport class Subquery<\n\tTAlias extends string = string,\n\tTSelectedFields extends Record<string, unknown> = Record<string, unknown>,\n> implements SQLWrapper {\n\tstatic readonly [entityKind]: string = 'Subquery';\n\n\tdeclare _: {\n\t\tbrand: 'Subquery';\n\t\tsql: SQL;\n\t\tselectedFields: TSelectedFields;\n\t\talias: TAlias;\n\t\tisWith: boolean;\n\t\tusedTables?: string[];\n\t};\n\n\tconstructor(sql: SQL, fields: TSelectedFields, alias: string, isWith = false, usedTables: string[] = []) {\n\t\tthis._ = {\n\t\t\tbrand: 'Subquery',\n\t\t\tsql,\n\t\t\tselectedFields: fields as TSelectedFields,\n\t\t\talias: alias as TAlias,\n\t\t\tisWith,\n\t\t\tusedTables,\n\t\t};\n\t}\n\n\t// getSQL(): SQL<unknown> {\n\t// \treturn new SQL([this]);\n\t// }\n}\n\nexport class WithSubquery<\n\tTAlias extends string = string,\n\tTSelection extends Record<string, unknown> = Record<string, unknown>,\n> extends Subquery<TAlias, TSelection> {\n\tstatic override readonly [entityKind]: string = 'WithSubquery';\n}\n\nexport type WithSubqueryWithoutSelection<TAlias extends string> = WithSubquery<TAlias, {}>;\n","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// src/version.ts\nvar version_exports = {};\n__export(version_exports, {\n compatibilityVersion: () => compatibilityVersion,\n npmVersion: () => version\n});\nmodule.exports = __toCommonJS(version_exports);\n\n// package.json\nvar version = \"0.45.2\";\n\n// src/version.ts\nvar compatibilityVersion = 10;\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n compatibilityVersion,\n npmVersion\n});\n","import type { Span, Tracer } from '@opentelemetry/api';\nimport { iife } from '~/tracing-utils.ts';\nimport { npmVersion } from '~/version.ts';\n\nlet otel: typeof import('@opentelemetry/api') | undefined;\nlet rawTracer: Tracer | undefined;\n// try {\n// \totel = await import('@opentelemetry/api');\n// } catch (err: any) {\n// \tif (err.code !== 'MODULE_NOT_FOUND' && err.code !== 'ERR_MODULE_NOT_FOUND') {\n// \t\tthrow err;\n// \t}\n// }\n\ntype SpanName =\n\t| 'drizzle.operation'\n\t| 'drizzle.prepareQuery'\n\t| 'drizzle.buildSQL'\n\t| 'drizzle.execute'\n\t| 'drizzle.driver.execute'\n\t| 'drizzle.mapResponse';\n\n/** @internal */\nexport const tracer = {\n\tstartActiveSpan<F extends (span?: Span) => unknown>(name: SpanName, fn: F): ReturnType<F> {\n\t\tif (!otel) {\n\t\t\treturn fn() as ReturnType<F>;\n\t\t}\n\n\t\tif (!rawTracer) {\n\t\t\trawTracer = otel.trace.getTracer('drizzle-orm', npmVersion);\n\t\t}\n\n\t\treturn iife(\n\t\t\t(otel, rawTracer) =>\n\t\t\t\trawTracer.startActiveSpan(\n\t\t\t\t\tname,\n\t\t\t\t\t((span: Span) => {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\treturn fn(span);\n\t\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\t\tspan.setStatus({\n\t\t\t\t\t\t\t\tcode: otel.SpanStatusCode.ERROR,\n\t\t\t\t\t\t\t\tmessage: e instanceof Error ? e.message : 'Unknown error', // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\tthrow e;\n\t\t\t\t\t\t} finally {\n\t\t\t\t\t\t\tspan.end();\n\t\t\t\t\t\t}\n\t\t\t\t\t}) as F,\n\t\t\t\t),\n\t\t\totel,\n\t\t\trawTracer,\n\t\t);\n\t},\n};\n","export const ViewBaseConfig = Symbol.for('drizzle:ViewBaseConfig');\n","import type { CasingCache } from '~/casing.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { isPgEnum } from '~/pg-core/columns/enum.ts';\nimport type { SelectResult } from '~/query-builders/select.types.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { tracer } from '~/tracing.ts';\nimport type { Assume, Equal } from '~/utils.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport type { AnyColumn } from '../column.ts';\nimport { Column } from '../column.ts';\nimport { IsAlias, Table } from '../table.ts';\n\n/**\n * This class is used to indicate a primitive param value that is used in `sql` tag.\n * It is only used on type level and is never instantiated at runtime.\n * If you see a value of this type in the code, its runtime value is actually the primitive param value.\n */\nexport class FakePrimitiveParam {\n\tstatic readonly [entityKind]: string = 'FakePrimitiveParam';\n}\n\nexport type Chunk =\n\t| string\n\t| Table\n\t| View\n\t| AnyColumn\n\t| Name\n\t| Param\n\t| Placeholder\n\t| SQL;\n\nexport interface BuildQueryConfig {\n\tcasing: CasingCache;\n\tescapeName(name: string): string;\n\tescapeParam(num: number, value: unknown): string;\n\tescapeString(str: string): string;\n\tprepareTyping?: (encoder: DriverValueEncoder<unknown, unknown>) => QueryTypingsValue;\n\tparamStartIndex?: { value: number };\n\tinlineParams?: boolean;\n\tinvokeSource?: 'indexes' | undefined;\n}\n\nexport type QueryTypingsValue = 'json' | 'decimal' | 'time' | 'timestamp' | 'uuid' | 'date' | 'none';\n\nexport interface Query {\n\tsql: string;\n\tparams: unknown[];\n}\n\nexport interface QueryWithTypings extends Query {\n\ttypings?: QueryTypingsValue[];\n}\n\n/**\n * Any value that implements the `getSQL` method. The implementations include:\n * - `Table`\n * - `Column`\n * - `View`\n * - `Subquery`\n * - `SQL`\n * - `SQL.Aliased`\n * - `Placeholder`\n * - `Param`\n */\nexport interface SQLWrapper {\n\tgetSQL(): SQL;\n\tshouldOmitSQLParens?(): boolean;\n}\n\nexport function isSQLWrapper(value: unknown): value is SQLWrapper {\n\treturn value !== null && value !== undefined && typeof (value as any).getSQL === 'function';\n}\n\nfunction mergeQueries(queries: QueryWithTypings[]): QueryWithTypings {\n\tconst result: QueryWithTypings = { sql: '', params: [] };\n\tfor (const query of queries) {\n\t\tresult.sql += query.sql;\n\t\tresult.params.push(...query.params);\n\t\tif (query.typings?.length) {\n\t\t\tif (!result.typings) {\n\t\t\t\tresult.typings = [];\n\t\t\t}\n\t\t\tresult.typings.push(...query.typings);\n\t\t}\n\t}\n\treturn result;\n}\n\nexport class StringChunk implements SQLWrapper {\n\tstatic readonly [entityKind]: string = 'StringChunk';\n\n\treadonly value: string[];\n\n\tconstructor(value: string | string[]) {\n\t\tthis.value = Array.isArray(value) ? value : [value];\n\t}\n\n\tgetSQL(): SQL<unknown> {\n\t\treturn new SQL([this]);\n\t}\n}\n\nexport class SQL<T = unknown> implements SQLWrapper {\n\tstatic readonly [entityKind]: string = 'SQL';\n\n\tdeclare _: {\n\t\tbrand: 'SQL';\n\t\ttype: T;\n\t};\n\n\t/** @internal */\n\tdecoder: DriverValueDecoder<T, any> = noopDecoder;\n\tprivate shouldInlineParams = false;\n\n\t/** @internal */\n\tusedTables: string[] = [];\n\n\tconstructor(readonly queryChunks: SQLChunk[]) {\n\t\tfor (const chunk of queryChunks) {\n\t\t\tif (is(chunk, Table)) {\n\t\t\t\tconst schemaName = chunk[Table.Symbol.Schema];\n\n\t\t\t\tthis.usedTables.push(\n\t\t\t\t\tschemaName === undefined\n\t\t\t\t\t\t? chunk[Table.Symbol.Name]\n\t\t\t\t\t\t: schemaName + '.' + chunk[Table.Symbol.Name],\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t}\n\n\tappend(query: SQL): this {\n\t\tthis.queryChunks.push(...query.queryChunks);\n\t\treturn this;\n\t}\n\n\ttoQuery(config: BuildQueryConfig): QueryWithTypings {\n\t\treturn tracer.startActiveSpan('drizzle.buildSQL', (span) => {\n\t\t\tconst query = this.buildQueryFromSourceParams(this.queryChunks, config);\n\t\t\tspan?.setAttributes({\n\t\t\t\t'drizzle.query.text': query.sql,\n\t\t\t\t'drizzle.query.params': JSON.stringify(query.params),\n\t\t\t});\n\t\t\treturn query;\n\t\t});\n\t}\n\n\tbuildQueryFromSourceParams(chunks: SQLChunk[], _config: BuildQueryConfig): Query {\n\t\tconst config = Object.assign({}, _config, {\n\t\t\tinlineParams: _config.inlineParams || this.shouldInlineParams,\n\t\t\tparamStartIndex: _config.paramStartIndex || { value: 0 },\n\t\t});\n\n\t\tconst {\n\t\t\tcasing,\n\t\t\tescapeName,\n\t\t\tescapeParam,\n\t\t\tprepareTyping,\n\t\t\tinlineParams,\n\t\t\tparamStartIndex,\n\t\t} = config;\n\n\t\treturn mergeQueries(chunks.map((chunk): QueryWithTypings => {\n\t\t\tif (is(chunk, StringChunk)) {\n\t\t\t\treturn { sql: chunk.value.join(''), params: [] };\n\t\t\t}\n\n\t\t\tif (is(chunk, Name)) {\n\t\t\t\treturn { sql: escapeName(chunk.value), params: [] };\n\t\t\t}\n\n\t\t\tif (chunk === undefined) {\n\t\t\t\treturn { sql: '', params: [] };\n\t\t\t}\n\n\t\t\tif (Array.isArray(chunk)) {\n\t\t\t\tconst result: SQLChunk[] = [new StringChunk('(')];\n\t\t\t\tfor (const [i, p] of chunk.entries()) {\n\t\t\t\t\tresult.push(p);\n\t\t\t\t\tif (i < chunk.length - 1) {\n\t\t\t\t\t\tresult.push(new StringChunk(', '));\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tresult.push(new StringChunk(')'));\n\t\t\t\treturn this.buildQueryFromSourceParams(result, config);\n\t\t\t}\n\n\t\t\tif (is(chunk, SQL)) {\n\t\t\t\treturn this.buildQueryFromSourceParams(chunk.queryChunks, {\n\t\t\t\t\t...config,\n\t\t\t\t\tinlineParams: inlineParams || chunk.shouldInlineParams,\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tif (is(chunk, Table)) {\n\t\t\t\tconst schemaName = chunk[Table.Symbol.Schema];\n\t\t\t\tconst tableName = chunk[Table.Symbol.Name];\n\t\t\t\treturn {\n\t\t\t\t\tsql: schemaName === undefined || chunk[IsAlias]\n\t\t\t\t\t\t? escapeName(tableName)\n\t\t\t\t\t\t: escapeName(schemaName) + '.' + escapeName(tableName),\n\t\t\t\t\tparams: [],\n\t\t\t\t};\n\t\t\t}\n\n\t\t\tif (is(chunk, Column)) {\n\t\t\t\tconst columnName = casing.getColumnCasing(chunk);\n\t\t\t\tif (_config.invokeSource === 'indexes') {\n\t\t\t\t\treturn { sql: escapeName(columnName), params: [] };\n\t\t\t\t}\n\n\t\t\t\tconst schemaName = chunk.table[Table.Symbol.Schema];\n\t\t\t\treturn {\n\t\t\t\t\tsql: chunk.table[IsAlias] || schemaName === undefined\n\t\t\t\t\t\t? escapeName(chunk.table[Table.Symbol.Name]) + '.' + escapeName(columnName)\n\t\t\t\t\t\t: escapeName(schemaName) + '.' + escapeName(chunk.table[Table.Symbol.Name]) + '.'\n\t\t\t\t\t\t\t+ escapeName(columnName),\n\t\t\t\t\tparams: [],\n\t\t\t\t};\n\t\t\t}\n\n\t\t\tif (is(chunk, View)) {\n\t\t\t\tconst schemaName = chunk[ViewBaseConfig].schema;\n\t\t\t\tconst viewName = chunk[ViewBaseConfig].name;\n\t\t\t\treturn {\n\t\t\t\t\tsql: schemaName === undefined || chunk[ViewBaseConfig].isAlias\n\t\t\t\t\t\t? escapeName(viewName)\n\t\t\t\t\t\t: escapeName(schemaName) + '.' + escapeName(viewName),\n\t\t\t\t\tparams: [],\n\t\t\t\t};\n\t\t\t}\n\n\t\t\tif (is(chunk, Param)) {\n\t\t\t\tif (is(chunk.value, Placeholder)) {\n\t\t\t\t\treturn { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: ['none'] };\n\t\t\t\t}\n\n\t\t\t\tconst mappedValue = chunk.value === null ? null : chunk.encoder.mapToDriverValue(chunk.value);\n\n\t\t\t\tif (is(mappedValue, SQL)) {\n\t\t\t\t\treturn this.buildQueryFromSourceParams([mappedValue], config);\n\t\t\t\t}\n\n\t\t\t\tif (inlineParams) {\n\t\t\t\t\treturn { sql: this.mapInlineParam(mappedValue, config), params: [] };\n\t\t\t\t}\n\n\t\t\t\tlet typings: QueryTypingsValue[] = ['none'];\n\t\t\t\tif (prepareTyping) {\n\t\t\t\t\ttypings = [prepareTyping(chunk.encoder)];\n\t\t\t\t}\n\n\t\t\t\treturn { sql: escapeParam(paramStartIndex.value++, mappedValue), params: [mappedValue], typings };\n\t\t\t}\n\n\t\t\tif (is(chunk, Placeholder)) {\n\t\t\t\treturn { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: ['none'] };\n\t\t\t}\n\n\t\t\tif (is(chunk, SQL.Aliased) && chunk.fieldAlias !== undefined) {\n\t\t\t\treturn { sql: escapeName(chunk.fieldAlias), params: [] };\n\t\t\t}\n\n\t\t\tif (is(chunk, Subquery)) {\n\t\t\t\tif (chunk._.isWith) {\n\t\t\t\t\treturn { sql: escapeName(chunk._.alias), params: [] };\n\t\t\t\t}\n\t\t\t\treturn this.buildQueryFromSourceParams([\n\t\t\t\t\tnew StringChunk('('),\n\t\t\t\t\tchunk._.sql,\n\t\t\t\t\tnew StringChunk(') '),\n\t\t\t\t\tnew Name(chunk._.alias),\n\t\t\t\t], config);\n\t\t\t}\n\n\t\t\tif (isPgEnum(chunk)) {\n\t\t\t\tif (chunk.schema) {\n\t\t\t\t\treturn { sql: escapeName(chunk.schema) + '.' + escapeName(chunk.enumName), params: [] };\n\t\t\t\t}\n\t\t\t\treturn { sql: escapeName(chunk.enumName), params: [] };\n\t\t\t}\n\n\t\t\tif (isSQLWrapper(chunk)) {\n\t\t\t\tif (chunk.shouldOmitSQLParens?.()) {\n\t\t\t\t\treturn this.buildQueryFromSourceParams([chunk.getSQL()], config);\n\t\t\t\t}\n\t\t\t\treturn this.buildQueryFromSourceParams([\n\t\t\t\t\tnew StringChunk('('),\n\t\t\t\t\tchunk.getSQL(),\n\t\t\t\t\tnew StringChunk(')'),\n\t\t\t\t], config);\n\t\t\t}\n\n\t\t\tif (inlineParams) {\n\t\t\t\treturn { sql: this.mapInlineParam(chunk, config), params: [] };\n\t\t\t}\n\n\t\t\treturn { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: ['none'] };\n\t\t}));\n\t}\n\n\tprivate mapInlineParam(\n\t\tchunk: unknown,\n\t\t{ escapeString }: BuildQueryConfig,\n\t): string {\n\t\tif (chunk === null) {\n\t\t\treturn 'null';\n\t\t}\n\t\tif (typeof chunk === 'number' || typeof chunk === 'boolean') {\n\t\t\treturn chunk.toString();\n\t\t}\n\t\tif (typeof chunk === 'string') {\n\t\t\treturn escapeString(chunk);\n\t\t}\n\t\tif (typeof chunk === 'object') {\n\t\t\tconst mappedValueAsString = chunk.toString();\n\t\t\tif (mappedValueAsString === '[object Object]') {\n\t\t\t\treturn escapeString(JSON.stringify(chunk));\n\t\t\t}\n\t\t\treturn escapeString(mappedValueAsString);\n\t\t}\n\t\tthrow new Error('Unexpected param value: ' + chunk);\n\t}\n\n\tgetSQL(): SQL {\n\t\treturn this;\n\t}\n\n\tas(alias: string): SQL.Aliased<T>;\n\t/**\n\t * @deprecated\n\t * Use ``sql<DataType>`query`.as(alias)`` instead.\n\t */\n\tas<TData>(): SQL<TData>;\n\t/**\n\t * @deprecated\n\t * Use ``sql<DataType>`query`.as(alias)`` instead.\n\t */\n\tas<TData>(alias: string): SQL.Aliased<TData>;\n\tas(alias?: string): SQL<T> | SQL.Aliased<T> {\n\t\t// TODO: remove with deprecated overloads\n\t\tif (alias === undefined) {\n\t\t\treturn this;\n\t\t}\n\n\t\treturn new SQL.Aliased(this, alias);\n\t}\n\n\tmapWith<\n\t\tTDecoder extends\n\t\t\t| DriverValueDecoder<any, any>\n\t\t\t| DriverValueDecoder<any, any>['mapFromDriverValue'],\n\t>(decoder: TDecoder): SQL<GetDecoderResult<TDecoder>> {\n\t\tthis.decoder = typeof decoder === 'function' ? { mapFromDriverValue: decoder } : decoder;\n\t\treturn this as SQL<GetDecoderResult<TDecoder>>;\n\t}\n\n\tinlineParams(): this {\n\t\tthis.shouldInlineParams = true;\n\t\treturn this;\n\t}\n\n\t/**\n\t * This method is used to conditionally include a part of the query.\n\t *\n\t * @param condition - Condition to check\n\t * @returns itself if the condition is `true`, otherwise `undefined`\n\t */\n\tif(condition: any | undefined): this | undefined {\n\t\treturn condition ? this : undefined;\n\t}\n}\n\nexport type GetDecoderResult<T> = T extends Column ? T['_']['data'] : T extends\n\t| DriverValueDecoder<infer TData, any>\n\t| DriverValueDecoder<infer TData, any>['mapFromDriverValue'] ? TData\n: never;\n\n/**\n * Any DB name (table, column, index etc.)\n */\nexport class Name implements SQLWrapper {\n\tstatic readonly [entityKind]: string = 'Name';\n\n\tprotected brand!: 'Name';\n\n\tconstructor(readonly value: string) {}\n\n\tgetSQL(): SQL<unknown> {\n\t\treturn new SQL([this]);\n\t}\n}\n\n/**\n * Any DB name (table, column, index etc.)\n * @deprecated Use `sql.identifier` instead.\n */\nexport function name(value: string): Name {\n\treturn new Name(value);\n}\n\nexport interface DriverValueDecoder<TData, TDriverParam> {\n\tmapFromDriverValue(value: TDriverParam): TData;\n}\n\nexport interface DriverValueEncoder<TData, TDriverParam> {\n\tmapToDriverValue(value: TData): TDriverParam | SQL;\n}\n\nexport function isDriverValueEncoder(value: unknown): value is DriverValueEncoder<any, any> {\n\treturn typeof value === 'object' && value !== null && 'mapToDriverValue' in value\n\t\t&& typeof (value as any).mapToDriverValue === 'function';\n}\n\nexport const noopDecoder: DriverValueDecoder<any, any> = {\n\tmapFromDriverValue: (value) => value,\n};\n\nexport const noopEncoder: DriverValueEncoder<any, any> = {\n\tmapToDriverValue: (value) => value,\n};\n\nexport interface DriverValueMapper<TData, TDriverParam>\n\textends DriverValueDecoder<TData, TDriverParam>, DriverValueEncoder<TData, TDriverParam>\n{}\n\nexport const noopMapper: DriverValueMapper<any, any> = {\n\t...noopDecoder,\n\t...noopEncoder,\n};\n\n/** Parameter value that is optionally bound to an encoder (for example, a column). */\nexport class Param<TDataType = unknown, TDriverParamType = TDataType> implements SQLWrapper {\n\tstatic readonly [entityKind]: string = 'Param';\n\n\tprotected brand!: 'BoundParamValue';\n\n\t/**\n\t * @param value - Parameter value\n\t * @param encoder - Encoder to convert the value to a driver parameter\n\t */\n\tconstructor(\n\t\treadonly value: TDataType,\n\t\treadonly encoder: DriverValueEncoder<TDataType, TDriverParamType> = noopEncoder,\n\t) {}\n\n\tgetSQL(): SQL<unknown> {\n\t\treturn new SQL([this]);\n\t}\n}\n\n/** @deprecated Use `sql.param` instead. */\nexport function param<TData, TDriver>(\n\tvalue: TData,\n\tencoder?: DriverValueEncoder<TData, TDriver>,\n): Param<TData, TDriver> {\n\treturn new Param(value, encoder);\n}\n\n/**\n * Anything that can be passed to the `` sql`...` `` tagged function.\n */\nexport type SQLChunk =\n\t| StringChunk\n\t| SQLChunk[]\n\t| SQLWrapper\n\t| SQL\n\t| Table\n\t| View\n\t| Subquery\n\t| AnyColumn\n\t| Param\n\t| Name\n\t| undefined\n\t| FakePrimitiveParam\n\t| Placeholder;\n\nexport function sql<T>(strings: TemplateStringsArray, ...params: any[]): SQL<T>;\n/*\n\tThe type of `params` is specified as `SQLChunk[]`, but that's slightly incorrect -\n\tin runtime, users won't pass `FakePrimitiveParam` instances as `params` - they will pass primitive values\n\twhich will be wrapped in `Param`. That's why the overload specifies `params` as `any[]` and not as `SQLSourceParam[]`.\n\tThis type is used to make our lives easier and the type checker happy.\n*/\nexport function sql(strings: TemplateStringsArray, ...params: SQLChunk[]): SQL {\n\tconst queryChunks: SQLChunk[] = [];\n\tif (params.length > 0 || (strings.length > 0 && strings[0] !== '')) {\n\t\tqueryChunks.push(new StringChunk(strings[0]!));\n\t}\n\tfor (const [paramIndex, param] of params.entries()) {\n\t\tqueryChunks.push(param, new StringChunk(strings[paramIndex + 1]!));\n\t}\n\n\treturn new SQL(queryChunks);\n}\n\nexport namespace sql {\n\texport function empty(): SQL {\n\t\treturn new SQL([]);\n\t}\n\n\t/** @deprecated - use `sql.join()` */\n\texport function fromList(list: SQLChunk[]): SQL {\n\t\treturn new SQL(list);\n\t}\n\n\t/**\n\t * Convenience function to create an SQL query from a raw string.\n\t * @param str The raw SQL query string.\n\t */\n\texport function raw(str: string): SQL {\n\t\treturn new SQL([new StringChunk(str)]);\n\t}\n\n\t/**\n\t * Join a list of SQL chunks with a separator.\n\t * @example\n\t * ```ts\n\t * const query = sql.join([sql`a`, sql`b`, sql`c`]);\n\t * // sql`abc`\n\t * ```\n\t * @example\n\t * ```ts\n\t * const query = sql.join([sql`a`, sql`b`, sql`c`], sql`, `);\n\t * // sql`a, b, c`\n\t * ```\n\t */\n\texport function join(chunks: SQLChunk[], separator?: SQLChunk): SQL {\n\t\tconst result: SQLChunk[] = [];\n\t\tfor (const [i, chunk] of chunks.entries()) {\n\t\t\tif (i > 0 && separator !== undefined) {\n\t\t\t\tresult.push(separator);\n\t\t\t}\n\t\t\tresult.push(chunk);\n\t\t}\n\t\treturn new SQL(result);\n\t}\n\n\t/**\n\t * Create a SQL chunk that represents a DB identifier (table, column, index etc.).\n\t * When used in a query, the identifier will be escaped based on the DB engine.\n\t * For example, in PostgreSQL, identifiers are escaped with double quotes.\n\t *\n\t * **WARNING: This function does not offer any protection against SQL injections, so you must validate any user input beforehand.**\n\t *\n\t * @example ```ts\n\t * const query = sql`SELECT * FROM ${sql.identifier('my-table')}`;\n\t * // 'SELECT * FROM \"my-table\"'\n\t * ```\n\t */\n\texport function identifier(value: string): Name {\n\t\treturn new Name(value);\n\t}\n\n\texport function placeholder<TName extends string>(name: TName): Placeholder<TName> {\n\t\treturn new Placeholder(name);\n\t}\n\n\texport function param<TData, TDriver>(\n\t\tvalue: TData,\n\t\tencoder?: DriverValueEncoder<TData, TDriver>,\n\t): Param<TData, TDriver> {\n\t\treturn new Param(value, encoder);\n\t}\n}\n\nexport namespace SQL {\n\texport class Aliased<T = unknown> implements SQLWrapper {\n\t\tstatic readonly [entityKind]: string = 'SQL.Aliased';\n\n\t\tdeclare _: {\n\t\t\tbrand: 'SQL.Aliased';\n\t\t\ttype: T;\n\t\t};\n\n\t\t/** @internal */\n\t\tisSelectionField = false;\n\n\t\tconstructor(\n\t\t\treadonly sql: SQL,\n\t\t\treadonly fieldAlias: string,\n\t\t) {}\n\n\t\tgetSQL(): SQL {\n\t\t\treturn this.sql;\n\t\t}\n\n\t\t/** @internal */\n\t\tclone() {\n\t\t\treturn new Aliased(this.sql, this.fieldAlias);\n\t\t}\n\t}\n}\n\nexport class Placeholder<TName extends string = string, TValue = any> implements SQLWrapper {\n\tstatic readonly [entityKind]: string = 'Placeholder';\n\n\tdeclare protected: TValue;\n\n\tconstructor(readonly name: TName) {}\n\n\tgetSQL(): SQL {\n\t\treturn new SQL([this]);\n\t}\n}\n\n/** @deprecated Use `sql.placeholder` instead. */\nexport function placeholder<TName extends string>(name: TName): Placeholder<TName> {\n\treturn new Placeholder(name);\n}\n\nexport function fillPlaceholders(params: unknown[], values: Record<string, unknown>): unknown[] {\n\treturn params.map((p) => {\n\t\tif (is(p, Placeholder)) {\n\t\t\tif (!(p.name in values)) {\n\t\t\t\tthrow new Error(`No value for placeholder \"${p.name}\" was provided`);\n\t\t\t}\n\n\t\t\treturn values[p.name];\n\t\t}\n\n\t\tif (is(p, Param) && is(p.value, Placeholder)) {\n\t\t\tif (!(p.value.name in values)) {\n\t\t\t\tthrow new Error(`No value for placeholder \"${p.value.name}\" was provided`);\n\t\t\t}\n\n\t\t\treturn p.encoder.mapToDriverValue(values[p.value.name]);\n\t\t}\n\n\t\treturn p;\n\t});\n}\n\nexport type ColumnsSelection = Record<string, unknown>;\n\nconst IsDrizzleView = Symbol.for('drizzle:IsDrizzleView');\n\nexport abstract class View<\n\tTName extends string = string,\n\tTExisting extends boolean = boolean,\n\tTSelection extends ColumnsSelection = ColumnsSelection,\n> implements SQLWrapper {\n\tstatic readonly [entityKind]: string = 'View';\n\n\tdeclare _: {\n\t\tbrand: 'View';\n\t\tviewBrand: string;\n\t\tname: TName;\n\t\texisting: TExisting;\n\t\tselectedFields: TSelection;\n\t};\n\n\t/** @internal */\n\t[ViewBaseConfig]: {\n\t\tname: TName;\n\t\toriginalName: TName;\n\t\tschema: string | undefined;\n\t\tselectedFields: ColumnsSelection;\n\t\tisExisting: TExisting;\n\t\tquery: TExisting extends true ? undefined : SQL;\n\t\tisAlias: boolean;\n\t};\n\n\t/** @internal */\n\t[IsDrizzleView] = true;\n\n\tdeclare readonly $inferSelect: InferSelectViewModel<View<Assume<TName, string>, TExisting, TSelection>>;\n\n\tconstructor(\n\t\t{ name, schema, selectedFields, query }: {\n\t\t\tname: TName;\n\t\t\tschema: string | undefined;\n\t\t\tselectedFields: ColumnsSelection;\n\t\t\tquery: SQL | undefined;\n\t\t},\n\t) {\n\t\tthis[ViewBaseConfig] = {\n\t\t\tname,\n\t\t\toriginalName: name,\n\t\t\tschema,\n\t\t\tselectedFields,\n\t\t\tquery: query as (TExisting extends true ? undefined : SQL),\n\t\t\tisExisting: !query as TExisting,\n\t\t\tisAlias: false,\n\t\t};\n\t}\n\n\tgetSQL(): SQL<unknown> {\n\t\treturn new SQL([this]);\n\t}\n}\n\nexport function isView(view: unknown): view is View {\n\treturn typeof view === 'object' && view !== null && IsDrizzleView in view;\n}\n\nexport function getViewName<T extends View>(view: T): T['_']['name'] {\n\treturn view[ViewBaseConfig].name;\n}\n\nexport type InferSelectViewModel<TView extends View> =\n\tEqual<TView['_']['selectedFields'], { [x: string]: unknown }> extends true ? { [x: string]: unknown }\n\t\t: SelectResult<\n\t\t\tTView['_']['selectedFields'],\n\t\t\t'single',\n\t\t\tRecord<TView['_']['name'], 'not-null'>\n\t\t>;\n\n// Defined separately from the Column class to resolve circular dependency\nColumn.prototype.getSQL = function() {\n\treturn new SQL([this]);\n};\n\n// Defined separately from the Table class to resolve circular dependency\nTable.prototype.getSQL = function() {\n\treturn new SQL([this]);\n};\n\n// Defined separately from the Column class to resolve circular dependency\nSubquery.prototype.getSQL = function() {\n\treturn new SQL([this]);\n};\n","import type { Cache } from './cache/core/cache.ts';\nimport type { AnyColumn } from './column.ts';\nimport { Column } from './column.ts';\nimport { is } from './entity.ts';\nimport type { Logger } from './logger.ts';\nimport type { SelectedFieldsOrdered } from './operations.ts';\nimport type { TableLike } from './query-builders/select.types.ts';\nimport { Param, SQL, View } from './sql/sql.ts';\nimport type { DriverValueDecoder } from './sql/sql.ts';\nimport { Subquery } from './subquery.ts';\nimport { getTableName, Table } from './table.ts';\nimport { ViewBaseConfig } from './view-common.ts';\n\n/** @internal */\nexport function mapResultRow<TResult>(\n\tcolumns: SelectedFieldsOrdered<AnyColumn>,\n\trow: unknown[],\n\tjoinsNotNullableMap: Record<string, boolean> | undefined,\n): TResult {\n\t// Key -> nested object key, value -> table name if all fields in the nested object are from the same table, false otherwise\n\tconst nullifyMap: Record<string, string | false> = {};\n\n\tconst result = columns.reduce<Record<string, any>>(\n\t\t(result, { path, field }, columnIndex) => {\n\t\t\tlet decoder: DriverValueDecoder<unknown, unknown>;\n\t\t\tif (is(field, Column)) {\n\t\t\t\tdecoder = field;\n\t\t\t} else if (is(field, SQL)) {\n\t\t\t\tdecoder = field.decoder;\n\t\t\t} else if (is(field, Subquery)) {\n\t\t\t\tdecoder = field._.sql.decoder;\n\t\t\t} else {\n\t\t\t\tdecoder = field.sql.decoder;\n\t\t\t}\n\t\t\tlet node = result;\n\t\t\tfor (const [pathChunkIndex, pathChunk] of path.entries()) {\n\t\t\t\tif (pathChunkIndex < path.length - 1) {\n\t\t\t\t\tif (!(pathChunk in node)) {\n\t\t\t\t\t\tnode[pathChunk] = {};\n\t\t\t\t\t}\n\t\t\t\t\tnode = node[pathChunk];\n\t\t\t\t} else {\n\t\t\t\t\tconst rawValue = row[columnIndex]!;\n\t\t\t\t\tconst value = node[pathChunk] = rawValue === null ? null : decoder.mapFromDriverValue(rawValue);\n\n\t\t\t\t\tif (joinsNotNullableMap && is(field, Column) && path.length === 2) {\n\t\t\t\t\t\tconst objectName = path[0]!;\n\t\t\t\t\t\tif (!(objectName in nullifyMap)) {\n\t\t\t\t\t\t\tnullifyMap[objectName] = value === null ? getTableName(field.table) : false;\n\t\t\t\t\t\t} else if (\n\t\t\t\t\t\t\ttypeof nullifyMap[objectName] === 'string' && nullifyMap[objectName] !== getTableName(field.table)\n\t\t\t\t\t\t) {\n\t\t\t\t\t\t\tnullifyMap[objectName] = false;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn result;\n\t\t},\n\t\t{},\n\t);\n\n\t// Nullify all nested objects from nullifyMap that are nullable\n\tif (joinsNotNullableMap && Object.keys(nullifyMap).length > 0) {\n\t\tfor (const [objectName, tableName] of Object.entries(nullifyMap)) {\n\t\t\tif (typeof tableName === 'string' && !joinsNotNullableMap[tableName]) {\n\t\t\t\tresult[objectName] = null;\n\t\t\t}\n\t\t}\n\t}\n\n\treturn result as TResult;\n}\n\n/** @internal */\nexport function orderSelectedFields<TColumn extends AnyColumn>(\n\tfields: Record<string, unknown>,\n\tpathPrefix?: string[],\n): SelectedFieldsOrdered<TColumn> {\n\treturn Object.entries(fields).reduce<SelectedFieldsOrdered<AnyColumn>>((result, [name, field]) => {\n\t\tif (typeof name !== 'string') {\n\t\t\treturn result;\n\t\t}\n\n\t\tconst newPath = pathPrefix ? [...pathPrefix, name] : [name];\n\t\tif (is(field, Column) || is(field, SQL) || is(field, SQL.Aliased) || is(field, Subquery)) {\n\t\t\tresult.push({ path: newPath, field });\n\t\t} else if (is(field, Table)) {\n\t\t\tresult.push(...orderSelectedFields(field[Table.Symbol.Columns], newPath));\n\t\t} else {\n\t\t\tresult.push(...orderSelectedFields(field as Record<string, unknown>, newPath));\n\t\t}\n\t\treturn result;\n\t}, []) as SelectedFieldsOrdered<TColumn>;\n}\n\nexport function haveSameKeys(left: Record<string, unknown>, right: Record<string, unknown>) {\n\tconst leftKeys = Object.keys(left);\n\tconst rightKeys = Object.keys(right);\n\n\tif (leftKeys.length !== rightKeys.length) {\n\t\treturn false;\n\t}\n\n\tfor (const [index, key] of leftKeys.entries()) {\n\t\tif (key !== rightKeys[index]) {\n\t\t\treturn false;\n\t\t}\n\t}\n\n\treturn true;\n}\n\n/** @internal */\nexport function mapUpdateSet(table: Table, values: Record<string, unknown>): UpdateSet {\n\tconst entries: [string, UpdateSet[string]][] = Object.entries(values)\n\t\t.filter(([, value]) => value !== undefined)\n\t\t.map(([key, value]) => {\n\t\t\t// eslint-disable-next-line unicorn/prefer-ternary\n\t\t\tif (is(value, SQL) || is(value, Column)) {\n\t\t\t\treturn [key, value];\n\t\t\t} else {\n\t\t\t\treturn [key, new Param(value, table[Table.Symbol.Columns][key])];\n\t\t\t}\n\t\t});\n\n\tif (entries.length === 0) {\n\t\tthrow new Error('No values to set');\n\t}\n\n\treturn Object.fromEntries(entries);\n}\n\nexport type UpdateSet = Record<string, SQL | Param | AnyColumn | null | undefined>;\n\nexport type OneOrMany<T> = T | T[];\n\nexport type Update<T, TUpdate> =\n\t& {\n\t\t[K in Exclude<keyof T, keyof TUpdate>]: T[K];\n\t}\n\t& TUpdate;\n\nexport type Simplify<T> =\n\t& {\n\t\t// @ts-ignore - \"Type parameter 'K' has a circular constraint\", not sure why\n\t\t[K in keyof T]: T[K];\n\t}\n\t& {};\n\nexport type Not<T extends boolean> = T extends true ? false : true;\n\nexport type IsNever<T> = [T] extends [never] ? true : false;\n\nexport type IsUnion<T, U extends T = T> = (T extends any ? (U extends T ? false : true) : never) extends false ? false\n\t: true;\n\nexport type SingleKeyObject<T, TError extends string, K = keyof T> = IsNever<K> extends true ? never\n\t: IsUnion<K> extends true ? DrizzleTypeError<TError>\n\t: T;\n\nexport type FromSingleKeyObject<T, Result, TError extends string, K = keyof T> = IsNever<K> extends true ? never\n\t: IsUnion<K> extends true ? DrizzleTypeError<TError>\n\t: Result;\n\nexport type SimplifyMappedType<T> = [T] extends [unknown] ? T : never;\n\nexport type ShallowRecord<K extends keyof any, T> = SimplifyMappedType<{ [P in K]: T }>;\n\nexport type Assume<T, U> = T extends U ? T : U;\n\nexport type Equal<X, Y> = (<T>() => T extends X ? 1 : 2) extends (<T>() => T extends Y ? 1 : 2) ? true : false;\n\nexport interface DrizzleTypeError<T extends string> {\n\t$drizzleTypeError: T;\n}\n\nexport type ValueOrArray<T> = T | T[];\n\n/** @internal */\nexport function applyMixins(baseClass: any, extendedClasses: any[]) {\n\tfor (const extendedClass of extendedClasses) {\n\t\tfor (const name of Object.getOwnPropertyNames(extendedClass.prototype)) {\n\t\t\tif (name === 'constructor') continue;\n\n\t\t\tObject.defineProperty(\n\t\t\t\tbaseClass.prototype,\n\t\t\t\tname,\n\t\t\t\tObject.getOwnPropertyDescriptor(extendedClass.prototype, name) || Object.create(null),\n\t\t\t);\n\t\t}\n\t}\n}\n\nexport type Or<T1, T2> = T1 extends true ? true : T2 extends true ? true : false;\n\nexport type IfThenElse<If, Then, Else> = If extends true ? Then : Else;\n\nexport type PromiseOf<T> = T extends Promise<infer U> ? U : T;\n\nexport type Writable<T> = {\n\t-readonly [P in keyof T]: T[P];\n};\n\nexport type NonArray<T> = T extends any[] ? never : T;\n\nexport function getTableColumns<T extends Table>(table: T): T['_']['columns'] {\n\treturn table[Table.Symbol.Columns];\n}\n\nexport function getViewSelectedFields<T extends View>(view: T): T['_']['selectedFields'] {\n\treturn view[ViewBaseConfig].selectedFields;\n}\n\n/** @internal */\nexport function getTableLikeName(table: TableLike): string | undefined {\n\treturn is(table, Subquery)\n\t\t? table._.alias\n\t\t: is(table, View)\n\t\t? table[ViewBaseConfig].name\n\t\t: is(table, SQL)\n\t\t? undefined\n\t\t: table[Table.Symbol.IsAlias]\n\t\t? table[Table.Symbol.Name]\n\t\t: table[Table.Symbol.BaseName];\n}\n\nexport type ColumnsWithTable<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends AnyColumn<{ tableName: TTableName }>[],\n> = { [Key in keyof TColumns]: AnyColumn<{ tableName: TForeignTableName }> };\n\nexport type Casing = 'snake_case' | 'camelCase';\n\nexport interface DrizzleConfig<TSchema extends Record<string, unknown> = Record<string, never>> {\n\tlogger?: boolean | Logger;\n\tschema?: TSchema;\n\tcasing?: Casing;\n\tcache?: Cache;\n}\nexport type ValidateShape<T, ValidShape, TResult = T> = T extends ValidShape\n\t? Exclude<keyof T, keyof ValidShape> extends never ? TResult\n\t: DrizzleTypeError<\n\t\t`Invalid key(s): ${Exclude<(keyof T) & (string | number | bigint | boolean | null | undefined), keyof ValidShape>}`\n\t>\n\t: never;\n\nexport type KnownKeysOnly<T, U> = {\n\t[K in keyof T]: K extends keyof U ? T[K] : never;\n};\n\nexport type IsAny<T> = 0 extends (1 & T) ? true : false;\n\n/** @internal */\nexport function getColumnNameAndConfig<\n\tTConfig extends Record<string, any> | undefined,\n>(a: string | TConfig | undefined, b: TConfig | undefined) {\n\treturn {\n\t\tname: typeof a === 'string' && a.length > 0 ? a : '' as string,\n\t\tconfig: typeof a === 'object' ? a : b as TConfig,\n\t};\n}\n\nexport type IfNotImported<T, Y, N> = unknown extends T ? Y : N;\n\nexport type ImportTypeError<TPackageName extends string> =\n\t`Please install \\`${TPackageName}\\` to allow Drizzle ORM to connect to the database`;\n\nexport type RequireAtLeastOne<T, Keys extends keyof T = keyof T> = Keys extends any\n\t? Required<Pick<T, Keys>> & Partial<Omit<T, Keys>>\n\t: never;\n\ntype ExpectedConfigShape = {\n\tlogger?: boolean | {\n\t\tlogQuery(query: string, params: unknown[]): void;\n\t};\n\tschema?: Record<string, never>;\n\tcasing?: 'snake_case' | 'camelCase';\n};\n\n// If this errors, you must update config shape checker function with new config specs\nconst _: DrizzleConfig = {} as ExpectedConfigShape;\nconst __: ExpectedConfigShape = {} as DrizzleConfig;\n\nexport function isConfig(data: any): boolean {\n\tif (typeof data !== 'object' || data === null) return false;\n\n\tif (data.constructor.name !== 'Object') return false;\n\n\tif ('logger' in data) {\n\t\tconst type = typeof data['logger'];\n\t\tif (\n\t\t\ttype !== 'boolean' && (type !== 'object' || typeof data['logger']['logQuery'] !== 'function')\n\t\t\t&& type !== 'undefined'\n\t\t) return false;\n\n\t\treturn true;\n\t}\n\n\tif ('schema' in data) {\n\t\tconst type = typeof data['schema'];\n\t\tif (type !== 'object' && type !== 'undefined') return false;\n\n\t\treturn true;\n\t}\n\n\tif ('casing' in data) {\n\t\tconst type = typeof data['casing'];\n\t\tif (type !== 'string' && type !== 'undefined') return false;\n\n\t\treturn true;\n\t}\n\n\tif ('mode' in data) {\n\t\tif (data['mode'] !== 'default' || data['mode'] !== 'planetscale' || data['mode'] !== undefined) return false;\n\n\t\treturn true;\n\t}\n\n\tif ('connection' in data) {\n\t\tconst type = typeof data['connection'];\n\t\tif (type !== 'string' && type !== 'object' && type !== 'undefined') return false;\n\n\t\treturn true;\n\t}\n\n\tif ('client' in data) {\n\t\tconst type = typeof data['client'];\n\t\tif (type !== 'object' && type !== 'function' && type !== 'undefined') return false;\n\n\t\treturn true;\n\t}\n\n\tif (Object.keys(data).length === 0) return true;\n\n\treturn false;\n}\n\nexport type NeonAuthToken = string | (() => string | Promise<string>);\n\nexport const textDecoder = typeof TextDecoder === 'undefined' ? null : new TextDecoder();\n","import type { ColumnBuilderBaseConfig, ColumnDataType, GeneratedIdentityConfig, IsIdentity } from '~/column-builder.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgSequenceOptions } from '../sequence.ts';\nimport { PgColumnBuilder } from './common.ts';\n\nexport abstract class PgIntColumnBaseBuilder<\n\tT extends ColumnBuilderBaseConfig<ColumnDataType, string>,\n> extends PgColumnBuilder<\n\tT,\n\t{ generatedIdentity: GeneratedIdentityConfig }\n> {\n\tstatic override readonly [entityKind]: string = 'PgIntColumnBaseBuilder';\n\n\tgeneratedAlwaysAsIdentity(\n\t\tsequence?: PgSequenceOptions & { name?: string },\n\t): IsIdentity<this, 'always'> {\n\t\tif (sequence) {\n\t\t\tconst { name, ...options } = sequence;\n\t\t\tthis.config.generatedIdentity = {\n\t\t\t\ttype: 'always',\n\t\t\t\tsequenceName: name,\n\t\t\t\tsequenceOptions: options,\n\t\t\t};\n\t\t} else {\n\t\t\tthis.config.generatedIdentity = {\n\t\t\t\ttype: 'always',\n\t\t\t};\n\t\t}\n\n\t\tthis.config.hasDefault = true;\n\t\tthis.config.notNull = true;\n\n\t\treturn this as IsIdentity<this, 'always'>;\n\t}\n\n\tgeneratedByDefaultAsIdentity(\n\t\tsequence?: PgSequenceOptions & { name?: string },\n\t): IsIdentity<this, 'byDefault'> {\n\t\tif (sequence) {\n\t\t\tconst { name, ...options } = sequence;\n\t\t\tthis.config.generatedIdentity = {\n\t\t\t\ttype: 'byDefault',\n\t\t\t\tsequenceName: name,\n\t\t\t\tsequenceOptions: options,\n\t\t\t};\n\t\t} else {\n\t\t\tthis.config.generatedIdentity = {\n\t\t\t\ttype: 'byDefault',\n\t\t\t};\n\t\t}\n\n\t\tthis.config.hasDefault = true;\n\t\tthis.config.notNull = true;\n\n\t\treturn this as IsIdentity<this, 'byDefault'>;\n\t}\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\n\nimport { getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn } from './common.ts';\nimport { PgIntColumnBaseBuilder } from './int.common.ts';\n\nexport type PgBigInt53BuilderInitial<TName extends string> = PgBigInt53Builder<{\n\tname: TName;\n\tdataType: 'number';\n\tcolumnType: 'PgBigInt53';\n\tdata: number;\n\tdriverParam: number | string;\n\tenumValues: undefined;\n}>;\n\nexport class PgBigInt53Builder<T extends ColumnBuilderBaseConfig<'number', 'PgBigInt53'>>\n\textends PgIntColumnBaseBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'PgBigInt53Builder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'number', 'PgBigInt53');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgBigInt53<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgBigInt53<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgBigInt53<T extends ColumnBaseConfig<'number', 'PgBigInt53'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgBigInt53';\n\n\tgetSQLType(): string {\n\t\treturn 'bigint';\n\t}\n\n\toverride mapFromDriverValue(value: number | string): number {\n\t\tif (typeof value === 'number') {\n\t\t\treturn value;\n\t\t}\n\t\treturn Number(value);\n\t}\n}\n\nexport type PgBigInt64BuilderInitial<TName extends string> = PgBigInt64Builder<{\n\tname: TName;\n\tdataType: 'bigint';\n\tcolumnType: 'PgBigInt64';\n\tdata: bigint;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgBigInt64Builder<T extends ColumnBuilderBaseConfig<'bigint', 'PgBigInt64'>>\n\textends PgIntColumnBaseBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'PgBigInt64Builder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'bigint', 'PgBigInt64');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgBigInt64<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgBigInt64<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgBigInt64<T extends ColumnBaseConfig<'bigint', 'PgBigInt64'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgBigInt64';\n\n\tgetSQLType(): string {\n\t\treturn 'bigint';\n\t}\n\n\t// eslint-disable-next-line unicorn/prefer-native-coercion-functions\n\toverride mapFromDriverValue(value: string): bigint {\n\t\treturn BigInt(value);\n\t}\n}\n\nexport interface PgBigIntConfig<T extends 'number' | 'bigint' = 'number' | 'bigint'> {\n\tmode: T;\n}\n\nexport function bigint<TMode extends PgBigIntConfig['mode']>(\n\tconfig: PgBigIntConfig<TMode>,\n): TMode extends 'number' ? PgBigInt53BuilderInitial<''> : PgBigInt64BuilderInitial<''>;\nexport function bigint<TName extends string, TMode extends PgBigIntConfig['mode']>(\n\tname: TName,\n\tconfig: PgBigIntConfig<TMode>,\n): TMode extends 'number' ? PgBigInt53BuilderInitial<TName> : PgBigInt64BuilderInitial<TName>;\nexport function bigint(a: string | PgBigIntConfig, b?: PgBigIntConfig) {\n\tconst { name, config } = getColumnNameAndConfig<PgBigIntConfig>(a, b);\n\tif (config.mode === 'number') {\n\t\treturn new PgBigInt53Builder(name);\n\t}\n\treturn new PgBigInt64Builder(name);\n}\n","import type {\n\tColumnBuilderBaseConfig,\n\tColumnBuilderRuntimeConfig,\n\tHasDefault,\n\tMakeColumnConfig,\n\tNotNull,\n} from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport { getColumnNameAndConfig } from '~/utils.ts';\nimport type { AnyPgTable } from '../table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgBigSerial53BuilderInitial<TName extends string> = NotNull<\n\tHasDefault<\n\t\tPgBigSerial53Builder<{\n\t\t\tname: TName;\n\t\t\tdataType: 'number';\n\t\t\tcolumnType: 'PgBigSerial53';\n\t\t\tdata: number;\n\t\t\tdriverParam: number;\n\t\t\tenumValues: undefined;\n\t\t}>\n\t>\n>;\n\nexport class PgBigSerial53Builder<T extends ColumnBuilderBaseConfig<'number', 'PgBigSerial53'>>\n\textends PgColumnBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'PgBigSerial53Builder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'number', 'PgBigSerial53');\n\t\tthis.config.hasDefault = true;\n\t\tthis.config.notNull = true;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgBigSerial53<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgBigSerial53<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgBigSerial53<T extends ColumnBaseConfig<'number', 'PgBigSerial53'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgBigSerial53';\n\n\tgetSQLType(): string {\n\t\treturn 'bigserial';\n\t}\n\n\toverride mapFromDriverValue(value: number): number {\n\t\tif (typeof value === 'number') {\n\t\t\treturn value;\n\t\t}\n\t\treturn Number(value);\n\t}\n}\n\nexport type PgBigSerial64BuilderInitial<TName extends string> = NotNull<\n\tHasDefault<\n\t\tPgBigSerial64Builder<{\n\t\t\tname: TName;\n\t\t\tdataType: 'bigint';\n\t\t\tcolumnType: 'PgBigSerial64';\n\t\t\tdata: bigint;\n\t\t\tdriverParam: string;\n\t\t\tenumValues: undefined;\n\t\t}>\n\t>\n>;\n\nexport class PgBigSerial64Builder<T extends ColumnBuilderBaseConfig<'bigint', 'PgBigSerial64'>>\n\textends PgColumnBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'PgBigSerial64Builder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'bigint', 'PgBigSerial64');\n\t\tthis.config.hasDefault = true;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgBigSerial64<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgBigSerial64<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgBigSerial64<T extends ColumnBaseConfig<'bigint', 'PgBigSerial64'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgBigSerial64';\n\n\tgetSQLType(): string {\n\t\treturn 'bigserial';\n\t}\n\n\t// eslint-disable-next-line unicorn/prefer-native-coercion-functions\n\toverride mapFromDriverValue(value: string): bigint {\n\t\treturn BigInt(value);\n\t}\n}\n\nexport interface PgBigSerialConfig<T extends 'number' | 'bigint' = 'number' | 'bigint'> {\n\tmode: T;\n}\n\nexport function bigserial<TMode extends PgBigSerialConfig['mode']>(\n\tconfig: PgBigSerialConfig<TMode>,\n): TMode extends 'number' ? PgBigSerial53BuilderInitial<''> : PgBigSerial64BuilderInitial<''>;\nexport function bigserial<TName extends string, TMode extends PgBigSerialConfig['mode']>(\n\tname: TName,\n\tconfig: PgBigSerialConfig<TMode>,\n): TMode extends 'number' ? PgBigSerial53BuilderInitial<TName> : PgBigSerial64BuilderInitial<TName>;\nexport function bigserial(a: string | PgBigSerialConfig, b?: PgBigSerialConfig) {\n\tconst { name, config } = getColumnNameAndConfig<PgBigSerialConfig>(a, b);\n\tif (config.mode === 'number') {\n\t\treturn new PgBigSerial53Builder(name);\n\t}\n\treturn new PgBigSerial64Builder(name);\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgBooleanBuilderInitial<TName extends string> = PgBooleanBuilder<{\n\tname: TName;\n\tdataType: 'boolean';\n\tcolumnType: 'PgBoolean';\n\tdata: boolean;\n\tdriverParam: boolean;\n\tenumValues: undefined;\n}>;\n\nexport class PgBooleanBuilder<T extends ColumnBuilderBaseConfig<'boolean', 'PgBoolean'>> extends PgColumnBuilder<T> {\n\tstatic override readonly [entityKind]: string = 'PgBooleanBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'boolean', 'PgBoolean');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgBoolean<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgBoolean<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgBoolean<T extends ColumnBaseConfig<'boolean', 'PgBoolean'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgBoolean';\n\n\tgetSQLType(): string {\n\t\treturn 'boolean';\n\t}\n}\n\nexport function boolean(): PgBooleanBuilderInitial<''>;\nexport function boolean<TName extends string>(name: TName): PgBooleanBuilderInitial<TName>;\nexport function boolean(name?: string) {\n\treturn new PgBooleanBuilder(name ?? '');\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { getColumnNameAndConfig, type Writable } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgCharBuilderInitial<\n\tTName extends string,\n\tTEnum extends [string, ...string[]],\n\tTLength extends number | undefined,\n> = PgCharBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgChar';\n\tdata: TEnum[number];\n\tenumValues: TEnum;\n\tdriverParam: string;\n\tlength: TLength;\n}>;\n\nexport class PgCharBuilder<T extends ColumnBuilderBaseConfig<'string', 'PgChar'> & { length?: number | undefined }>\n\textends PgColumnBuilder<\n\t\tT,\n\t\t{ length: T['length']; enumValues: T['enumValues'] },\n\t\t{ length: T['length'] }\n\t>\n{\n\tstatic override readonly [entityKind]: string = 'PgCharBuilder';\n\n\tconstructor(name: T['name'], config: PgCharConfig<T['enumValues'], T['length']>) {\n\t\tsuper(name, 'string', 'PgChar');\n\t\tthis.config.length = config.length;\n\t\tthis.config.enumValues = config.enum;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgChar<MakeColumnConfig<T, TTableName> & { length: T['length'] }> {\n\t\treturn new PgChar<MakeColumnConfig<T, TTableName> & { length: T['length'] }>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgChar<T extends ColumnBaseConfig<'string', 'PgChar'> & { length?: number | undefined }>\n\textends PgColumn<T, { length: T['length']; enumValues: T['enumValues'] }, { length: T['length'] }>\n{\n\tstatic override readonly [entityKind]: string = 'PgChar';\n\n\treadonly length = this.config.length;\n\toverride readonly enumValues = this.config.enumValues;\n\n\tgetSQLType(): string {\n\t\treturn this.length === undefined ? `char` : `char(${this.length})`;\n\t}\n}\n\nexport interface PgCharConfig<\n\tTEnum extends readonly string[] | string[] | undefined = readonly string[] | string[] | undefined,\n\tTLength extends number | undefined = number | undefined,\n> {\n\tenum?: TEnum;\n\tlength?: TLength;\n}\n\nexport function char(): PgCharBuilderInitial<'', [string, ...string[]], undefined>;\nexport function char<U extends string, T extends Readonly<[U, ...U[]]>, L extends number | undefined>(\n\tconfig?: PgCharConfig<T | Writable<T>, L>,\n): PgCharBuilderInitial<'', Writable<T>, L>;\nexport function char<\n\tTName extends string,\n\tU extends string,\n\tT extends Readonly<[U, ...U[]]>,\n\tL extends number | undefined,\n>(\n\tname: TName,\n\tconfig?: PgCharConfig<T | Writable<T>, L>,\n): PgCharBuilderInitial<TName, Writable<T>, L>;\nexport function char(a?: string | PgCharConfig, b: PgCharConfig = {}): any {\n\tconst { name, config } = getColumnNameAndConfig<PgCharConfig>(a, b);\n\treturn new PgCharBuilder(name, config as any);\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '../table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgCidrBuilderInitial<TName extends string> = PgCidrBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgCidr';\n\tdata: string;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgCidrBuilder<T extends ColumnBuilderBaseConfig<'string', 'PgCidr'>> extends PgColumnBuilder<T> {\n\tstatic override readonly [entityKind]: string = 'PgCidrBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'string', 'PgCidr');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgCidr<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgCidr<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgCidr<T extends ColumnBaseConfig<'string', 'PgCidr'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgCidr';\n\n\tgetSQLType(): string {\n\t\treturn 'cidr';\n\t}\n}\n\nexport function cidr(): PgCidrBuilderInitial<''>;\nexport function cidr<TName extends string>(name: TName): PgCidrBuilderInitial<TName>;\nexport function cidr(name?: string) {\n\treturn new PgCidrBuilder(name ?? '');\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport type { SQL } from '~/sql/sql.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type ConvertCustomConfig<TName extends string, T extends Partial<CustomTypeValues>> =\n\t& {\n\t\tname: TName;\n\t\tdataType: 'custom';\n\t\tcolumnType: 'PgCustomColumn';\n\t\tdata: T['data'];\n\t\tdriverParam: T['driverData'];\n\t\tenumValues: undefined;\n\t}\n\t& (T['notNull'] extends true ? { notNull: true } : {})\n\t& (T['default'] extends true ? { hasDefault: true } : {});\n\nexport interface PgCustomColumnInnerConfig {\n\tcustomTypeValues: CustomTypeValues;\n}\n\nexport class PgCustomColumnBuilder<T extends ColumnBuilderBaseConfig<'custom', 'PgCustomColumn'>>\n\textends PgColumnBuilder<\n\t\tT,\n\t\t{\n\t\t\tfieldConfig: CustomTypeValues['config'];\n\t\t\tcustomTypeParams: CustomTypeParams<any>;\n\t\t},\n\t\t{\n\t\t\tpgColumnBuilderBrand: 'PgCustomColumnBuilderBrand';\n\t\t}\n\t>\n{\n\tstatic override readonly [entityKind]: string = 'PgCustomColumnBuilder';\n\n\tconstructor(\n\t\tname: T['name'],\n\t\tfieldConfig: CustomTypeValues['config'],\n\t\tcustomTypeParams: CustomTypeParams<any>,\n\t) {\n\t\tsuper(name, 'custom', 'PgCustomColumn');\n\t\tthis.config.fieldConfig = fieldConfig;\n\t\tthis.config.customTypeParams = customTypeParams;\n\t}\n\n\t/** @internal */\n\tbuild<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgCustomColumn<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgCustomColumn<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgCustomColumn<T extends ColumnBaseConfig<'custom', 'PgCustomColumn'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgCustomColumn';\n\n\tprivate sqlName: string;\n\tprivate mapTo?: (value: T['data']) => T['driverParam'];\n\tprivate mapFrom?: (value: T['driverParam']) => T['data'];\n\n\tconstructor(\n\t\ttable: AnyPgTable<{ name: T['tableName'] }>,\n\t\tconfig: PgCustomColumnBuilder<T>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.sqlName = config.customTypeParams.dataType(config.fieldConfig);\n\t\tthis.mapTo = config.customTypeParams.toDriver;\n\t\tthis.mapFrom = config.customTypeParams.fromDriver;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.sqlName;\n\t}\n\n\toverride mapFromDriverValue(value: T['driverParam']): T['data'] {\n\t\treturn typeof this.mapFrom === 'function' ? this.mapFrom(value) : value as T['data'];\n\t}\n\n\toverride mapToDriverValue(value: T['data']): T['driverParam'] {\n\t\treturn typeof this.mapTo === 'function' ? this.mapTo(value) : value as T['data'];\n\t}\n}\n\nexport type CustomTypeValues = {\n\t/**\n\t * Required type for custom column, that will infer proper type model\n\t *\n\t * Examples:\n\t *\n\t * If you want your column to be `string` type after selecting/or on inserting - use `data: string`. Like `text`, `varchar`\n\t *\n\t * If you want your column to be `number` type after selecting/or on inserting - use `data: number`. Like `integer`\n\t */\n\tdata: unknown;\n\n\t/**\n\t * Type helper, that represents what type database driver is accepting for specific database data type\n\t */\n\tdriverData?: unknown;\n\n\t/**\n\t * What config type should be used for {@link CustomTypeParams} `dataType` generation\n\t */\n\tconfig?: Record<string, any>;\n\n\t/**\n\t * Whether the config argument should be required or not\n\t * @default false\n\t */\n\tconfigRequired?: boolean;\n\n\t/**\n\t * If your custom data type should be notNull by default you can use `notNull: true`\n\t *\n\t * @example\n\t * const customSerial = customType<{ data: number, notNull: true, default: true }>({\n\t * \t dataType() {\n\t * \t return 'serial';\n\t * },\n\t * });\n\t */\n\tnotNull?: boolean;\n\n\t/**\n\t * If your custom data type has default you can use `default: true`\n\t *\n\t * @example\n\t * const customSerial = customType<{ data: number, notNull: true, default: true }>({\n\t * \t dataType() {\n\t * \t return 'serial';\n\t * },\n\t * });\n\t */\n\tdefault?: boolean;\n};\n\nexport interface CustomTypeParams<T extends CustomTypeValues> {\n\t/**\n\t * Database data type string representation, that is used for migrations\n\t * @example\n\t * ```\n\t * `jsonb`, `text`\n\t * ```\n\t *\n\t * If database data type needs additional params you can use them from `config` param\n\t * @example\n\t * ```\n\t * `varchar(256)`, `numeric(2,3)`\n\t * ```\n\t *\n\t * To make `config` be of specific type please use config generic in {@link CustomTypeValues}\n\t *\n\t * @example\n\t * Usage example\n\t * ```\n\t * dataType() {\n\t * return 'boolean';\n\t * },\n\t * ```\n\t * Or\n\t * ```\n\t * dataType(config) {\n\t * \t return typeof config.length !== 'undefined' ? `varchar(${config.length})` : `varchar`;\n\t * \t }\n\t * ```\n\t */\n\tdataType: (config: T['config'] | (Equal<T['configRequired'], true> extends true ? never : undefined)) => string;\n\n\t/**\n\t * Optional mapping function, between user input and driver\n\t * @example\n\t * For example, when using jsonb we need to map JS/TS object to string before writing to database\n\t * ```\n\t * toDriver(value: TData): string {\n\t * \t return JSON.stringify(value);\n\t * }\n\t * ```\n\t */\n\ttoDriver?: (value: T['data']) => T['driverData'] | SQL;\n\n\t/**\n\t * Optional mapping function, that is responsible for data mapping from database to JS/TS code\n\t * @example\n\t * For example, when using timestamp we need to map string Date representation to JS Date\n\t * ```\n\t * fromDriver(value: string): Date {\n\t * \treturn new Date(value);\n\t * },\n\t * ```\n\t */\n\tfromDriver?: (value: T['driverData']) => T['data'];\n}\n\n/**\n * Custom pg database data type generator\n */\nexport function customType<T extends CustomTypeValues = CustomTypeValues>(\n\tcustomTypeParams: CustomTypeParams<T>,\n): Equal<T['configRequired'], true> extends true ? {\n\t\t<TConfig extends Record<string, any> & T['config']>(\n\t\t\tfieldConfig: TConfig,\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<'', T>>;\n\t\t<TName extends string>(\n\t\t\tdbName: TName,\n\t\t\tfieldConfig: T['config'],\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<TName, T>>;\n\t}\n\t: {\n\t\t(): PgCustomColumnBuilder<ConvertCustomConfig<'', T>>;\n\t\t<TConfig extends Record<string, any> & T['config']>(\n\t\t\tfieldConfig?: TConfig,\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<'', T>>;\n\t\t<TName extends string>(\n\t\t\tdbName: TName,\n\t\t\tfieldConfig?: T['config'],\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<TName, T>>;\n\t}\n{\n\treturn <TName extends string>(\n\t\ta?: TName | T['config'],\n\t\tb?: T['config'],\n\t): PgCustomColumnBuilder<ConvertCustomConfig<TName, T>> => {\n\t\tconst { name, config } = getColumnNameAndConfig<T['config']>(a, b);\n\t\treturn new PgCustomColumnBuilder(name as ConvertCustomConfig<TName, T>['name'], config, customTypeParams);\n\t};\n}\n","import type { ColumnBuilderBaseConfig, ColumnDataType } from '~/column-builder.ts';\nimport { entityKind } from '~/entity.ts';\nimport { sql } from '~/sql/sql.ts';\nimport { PgColumnBuilder } from './common.ts';\n\nexport abstract class PgDateColumnBaseBuilder<\n\tT extends ColumnBuilderBaseConfig<ColumnDataType, string>,\n\tTRuntimeConfig extends object = object,\n> extends PgColumnBuilder<T, TRuntimeConfig> {\n\tstatic override readonly [entityKind]: string = 'PgDateColumnBaseBuilder';\n\n\tdefaultNow() {\n\t\treturn this.default(sql`now()`);\n\t}\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn } from './common.ts';\nimport { PgDateColumnBaseBuilder } from './date.common.ts';\n\nexport type PgDateBuilderInitial<TName extends string> = PgDateBuilder<{\n\tname: TName;\n\tdataType: 'date';\n\tcolumnType: 'PgDate';\n\tdata: Date;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgDateBuilder<T extends ColumnBuilderBaseConfig<'date', 'PgDate'>> extends PgDateColumnBaseBuilder<T> {\n\tstatic override readonly [entityKind]: string = 'PgDateBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'date', 'PgDate');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgDate<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgDate<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgDate<T extends ColumnBaseConfig<'date', 'PgDate'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgDate';\n\n\tgetSQLType(): string {\n\t\treturn 'date';\n\t}\n\n\toverride mapFromDriverValue(value: string | Date): Date {\n\t\tif (typeof value === 'string') return new Date(value);\n\n\t\treturn value;\n\t}\n\n\toverride mapToDriverValue(value: Date): string {\n\t\treturn value.toISOString();\n\t}\n}\n\nexport type PgDateStringBuilderInitial<TName extends string> = PgDateStringBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgDateString';\n\tdata: string;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgDateStringBuilder<T extends ColumnBuilderBaseConfig<'string', 'PgDateString'>>\n\textends PgDateColumnBaseBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'PgDateStringBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'string', 'PgDateString');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgDateString<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgDateString<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgDateString<T extends ColumnBaseConfig<'string', 'PgDateString'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgDateString';\n\n\tgetSQLType(): string {\n\t\treturn 'date';\n\t}\n\n\toverride mapFromDriverValue(value: Date | string): string {\n\t\tif (typeof value === 'string') return value;\n\n\t\treturn value.toISOString().slice(0, -14);\n\t}\n}\n\nexport interface PgDateConfig<T extends 'date' | 'string' = 'date' | 'string'> {\n\tmode: T;\n}\n\nexport function date(): PgDateStringBuilderInitial<''>;\nexport function date<TMode extends PgDateConfig['mode'] & {}>(\n\tconfig?: PgDateConfig<TMode>,\n): Equal<TMode, 'date'> extends true ? PgDateBuilderInitial<''> : PgDateStringBuilderInitial<''>;\nexport function date<TName extends string, TMode extends PgDateConfig['mode'] & {}>(\n\tname: TName,\n\tconfig?: PgDateConfig<TMode>,\n): Equal<TMode, 'date'> extends true ? PgDateBuilderInitial<TName> : PgDateStringBuilderInitial<TName>;\nexport function date(a?: string | PgDateConfig, b?: PgDateConfig) {\n\tconst { name, config } = getColumnNameAndConfig<PgDateConfig>(a, b);\n\tif (config?.mode === 'date') {\n\t\treturn new PgDateBuilder(name);\n\t}\n\treturn new PgDateStringBuilder(name);\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgDoublePrecisionBuilderInitial<TName extends string> = PgDoublePrecisionBuilder<{\n\tname: TName;\n\tdataType: 'number';\n\tcolumnType: 'PgDoublePrecision';\n\tdata: number;\n\tdriverParam: string | number;\n\tenumValues: undefined;\n}>;\n\nexport class PgDoublePrecisionBuilder<T extends ColumnBuilderBaseConfig<'number', 'PgDoublePrecision'>>\n\textends PgColumnBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'PgDoublePrecisionBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'number', 'PgDoublePrecision');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgDoublePrecision<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgDoublePrecision<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgDoublePrecision<T extends ColumnBaseConfig<'number', 'PgDoublePrecision'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgDoublePrecision';\n\n\tgetSQLType(): string {\n\t\treturn 'double precision';\n\t}\n\n\toverride mapFromDriverValue(value: string | number): number {\n\t\tif (typeof value === 'string') {\n\t\t\treturn Number.parseFloat(value);\n\t\t}\n\t\treturn value;\n\t}\n}\n\nexport function doublePrecision(): PgDoublePrecisionBuilderInitial<''>;\nexport function doublePrecision<TName extends string>(name: TName): PgDoublePrecisionBuilderInitial<TName>;\nexport function doublePrecision(name?: string) {\n\treturn new PgDoublePrecisionBuilder(name ?? '');\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '../table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgInetBuilderInitial<TName extends string> = PgInetBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgInet';\n\tdata: string;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgInetBuilder<T extends ColumnBuilderBaseConfig<'string', 'PgInet'>> extends PgColumnBuilder<T> {\n\tstatic override readonly [entityKind]: string = 'PgInetBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'string', 'PgInet');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgInet<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgInet<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgInet<T extends ColumnBaseConfig<'string', 'PgInet'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgInet';\n\n\tgetSQLType(): string {\n\t\treturn 'inet';\n\t}\n}\n\nexport function inet(): PgInetBuilderInitial<''>;\nexport function inet<TName extends string>(name: TName): PgInetBuilderInitial<TName>;\nexport function inet(name?: string) {\n\treturn new PgInetBuilder(name ?? '');\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '../table.ts';\nimport { PgColumn } from './common.ts';\nimport { PgIntColumnBaseBuilder } from './int.common.ts';\n\nexport type PgIntegerBuilderInitial<TName extends string> = PgIntegerBuilder<{\n\tname: TName;\n\tdataType: 'number';\n\tcolumnType: 'PgInteger';\n\tdata: number;\n\tdriverParam: number | string;\n\tenumValues: undefined;\n}>;\n\nexport class PgIntegerBuilder<T extends ColumnBuilderBaseConfig<'number', 'PgInteger'>>\n\textends PgIntColumnBaseBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'PgIntegerBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'number', 'PgInteger');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgInteger<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgInteger<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgInteger<T extends ColumnBaseConfig<'number', 'PgInteger'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgInteger';\n\n\tgetSQLType(): string {\n\t\treturn 'integer';\n\t}\n\n\toverride mapFromDriverValue(value: number | string): number {\n\t\tif (typeof value === 'string') {\n\t\t\treturn Number.parseInt(value);\n\t\t}\n\t\treturn value;\n\t}\n}\n\nexport function integer(): PgIntegerBuilderInitial<''>;\nexport function integer<TName extends string>(name: TName): PgIntegerBuilderInitial<TName>;\nexport function integer(name?: string) {\n\treturn new PgIntegerBuilder(name ?? '');\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\nimport type { Precision } from './timestamp.ts';\n\nexport type PgIntervalBuilderInitial<TName extends string> = PgIntervalBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgInterval';\n\tdata: string;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgIntervalBuilder<T extends ColumnBuilderBaseConfig<'string', 'PgInterval'>>\n\textends PgColumnBuilder<T, { intervalConfig: IntervalConfig }>\n{\n\tstatic override readonly [entityKind]: string = 'PgIntervalBuilder';\n\n\tconstructor(\n\t\tname: T['name'],\n\t\tintervalConfig: IntervalConfig,\n\t) {\n\t\tsuper(name, 'string', 'PgInterval');\n\t\tthis.config.intervalConfig = intervalConfig;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgInterval<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgInterval<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgInterval<T extends ColumnBaseConfig<'string', 'PgInterval'>>\n\textends PgColumn<T, { intervalConfig: IntervalConfig }>\n{\n\tstatic override readonly [entityKind]: string = 'PgInterval';\n\n\treadonly fields: IntervalConfig['fields'] = this.config.intervalConfig.fields;\n\treadonly precision: IntervalConfig['precision'] = this.config.intervalConfig.precision;\n\n\tgetSQLType(): string {\n\t\tconst fields = this.fields ? ` ${this.fields}` : '';\n\t\tconst precision = this.precision ? `(${this.precision})` : '';\n\t\treturn `interval${fields}${precision}`;\n\t}\n}\n\nexport interface IntervalConfig {\n\tfields?:\n\t\t| 'year'\n\t\t| 'month'\n\t\t| 'day'\n\t\t| 'hour'\n\t\t| 'minute'\n\t\t| 'second'\n\t\t| 'year to month'\n\t\t| 'day to hour'\n\t\t| 'day to minute'\n\t\t| 'day to second'\n\t\t| 'hour to minute'\n\t\t| 'hour to second'\n\t\t| 'minute to second';\n\tprecision?: Precision;\n}\n\nexport function interval(): PgIntervalBuilderInitial<''>;\nexport function interval(\n\tconfig?: IntervalConfig,\n): PgIntervalBuilderInitial<''>;\nexport function interval<TName extends string>(\n\tname: TName,\n\tconfig?: IntervalConfig,\n): PgIntervalBuilderInitial<TName>;\nexport function interval(a?: string | IntervalConfig, b: IntervalConfig = {}) {\n\tconst { name, config } = getColumnNameAndConfig<IntervalConfig>(a, b);\n\treturn new PgIntervalBuilder(name, config);\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgJsonBuilderInitial<TName extends string> = PgJsonBuilder<{\n\tname: TName;\n\tdataType: 'json';\n\tcolumnType: 'PgJson';\n\tdata: unknown;\n\tdriverParam: unknown;\n\tenumValues: undefined;\n}>;\n\nexport class PgJsonBuilder<T extends ColumnBuilderBaseConfig<'json', 'PgJson'>> extends PgColumnBuilder<\n\tT\n> {\n\tstatic override readonly [entityKind]: string = 'PgJsonBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'json', 'PgJson');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgJson<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgJson<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgJson<T extends ColumnBaseConfig<'json', 'PgJson'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgJson';\n\n\tconstructor(table: AnyPgTable<{ name: T['tableName'] }>, config: PgJsonBuilder<T>['config']) {\n\t\tsuper(table, config);\n\t}\n\n\tgetSQLType(): string {\n\t\treturn 'json';\n\t}\n\n\toverride mapToDriverValue(value: T['data']): string {\n\t\treturn JSON.stringify(value);\n\t}\n\n\toverride mapFromDriverValue(value: T['data'] | string): T['data'] {\n\t\tif (typeof value === 'string') {\n\t\t\ttry {\n\t\t\t\treturn JSON.parse(value);\n\t\t\t} catch {\n\t\t\t\treturn value as T['data'];\n\t\t\t}\n\t\t}\n\t\treturn value;\n\t}\n}\n\nexport function json(): PgJsonBuilderInitial<''>;\nexport function json<TName extends string>(name: TName): PgJsonBuilderInitial<TName>;\nexport function json(name?: string) {\n\treturn new PgJsonBuilder(name ?? '');\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgJsonbBuilderInitial<TName extends string> = PgJsonbBuilder<{\n\tname: TName;\n\tdataType: 'json';\n\tcolumnType: 'PgJsonb';\n\tdata: unknown;\n\tdriverParam: unknown;\n\tenumValues: undefined;\n}>;\n\nexport class PgJsonbBuilder<T extends ColumnBuilderBaseConfig<'json', 'PgJsonb'>> extends PgColumnBuilder<T> {\n\tstatic override readonly [entityKind]: string = 'PgJsonbBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'json', 'PgJsonb');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgJsonb<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgJsonb<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgJsonb<T extends ColumnBaseConfig<'json', 'PgJsonb'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgJsonb';\n\n\tconstructor(table: AnyPgTable<{ name: T['tableName'] }>, config: PgJsonbBuilder<T>['config']) {\n\t\tsuper(table, config);\n\t}\n\n\tgetSQLType(): string {\n\t\treturn 'jsonb';\n\t}\n\n\toverride mapToDriverValue(value: T['data']): string {\n\t\treturn JSON.stringify(value);\n\t}\n\n\toverride mapFromDriverValue(value: T['data'] | string): T['data'] {\n\t\tif (typeof value === 'string') {\n\t\t\ttry {\n\t\t\t\treturn JSON.parse(value);\n\t\t\t} catch {\n\t\t\t\treturn value as T['data'];\n\t\t\t}\n\t\t}\n\t\treturn value;\n\t}\n}\n\nexport function jsonb(): PgJsonbBuilderInitial<''>;\nexport function jsonb<TName extends string>(name: TName): PgJsonbBuilderInitial<TName>;\nexport function jsonb(name?: string) {\n\treturn new PgJsonbBuilder(name ?? '');\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\n\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgLineBuilderInitial<TName extends string> = PgLineBuilder<{\n\tname: TName;\n\tdataType: 'array';\n\tcolumnType: 'PgLine';\n\tdata: [number, number, number];\n\tdriverParam: number | string;\n\tenumValues: undefined;\n}>;\n\nexport class PgLineBuilder<T extends ColumnBuilderBaseConfig<'array', 'PgLine'>> extends PgColumnBuilder<T> {\n\tstatic override readonly [entityKind]: string = 'PgLineBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'array', 'PgLine');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgLineTuple<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgLineTuple<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgLineTuple<T extends ColumnBaseConfig<'array', 'PgLine'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgLine';\n\n\tgetSQLType(): string {\n\t\treturn 'line';\n\t}\n\n\toverride mapFromDriverValue(value: string): [number, number, number] {\n\t\tconst [a, b, c] = value.slice(1, -1).split(',');\n\t\treturn [Number.parseFloat(a!), Number.parseFloat(b!), Number.parseFloat(c!)];\n\t}\n\n\toverride mapToDriverValue(value: [number, number, number]): string {\n\t\treturn `{${value[0]},${value[1]},${value[2]}}`;\n\t}\n}\n\nexport type PgLineABCBuilderInitial<TName extends string> = PgLineABCBuilder<{\n\tname: TName;\n\tdataType: 'json';\n\tcolumnType: 'PgLineABC';\n\tdata: { a: number; b: number; c: number };\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgLineABCBuilder<T extends ColumnBuilderBaseConfig<'json', 'PgLineABC'>> extends PgColumnBuilder<T> {\n\tstatic override readonly [entityKind]: string = 'PgLineABCBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'json', 'PgLineABC');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgLineABC<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgLineABC<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgLineABC<T extends ColumnBaseConfig<'json', 'PgLineABC'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgLineABC';\n\n\tgetSQLType(): string {\n\t\treturn 'line';\n\t}\n\n\toverride mapFromDriverValue(value: string): { a: number; b: number; c: number } {\n\t\tconst [a, b, c] = value.slice(1, -1).split(',');\n\t\treturn { a: Number.parseFloat(a!), b: Number.parseFloat(b!), c: Number.parseFloat(c!) };\n\t}\n\n\toverride mapToDriverValue(value: { a: number; b: number; c: number }): string {\n\t\treturn `{${value.a},${value.b},${value.c}}`;\n\t}\n}\n\nexport interface PgLineTypeConfig<T extends 'tuple' | 'abc' = 'tuple' | 'abc'> {\n\tmode?: T;\n}\n\nexport function line(): PgLineBuilderInitial<''>;\nexport function line<TMode extends PgLineTypeConfig['mode'] & {}>(\n\tconfig?: PgLineTypeConfig<TMode>,\n): Equal<TMode, 'abc'> extends true ? PgLineABCBuilderInitial<''>\n\t: PgLineBuilderInitial<''>;\nexport function line<TName extends string, TMode extends PgLineTypeConfig['mode'] & {}>(\n\tname: TName,\n\tconfig?: PgLineTypeConfig<TMode>,\n): Equal<TMode, 'abc'> extends true ? PgLineABCBuilderInitial<TName>\n\t: PgLineBuilderInitial<TName>;\nexport function line(a?: string | PgLineTypeConfig, b?: PgLineTypeConfig) {\n\tconst { name, config } = getColumnNameAndConfig<PgLineTypeConfig>(a, b);\n\tif (!config?.mode || config.mode === 'tuple') {\n\t\treturn new PgLineBuilder(name);\n\t}\n\treturn new PgLineABCBuilder(name);\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '../table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgMacaddrBuilderInitial<TName extends string> = PgMacaddrBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgMacaddr';\n\tdata: string;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgMacaddrBuilder<T extends ColumnBuilderBaseConfig<'string', 'PgMacaddr'>> extends PgColumnBuilder<T> {\n\tstatic override readonly [entityKind]: string = 'PgMacaddrBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'string', 'PgMacaddr');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgMacaddr<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgMacaddr<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgMacaddr<T extends ColumnBaseConfig<'string', 'PgMacaddr'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgMacaddr';\n\n\tgetSQLType(): string {\n\t\treturn 'macaddr';\n\t}\n}\n\nexport function macaddr(): PgMacaddrBuilderInitial<''>;\nexport function macaddr<TName extends string>(name: TName): PgMacaddrBuilderInitial<TName>;\nexport function macaddr(name?: string) {\n\treturn new PgMacaddrBuilder(name ?? '');\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '../table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgMacaddr8BuilderInitial<TName extends string> = PgMacaddr8Builder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgMacaddr8';\n\tdata: string;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgMacaddr8Builder<T extends ColumnBuilderBaseConfig<'string', 'PgMacaddr8'>> extends PgColumnBuilder<T> {\n\tstatic override readonly [entityKind]: string = 'PgMacaddr8Builder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'string', 'PgMacaddr8');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgMacaddr8<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgMacaddr8<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgMacaddr8<T extends ColumnBaseConfig<'string', 'PgMacaddr8'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgMacaddr8';\n\n\tgetSQLType(): string {\n\t\treturn 'macaddr8';\n\t}\n}\n\nexport function macaddr8(): PgMacaddr8BuilderInitial<''>;\nexport function macaddr8<TName extends string>(name: TName): PgMacaddr8BuilderInitial<TName>;\nexport function macaddr8(name?: string) {\n\treturn new PgMacaddr8Builder(name ?? '');\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgNumericBuilderInitial<TName extends string> = PgNumericBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgNumeric';\n\tdata: string;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgNumericBuilder<T extends ColumnBuilderBaseConfig<'string', 'PgNumeric'>> extends PgColumnBuilder<\n\tT,\n\t{\n\t\tprecision: number | undefined;\n\t\tscale: number | undefined;\n\t}\n> {\n\tstatic override readonly [entityKind]: string = 'PgNumericBuilder';\n\n\tconstructor(name: T['name'], precision?: number, scale?: number) {\n\t\tsuper(name, 'string', 'PgNumeric');\n\t\tthis.config.precision = precision;\n\t\tthis.config.scale = scale;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgNumeric<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgNumeric<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgNumeric<T extends ColumnBaseConfig<'string', 'PgNumeric'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgNumeric';\n\n\treadonly precision: number | undefined;\n\treadonly scale: number | undefined;\n\n\tconstructor(table: AnyPgTable<{ name: T['tableName'] }>, config: PgNumericBuilder<T>['config']) {\n\t\tsuper(table, config);\n\t\tthis.precision = config.precision;\n\t\tthis.scale = config.scale;\n\t}\n\n\toverride mapFromDriverValue(value: unknown): string {\n\t\tif (typeof value === 'string') return value;\n\n\t\treturn String(value);\n\t}\n\n\tgetSQLType(): string {\n\t\tif (this.precision !== undefined && this.scale !== undefined) {\n\t\t\treturn `numeric(${this.precision}, ${this.scale})`;\n\t\t} else if (this.precision === undefined) {\n\t\t\treturn 'numeric';\n\t\t} else {\n\t\t\treturn `numeric(${this.precision})`;\n\t\t}\n\t}\n}\n\nexport type PgNumericNumberBuilderInitial<TName extends string> = PgNumericNumberBuilder<{\n\tname: TName;\n\tdataType: 'number';\n\tcolumnType: 'PgNumericNumber';\n\tdata: number;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgNumericNumberBuilder<T extends ColumnBuilderBaseConfig<'number', 'PgNumericNumber'>>\n\textends PgColumnBuilder<\n\t\tT,\n\t\t{\n\t\t\tprecision: number | undefined;\n\t\t\tscale: number | undefined;\n\t\t}\n\t>\n{\n\tstatic override readonly [entityKind]: string = 'PgNumericNumberBuilder';\n\n\tconstructor(name: T['name'], precision?: number, scale?: number) {\n\t\tsuper(name, 'number', 'PgNumericNumber');\n\t\tthis.config.precision = precision;\n\t\tthis.config.scale = scale;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgNumericNumber<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgNumericNumber<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgNumericNumber<T extends ColumnBaseConfig<'number', 'PgNumericNumber'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgNumericNumber';\n\n\treadonly precision: number | undefined;\n\treadonly scale: number | undefined;\n\n\tconstructor(table: AnyPgTable<{ name: T['tableName'] }>, config: PgNumericNumberBuilder<T>['config']) {\n\t\tsuper(table, config);\n\t\tthis.precision = config.precision;\n\t\tthis.scale = config.scale;\n\t}\n\n\toverride mapFromDriverValue(value: unknown): number {\n\t\tif (typeof value === 'number') return value;\n\n\t\treturn Number(value);\n\t}\n\n\toverride mapToDriverValue = String;\n\n\tgetSQLType(): string {\n\t\tif (this.precision !== undefined && this.scale !== undefined) {\n\t\t\treturn `numeric(${this.precision}, ${this.scale})`;\n\t\t} else if (this.precision === undefined) {\n\t\t\treturn 'numeric';\n\t\t} else {\n\t\t\treturn `numeric(${this.precision})`;\n\t\t}\n\t}\n}\n\nexport type PgNumericBigIntBuilderInitial<TName extends string> = PgNumericBigIntBuilder<{\n\tname: TName;\n\tdataType: 'bigint';\n\tcolumnType: 'PgNumericBigInt';\n\tdata: bigint;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgNumericBigIntBuilder<T extends ColumnBuilderBaseConfig<'bigint', 'PgNumericBigInt'>>\n\textends PgColumnBuilder<\n\t\tT,\n\t\t{\n\t\t\tprecision: number | undefined;\n\t\t\tscale: number | undefined;\n\t\t}\n\t>\n{\n\tstatic override readonly [entityKind]: string = 'PgNumericBigIntBuilder';\n\n\tconstructor(name: T['name'], precision?: number, scale?: number) {\n\t\tsuper(name, 'bigint', 'PgNumericBigInt');\n\t\tthis.config.precision = precision;\n\t\tthis.config.scale = scale;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgNumericBigInt<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgNumericBigInt<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgNumericBigInt<T extends ColumnBaseConfig<'bigint', 'PgNumericBigInt'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgNumericBigInt';\n\n\treadonly precision: number | undefined;\n\treadonly scale: number | undefined;\n\n\tconstructor(table: AnyPgTable<{ name: T['tableName'] }>, config: PgNumericBigIntBuilder<T>['config']) {\n\t\tsuper(table, config);\n\t\tthis.precision = config.precision;\n\t\tthis.scale = config.scale;\n\t}\n\n\toverride mapFromDriverValue = BigInt;\n\n\toverride mapToDriverValue = String;\n\n\tgetSQLType(): string {\n\t\tif (this.precision !== undefined && this.scale !== undefined) {\n\t\t\treturn `numeric(${this.precision}, ${this.scale})`;\n\t\t} else if (this.precision === undefined) {\n\t\t\treturn 'numeric';\n\t\t} else {\n\t\t\treturn `numeric(${this.precision})`;\n\t\t}\n\t}\n}\n\nexport type PgNumericConfig<T extends 'string' | 'number' | 'bigint' = 'string' | 'number' | 'bigint'> =\n\t| { precision: number; scale?: number; mode?: T }\n\t| { precision?: number; scale: number; mode?: T }\n\t| { precision?: number; scale?: number; mode: T };\n\nexport function numeric<TMode extends 'string' | 'number' | 'bigint'>(\n\tconfig?: PgNumericConfig<TMode>,\n): Equal<TMode, 'number'> extends true ? PgNumericNumberBuilderInitial<''>\n\t: Equal<TMode, 'bigint'> extends true ? PgNumericBigIntBuilderInitial<''>\n\t: PgNumericBuilderInitial<''>;\nexport function numeric<TName extends string, TMode extends 'string' | 'number' | 'bigint'>(\n\tname: TName,\n\tconfig?: PgNumericConfig<TMode>,\n): Equal<TMode, 'number'> extends true ? PgNumericNumberBuilderInitial<TName>\n\t: Equal<TMode, 'bigint'> extends true ? PgNumericBigIntBuilderInitial<TName>\n\t: PgNumericBuilderInitial<TName>;\nexport function numeric(a?: string | PgNumericConfig, b?: PgNumericConfig) {\n\tconst { name, config } = getColumnNameAndConfig<PgNumericConfig>(a, b);\n\tconst mode = config?.mode;\n\treturn mode === 'number'\n\t\t? new PgNumericNumberBuilder(name, config?.precision, config?.scale)\n\t\t: mode === 'bigint'\n\t\t? new PgNumericBigIntBuilder(name, config?.precision, config?.scale)\n\t\t: new PgNumericBuilder(name, config?.precision, config?.scale);\n}\n\nexport const decimal = numeric;\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\n\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgPointTupleBuilderInitial<TName extends string> = PgPointTupleBuilder<{\n\tname: TName;\n\tdataType: 'array';\n\tcolumnType: 'PgPointTuple';\n\tdata: [number, number];\n\tdriverParam: number | string;\n\tenumValues: undefined;\n}>;\n\nexport class PgPointTupleBuilder<T extends ColumnBuilderBaseConfig<'array', 'PgPointTuple'>>\n\textends PgColumnBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'PgPointTupleBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'array', 'PgPointTuple');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgPointTuple<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgPointTuple<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgPointTuple<T extends ColumnBaseConfig<'array', 'PgPointTuple'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgPointTuple';\n\n\tgetSQLType(): string {\n\t\treturn 'point';\n\t}\n\n\toverride mapFromDriverValue(value: string | { x: number; y: number }): [number, number] {\n\t\tif (typeof value === 'string') {\n\t\t\tconst [x, y] = value.slice(1, -1).split(',');\n\t\t\treturn [Number.parseFloat(x!), Number.parseFloat(y!)];\n\t\t}\n\t\treturn [value.x, value.y];\n\t}\n\n\toverride mapToDriverValue(value: [number, number]): string {\n\t\treturn `(${value[0]},${value[1]})`;\n\t}\n}\n\nexport type PgPointObjectBuilderInitial<TName extends string> = PgPointObjectBuilder<{\n\tname: TName;\n\tdataType: 'json';\n\tcolumnType: 'PgPointObject';\n\tdata: { x: number; y: number };\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgPointObjectBuilder<T extends ColumnBuilderBaseConfig<'json', 'PgPointObject'>>\n\textends PgColumnBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'PgPointObjectBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'json', 'PgPointObject');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgPointObject<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgPointObject<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgPointObject<T extends ColumnBaseConfig<'json', 'PgPointObject'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgPointObject';\n\n\tgetSQLType(): string {\n\t\treturn 'point';\n\t}\n\n\toverride mapFromDriverValue(value: string | { x: number; y: number }): { x: number; y: number } {\n\t\tif (typeof value === 'string') {\n\t\t\tconst [x, y] = value.slice(1, -1).split(',');\n\t\t\treturn { x: Number.parseFloat(x!), y: Number.parseFloat(y!) };\n\t\t}\n\t\treturn value;\n\t}\n\n\toverride mapToDriverValue(value: { x: number; y: number }): string {\n\t\treturn `(${value.x},${value.y})`;\n\t}\n}\n\nexport interface PgPointConfig<T extends 'tuple' | 'xy' = 'tuple' | 'xy'> {\n\tmode?: T;\n}\n\nexport function point(): PgPointTupleBuilderInitial<''>;\nexport function point<TMode extends PgPointConfig['mode'] & {}>(\n\tconfig?: PgPointConfig<TMode>,\n): Equal<TMode, 'xy'> extends true ? PgPointObjectBuilderInitial<''>\n\t: PgPointTupleBuilderInitial<''>;\nexport function point<TName extends string, TMode extends PgPointConfig['mode'] & {}>(\n\tname: TName,\n\tconfig?: PgPointConfig<TMode>,\n): Equal<TMode, 'xy'> extends true ? PgPointObjectBuilderInitial<TName>\n\t: PgPointTupleBuilderInitial<TName>;\nexport function point(a?: string | PgPointConfig, b?: PgPointConfig) {\n\tconst { name, config } = getColumnNameAndConfig<PgPointConfig>(a, b);\n\tif (!config?.mode || config.mode === 'tuple') {\n\t\treturn new PgPointTupleBuilder(name);\n\t}\n\treturn new PgPointObjectBuilder(name);\n}\n","function hexToBytes(hex: string): Uint8Array {\n\tconst bytes: number[] = [];\n\tfor (let c = 0; c < hex.length; c += 2) {\n\t\tbytes.push(Number.parseInt(hex.slice(c, c + 2), 16));\n\t}\n\treturn new Uint8Array(bytes);\n}\n\nfunction bytesToFloat64(bytes: Uint8Array, offset: number): number {\n\tconst buffer = new ArrayBuffer(8);\n\tconst view = new DataView(buffer);\n\tfor (let i = 0; i < 8; i++) {\n\t\tview.setUint8(i, bytes[offset + i]!);\n\t}\n\treturn view.getFloat64(0, true);\n}\n\nexport function parseEWKB(hex: string): [number, number] {\n\tconst bytes = hexToBytes(hex);\n\n\tlet offset = 0;\n\n\t// Byte order: 1 is little-endian, 0 is big-endian\n\tconst byteOrder = bytes[offset];\n\toffset += 1;\n\n\tconst view = new DataView(bytes.buffer);\n\tconst geomType = view.getUint32(offset, byteOrder === 1);\n\toffset += 4;\n\n\tlet _srid: number | undefined;\n\tif (geomType & 0x20000000) { // SRID flag\n\t\t_srid = view.getUint32(offset, byteOrder === 1);\n\t\toffset += 4;\n\t}\n\n\tif ((geomType & 0xFFFF) === 1) {\n\t\tconst x = bytesToFloat64(bytes, offset);\n\t\toffset += 8;\n\t\tconst y = bytesToFloat64(bytes, offset);\n\t\toffset += 8;\n\n\t\treturn [x, y];\n\t}\n\n\tthrow new Error('Unsupported geometry type');\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\n\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from '../common.ts';\nimport { parseEWKB } from './utils.ts';\n\nexport type PgGeometryBuilderInitial<TName extends string> = PgGeometryBuilder<{\n\tname: TName;\n\tdataType: 'array';\n\tcolumnType: 'PgGeometry';\n\tdata: [number, number];\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgGeometryBuilder<T extends ColumnBuilderBaseConfig<'array', 'PgGeometry'>> extends PgColumnBuilder<T> {\n\tstatic override readonly [entityKind]: string = 'PgGeometryBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'array', 'PgGeometry');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgGeometry<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgGeometry<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgGeometry<T extends ColumnBaseConfig<'array', 'PgGeometry'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgGeometry';\n\n\tgetSQLType(): string {\n\t\treturn 'geometry(point)';\n\t}\n\n\toverride mapFromDriverValue(value: string): [number, number] {\n\t\treturn parseEWKB(value);\n\t}\n\n\toverride mapToDriverValue(value: [number, number]): string {\n\t\treturn `point(${value[0]} ${value[1]})`;\n\t}\n}\n\nexport type PgGeometryObjectBuilderInitial<TName extends string> = PgGeometryObjectBuilder<{\n\tname: TName;\n\tdataType: 'json';\n\tcolumnType: 'PgGeometryObject';\n\tdata: { x: number; y: number };\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgGeometryObjectBuilder<T extends ColumnBuilderBaseConfig<'json', 'PgGeometryObject'>>\n\textends PgColumnBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'PgGeometryObjectBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'json', 'PgGeometryObject');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgGeometryObject<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgGeometryObject<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgGeometryObject<T extends ColumnBaseConfig<'json', 'PgGeometryObject'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgGeometryObject';\n\n\tgetSQLType(): string {\n\t\treturn 'geometry(point)';\n\t}\n\n\toverride mapFromDriverValue(value: string): { x: number; y: number } {\n\t\tconst parsed = parseEWKB(value);\n\t\treturn { x: parsed[0], y: parsed[1] };\n\t}\n\n\toverride mapToDriverValue(value: { x: number; y: number }): string {\n\t\treturn `point(${value.x} ${value.y})`;\n\t}\n}\n\nexport interface PgGeometryConfig<T extends 'tuple' | 'xy' = 'tuple' | 'xy'> {\n\tmode?: T;\n\ttype?: 'point' | (string & {});\n\tsrid?: number;\n}\n\nexport function geometry(): PgGeometryBuilderInitial<''>;\nexport function geometry<TMode extends PgGeometryConfig['mode'] & {}>(\n\tconfig?: PgGeometryConfig<TMode>,\n): Equal<TMode, 'xy'> extends true ? PgGeometryObjectBuilderInitial<''> : PgGeometryBuilderInitial<''>;\nexport function geometry<TName extends string, TMode extends PgGeometryConfig['mode'] & {}>(\n\tname: TName,\n\tconfig?: PgGeometryConfig<TMode>,\n): Equal<TMode, 'xy'> extends true ? PgGeometryObjectBuilderInitial<TName> : PgGeometryBuilderInitial<TName>;\nexport function geometry(a?: string | PgGeometryConfig, b?: PgGeometryConfig) {\n\tconst { name, config } = getColumnNameAndConfig<PgGeometryConfig>(a, b);\n\tif (!config?.mode || config.mode === 'tuple') {\n\t\treturn new PgGeometryBuilder(name);\n\t}\n\treturn new PgGeometryObjectBuilder(name);\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgRealBuilderInitial<TName extends string> = PgRealBuilder<{\n\tname: TName;\n\tdataType: 'number';\n\tcolumnType: 'PgReal';\n\tdata: number;\n\tdriverParam: string | number;\n\tenumValues: undefined;\n}>;\n\nexport class PgRealBuilder<T extends ColumnBuilderBaseConfig<'number', 'PgReal'>> extends PgColumnBuilder<\n\tT,\n\t{ length: number | undefined }\n> {\n\tstatic override readonly [entityKind]: string = 'PgRealBuilder';\n\n\tconstructor(name: T['name'], length?: number) {\n\t\tsuper(name, 'number', 'PgReal');\n\t\tthis.config.length = length;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgReal<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgReal<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgReal<T extends ColumnBaseConfig<'number', 'PgReal'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgReal';\n\n\tconstructor(table: AnyPgTable<{ name: T['tableName'] }>, config: PgRealBuilder<T>['config']) {\n\t\tsuper(table, config);\n\t}\n\n\tgetSQLType(): string {\n\t\treturn 'real';\n\t}\n\n\toverride mapFromDriverValue = (value: string | number): number => {\n\t\tif (typeof value === 'string') {\n\t\t\treturn Number.parseFloat(value);\n\t\t}\n\t\treturn value;\n\t};\n}\n\nexport function real(): PgRealBuilderInitial<''>;\nexport function real<TName extends string>(name: TName): PgRealBuilderInitial<TName>;\nexport function real(name?: string) {\n\treturn new PgRealBuilder(name ?? '');\n}\n","import type {\n\tColumnBuilderBaseConfig,\n\tColumnBuilderRuntimeConfig,\n\tHasDefault,\n\tMakeColumnConfig,\n\tNotNull,\n} from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgSerialBuilderInitial<TName extends string> = NotNull<\n\tHasDefault<\n\t\tPgSerialBuilder<{\n\t\t\tname: TName;\n\t\t\tdataType: 'number';\n\t\t\tcolumnType: 'PgSerial';\n\t\t\tdata: number;\n\t\t\tdriverParam: number;\n\t\t\tenumValues: undefined;\n\t\t}>\n\t>\n>;\n\nexport class PgSerialBuilder<T extends ColumnBuilderBaseConfig<'number', 'PgSerial'>> extends PgColumnBuilder<T> {\n\tstatic override readonly [entityKind]: string = 'PgSerialBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'number', 'PgSerial');\n\t\tthis.config.hasDefault = true;\n\t\tthis.config.notNull = true;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgSerial<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgSerial<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgSerial<T extends ColumnBaseConfig<'number', 'PgSerial'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgSerial';\n\n\tgetSQLType(): string {\n\t\treturn 'serial';\n\t}\n}\n\nexport function serial(): PgSerialBuilderInitial<''>;\nexport function serial<TName extends string>(name: TName): PgSerialBuilderInitial<TName>;\nexport function serial(name?: string) {\n\treturn new PgSerialBuilder(name ?? '');\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { PgColumn } from './common.ts';\nimport { PgIntColumnBaseBuilder } from './int.common.ts';\n\nexport type PgSmallIntBuilderInitial<TName extends string> = PgSmallIntBuilder<{\n\tname: TName;\n\tdataType: 'number';\n\tcolumnType: 'PgSmallInt';\n\tdata: number;\n\tdriverParam: number | string;\n\tenumValues: undefined;\n}>;\n\nexport class PgSmallIntBuilder<T extends ColumnBuilderBaseConfig<'number', 'PgSmallInt'>>\n\textends PgIntColumnBaseBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'PgSmallIntBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'number', 'PgSmallInt');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgSmallInt<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgSmallInt<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgSmallInt<T extends ColumnBaseConfig<'number', 'PgSmallInt'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgSmallInt';\n\n\tgetSQLType(): string {\n\t\treturn 'smallint';\n\t}\n\n\toverride mapFromDriverValue = (value: number | string): number => {\n\t\tif (typeof value === 'string') {\n\t\t\treturn Number(value);\n\t\t}\n\t\treturn value;\n\t};\n}\n\nexport function smallint(): PgSmallIntBuilderInitial<''>;\nexport function smallint<TName extends string>(name: TName): PgSmallIntBuilderInitial<TName>;\nexport function smallint(name?: string) {\n\treturn new PgSmallIntBuilder(name ?? '');\n}\n","import type {\n\tColumnBuilderBaseConfig,\n\tColumnBuilderRuntimeConfig,\n\tHasDefault,\n\tMakeColumnConfig,\n\tNotNull,\n} from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgSmallSerialBuilderInitial<TName extends string> = NotNull<\n\tHasDefault<\n\t\tPgSmallSerialBuilder<{\n\t\t\tname: TName;\n\t\t\tdataType: 'number';\n\t\t\tcolumnType: 'PgSmallSerial';\n\t\t\tdata: number;\n\t\t\tdriverParam: number;\n\t\t\tenumValues: undefined;\n\t\t}>\n\t>\n>;\n\nexport class PgSmallSerialBuilder<T extends ColumnBuilderBaseConfig<'number', 'PgSmallSerial'>>\n\textends PgColumnBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'PgSmallSerialBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'number', 'PgSmallSerial');\n\t\tthis.config.hasDefault = true;\n\t\tthis.config.notNull = true;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgSmallSerial<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgSmallSerial<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgSmallSerial<T extends ColumnBaseConfig<'number', 'PgSmallSerial'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgSmallSerial';\n\n\tgetSQLType(): string {\n\t\treturn 'smallserial';\n\t}\n}\n\nexport function smallserial(): PgSmallSerialBuilderInitial<''>;\nexport function smallserial<TName extends string>(name: TName): PgSmallSerialBuilderInitial<TName>;\nexport function smallserial(name?: string) {\n\treturn new PgSmallSerialBuilder(name ?? '');\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { getColumnNameAndConfig, type Writable } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgTextBuilderInitial<TName extends string, TEnum extends [string, ...string[]]> = PgTextBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgText';\n\tdata: TEnum[number];\n\tenumValues: TEnum;\n\tdriverParam: string;\n}>;\n\nexport class PgTextBuilder<\n\tT extends ColumnBuilderBaseConfig<'string', 'PgText'>,\n> extends PgColumnBuilder<T, { enumValues: T['enumValues'] }> {\n\tstatic override readonly [entityKind]: string = 'PgTextBuilder';\n\n\tconstructor(\n\t\tname: T['name'],\n\t\tconfig: PgTextConfig<T['enumValues']>,\n\t) {\n\t\tsuper(name, 'string', 'PgText');\n\t\tthis.config.enumValues = config.enum;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgText<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgText<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgText<T extends ColumnBaseConfig<'string', 'PgText'>>\n\textends PgColumn<T, { enumValues: T['enumValues'] }>\n{\n\tstatic override readonly [entityKind]: string = 'PgText';\n\n\toverride readonly enumValues = this.config.enumValues;\n\n\tgetSQLType(): string {\n\t\treturn 'text';\n\t}\n}\n\nexport interface PgTextConfig<\n\tTEnum extends readonly string[] | string[] | undefined = readonly string[] | string[] | undefined,\n> {\n\tenum?: TEnum;\n}\n\nexport function text(): PgTextBuilderInitial<'', [string, ...string[]]>;\nexport function text<U extends string, T extends Readonly<[U, ...U[]]>>(\n\tconfig?: PgTextConfig<T | Writable<T>>,\n): PgTextBuilderInitial<'', Writable<T>>;\nexport function text<TName extends string, U extends string, T extends Readonly<[U, ...U[]]>>(\n\tname: TName,\n\tconfig?: PgTextConfig<T | Writable<T>>,\n): PgTextBuilderInitial<TName, Writable<T>>;\nexport function text(a?: string | PgTextConfig, b: PgTextConfig = {}): any {\n\tconst { name, config } = getColumnNameAndConfig<PgTextConfig>(a, b);\n\treturn new PgTextBuilder(name, config as any);\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn } from './common.ts';\nimport { PgDateColumnBaseBuilder } from './date.common.ts';\nimport type { Precision } from './timestamp.ts';\n\nexport type PgTimeBuilderInitial<TName extends string> = PgTimeBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgTime';\n\tdata: string;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgTimeBuilder<T extends ColumnBuilderBaseConfig<'string', 'PgTime'>> extends PgDateColumnBaseBuilder<\n\tT,\n\t{ withTimezone: boolean; precision: number | undefined }\n> {\n\tstatic override readonly [entityKind]: string = 'PgTimeBuilder';\n\n\tconstructor(\n\t\tname: T['name'],\n\t\treadonly withTimezone: boolean,\n\t\treadonly precision: number | undefined,\n\t) {\n\t\tsuper(name, 'string', 'PgTime');\n\t\tthis.config.withTimezone = withTimezone;\n\t\tthis.config.precision = precision;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgTime<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgTime<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgTime<T extends ColumnBaseConfig<'string', 'PgTime'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgTime';\n\n\treadonly withTimezone: boolean;\n\treadonly precision: number | undefined;\n\n\tconstructor(table: AnyPgTable<{ name: T['tableName'] }>, config: PgTimeBuilder<T>['config']) {\n\t\tsuper(table, config);\n\t\tthis.withTimezone = config.withTimezone;\n\t\tthis.precision = config.precision;\n\t}\n\n\tgetSQLType(): string {\n\t\tconst precision = this.precision === undefined ? '' : `(${this.precision})`;\n\t\treturn `time${precision}${this.withTimezone ? ' with time zone' : ''}`;\n\t}\n}\n\nexport interface TimeConfig {\n\tprecision?: Precision;\n\twithTimezone?: boolean;\n}\n\nexport function time(): PgTimeBuilderInitial<''>;\nexport function time(config?: TimeConfig): PgTimeBuilderInitial<''>;\nexport function time<TName extends string>(name: TName, config?: TimeConfig): PgTimeBuilderInitial<TName>;\nexport function time(a?: string | TimeConfig, b: TimeConfig = {}) {\n\tconst { name, config } = getColumnNameAndConfig<TimeConfig>(a, b);\n\treturn new PgTimeBuilder(name, config.withTimezone ?? false, config.precision);\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn } from './common.ts';\nimport { PgDateColumnBaseBuilder } from './date.common.ts';\n\nexport type PgTimestampBuilderInitial<TName extends string> = PgTimestampBuilder<{\n\tname: TName;\n\tdataType: 'date';\n\tcolumnType: 'PgTimestamp';\n\tdata: Date;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgTimestampBuilder<T extends ColumnBuilderBaseConfig<'date', 'PgTimestamp'>>\n\textends PgDateColumnBaseBuilder<\n\t\tT,\n\t\t{ withTimezone: boolean; precision: number | undefined }\n\t>\n{\n\tstatic override readonly [entityKind]: string = 'PgTimestampBuilder';\n\n\tconstructor(\n\t\tname: T['name'],\n\t\twithTimezone: boolean,\n\t\tprecision: number | undefined,\n\t) {\n\t\tsuper(name, 'date', 'PgTimestamp');\n\t\tthis.config.withTimezone = withTimezone;\n\t\tthis.config.precision = precision;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgTimestamp<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgTimestamp<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgTimestamp<T extends ColumnBaseConfig<'date', 'PgTimestamp'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgTimestamp';\n\n\treadonly withTimezone: boolean;\n\treadonly precision: number | undefined;\n\n\tconstructor(table: AnyPgTable<{ name: T['tableName'] }>, config: PgTimestampBuilder<T>['config']) {\n\t\tsuper(table, config);\n\t\tthis.withTimezone = config.withTimezone;\n\t\tthis.precision = config.precision;\n\t}\n\n\tgetSQLType(): string {\n\t\tconst precision = this.precision === undefined ? '' : ` (${this.precision})`;\n\t\treturn `timestamp${precision}${this.withTimezone ? ' with time zone' : ''}`;\n\t}\n\n\toverride mapFromDriverValue(value: Date | string): Date {\n\t\tif (typeof value === 'string') return new Date(this.withTimezone ? value : value + '+0000');\n\n\t\treturn value;\n\t}\n\n\toverride mapToDriverValue = (value: Date): string => {\n\t\treturn value.toISOString();\n\t};\n}\n\nexport type PgTimestampStringBuilderInitial<TName extends string> = PgTimestampStringBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgTimestampString';\n\tdata: string;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgTimestampStringBuilder<T extends ColumnBuilderBaseConfig<'string', 'PgTimestampString'>>\n\textends PgDateColumnBaseBuilder<\n\t\tT,\n\t\t{ withTimezone: boolean; precision: number | undefined }\n\t>\n{\n\tstatic override readonly [entityKind]: string = 'PgTimestampStringBuilder';\n\n\tconstructor(\n\t\tname: T['name'],\n\t\twithTimezone: boolean,\n\t\tprecision: number | undefined,\n\t) {\n\t\tsuper(name, 'string', 'PgTimestampString');\n\t\tthis.config.withTimezone = withTimezone;\n\t\tthis.config.precision = precision;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgTimestampString<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgTimestampString<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgTimestampString<T extends ColumnBaseConfig<'string', 'PgTimestampString'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgTimestampString';\n\n\treadonly withTimezone: boolean;\n\treadonly precision: number | undefined;\n\n\tconstructor(table: AnyPgTable<{ name: T['tableName'] }>, config: PgTimestampStringBuilder<T>['config']) {\n\t\tsuper(table, config);\n\t\tthis.withTimezone = config.withTimezone;\n\t\tthis.precision = config.precision;\n\t}\n\n\tgetSQLType(): string {\n\t\tconst precision = this.precision === undefined ? '' : `(${this.precision})`;\n\t\treturn `timestamp${precision}${this.withTimezone ? ' with time zone' : ''}`;\n\t}\n\n\toverride mapFromDriverValue(value: Date | string): string {\n\t\tif (typeof value === 'string') return value;\n\n\t\tconst shortened = value.toISOString().slice(0, -1).replace('T', ' ');\n\t\tif (this.withTimezone) {\n\t\t\tconst offset = value.getTimezoneOffset();\n\t\t\tconst sign = offset <= 0 ? '+' : '-';\n\t\t\treturn `${shortened}${sign}${Math.floor(Math.abs(offset) / 60).toString().padStart(2, '0')}`;\n\t\t}\n\n\t\treturn shortened;\n\t}\n}\n\nexport type Precision = 0 | 1 | 2 | 3 | 4 | 5 | 6;\n\nexport interface PgTimestampConfig<TMode extends 'date' | 'string' = 'date' | 'string'> {\n\tmode?: TMode;\n\tprecision?: Precision;\n\twithTimezone?: boolean;\n}\n\nexport function timestamp(): PgTimestampBuilderInitial<''>;\nexport function timestamp<TMode extends PgTimestampConfig['mode'] & {}>(\n\tconfig?: PgTimestampConfig<TMode>,\n): Equal<TMode, 'string'> extends true ? PgTimestampStringBuilderInitial<''> : PgTimestampBuilderInitial<''>;\nexport function timestamp<TName extends string, TMode extends PgTimestampConfig['mode'] & {}>(\n\tname: TName,\n\tconfig?: PgTimestampConfig<TMode>,\n): Equal<TMode, 'string'> extends true ? PgTimestampStringBuilderInitial<TName> : PgTimestampBuilderInitial<TName>;\nexport function timestamp(a?: string | PgTimestampConfig, b: PgTimestampConfig = {}) {\n\tconst { name, config } = getColumnNameAndConfig<PgTimestampConfig | undefined>(a, b);\n\tif (config?.mode === 'string') {\n\t\treturn new PgTimestampStringBuilder(name, config.withTimezone ?? false, config.precision);\n\t}\n\treturn new PgTimestampBuilder(name, config?.withTimezone ?? false, config?.precision);\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { sql } from '~/sql/sql.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgUUIDBuilderInitial<TName extends string> = PgUUIDBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgUUID';\n\tdata: string;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgUUIDBuilder<T extends ColumnBuilderBaseConfig<'string', 'PgUUID'>> extends PgColumnBuilder<T> {\n\tstatic override readonly [entityKind]: string = 'PgUUIDBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'string', 'PgUUID');\n\t}\n\n\t/**\n\t * Adds `default gen_random_uuid()` to the column definition.\n\t */\n\tdefaultRandom(): ReturnType<this['default']> {\n\t\treturn this.default(sql`gen_random_uuid()`) as ReturnType<this['default']>;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgUUID<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgUUID<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class PgUUID<T extends ColumnBaseConfig<'string', 'PgUUID'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgUUID';\n\n\tgetSQLType(): string {\n\t\treturn 'uuid';\n\t}\n}\n\nexport function uuid(): PgUUIDBuilderInitial<''>;\nexport function uuid<TName extends string>(name: TName): PgUUIDBuilderInitial<TName>;\nexport function uuid(name?: string) {\n\treturn new PgUUIDBuilder(name ?? '');\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { getColumnNameAndConfig, type Writable } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type PgVarcharBuilderInitial<\n\tTName extends string,\n\tTEnum extends [string, ...string[]],\n\tTLength extends number | undefined,\n> = PgVarcharBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgVarchar';\n\tdata: TEnum[number];\n\tdriverParam: string;\n\tenumValues: TEnum;\n\tlength: TLength;\n}>;\n\nexport class PgVarcharBuilder<\n\tT extends ColumnBuilderBaseConfig<'string', 'PgVarchar'> & { length?: number | undefined },\n> extends PgColumnBuilder<\n\tT,\n\t{ length: T['length']; enumValues: T['enumValues'] },\n\t{ length: T['length'] }\n> {\n\tstatic override readonly [entityKind]: string = 'PgVarcharBuilder';\n\n\tconstructor(name: T['name'], config: PgVarcharConfig<T['enumValues'], T['length']>) {\n\t\tsuper(name, 'string', 'PgVarchar');\n\t\tthis.config.length = config.length;\n\t\tthis.config.enumValues = config.enum;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgVarchar<MakeColumnConfig<T, TTableName> & { length: T['length'] }> {\n\t\treturn new PgVarchar<MakeColumnConfig<T, TTableName> & { length: T['length'] }>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgVarchar<T extends ColumnBaseConfig<'string', 'PgVarchar'> & { length?: number | undefined }>\n\textends PgColumn<T, { length: T['length']; enumValues: T['enumValues'] }, { length: T['length'] }>\n{\n\tstatic override readonly [entityKind]: string = 'PgVarchar';\n\n\treadonly length = this.config.length;\n\toverride readonly enumValues = this.config.enumValues;\n\n\tgetSQLType(): string {\n\t\treturn this.length === undefined ? `varchar` : `varchar(${this.length})`;\n\t}\n}\n\nexport interface PgVarcharConfig<\n\tTEnum extends readonly string[] | string[] | undefined = readonly string[] | string[] | undefined,\n\tTLength extends number | undefined = number | undefined,\n> {\n\tenum?: TEnum;\n\tlength?: TLength;\n}\n\nexport function varchar(): PgVarcharBuilderInitial<'', [string, ...string[]], undefined>;\nexport function varchar<\n\tU extends string,\n\tT extends Readonly<[U, ...U[]]>,\n\tL extends number | undefined,\n>(\n\tconfig?: PgVarcharConfig<T | Writable<T>, L>,\n): PgVarcharBuilderInitial<'', Writable<T>, L>;\nexport function varchar<\n\tTName extends string,\n\tU extends string,\n\tT extends Readonly<[U, ...U[]]>,\n\tL extends number | undefined,\n>(\n\tname: TName,\n\tconfig?: PgVarcharConfig<T | Writable<T>, L>,\n): PgVarcharBuilderInitial<TName, Writable<T>, L>;\nexport function varchar(a?: string | PgVarcharConfig, b: PgVarcharConfig = {}): any {\n\tconst { name, config } = getColumnNameAndConfig<PgVarcharConfig>(a, b);\n\treturn new PgVarcharBuilder(name, config as any);\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from '../common.ts';\n\nexport type PgBinaryVectorBuilderInitial<TName extends string, TDimensions extends number> = PgBinaryVectorBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgBinaryVector';\n\tdata: string;\n\tdriverParam: string;\n\tenumValues: undefined;\n\tdimensions: TDimensions;\n}>;\n\nexport class PgBinaryVectorBuilder<\n\tT extends ColumnBuilderBaseConfig<'string', 'PgBinaryVector'> & { dimensions: number },\n> extends PgColumnBuilder<\n\tT,\n\t{ dimensions: T['dimensions'] }\n> {\n\tstatic override readonly [entityKind]: string = 'PgBinaryVectorBuilder';\n\n\tconstructor(name: string, config: PgBinaryVectorConfig<T['dimensions']>) {\n\t\tsuper(name, 'string', 'PgBinaryVector');\n\t\tthis.config.dimensions = config.dimensions;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgBinaryVector<MakeColumnConfig<T, TTableName> & { dimensions: T['dimensions'] }> {\n\t\treturn new PgBinaryVector<MakeColumnConfig<T, TTableName> & { dimensions: T['dimensions'] }>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgBinaryVector<T extends ColumnBaseConfig<'string', 'PgBinaryVector'> & { dimensions: number }>\n\textends PgColumn<T, { dimensions: T['dimensions'] }, { dimensions: T['dimensions'] }>\n{\n\tstatic override readonly [entityKind]: string = 'PgBinaryVector';\n\n\treadonly dimensions = this.config.dimensions;\n\n\tgetSQLType(): string {\n\t\treturn `bit(${this.dimensions})`;\n\t}\n}\n\nexport interface PgBinaryVectorConfig<TDimensions extends number = number> {\n\tdimensions: TDimensions;\n}\n\nexport function bit<D extends number>(\n\tconfig: PgBinaryVectorConfig<D>,\n): PgBinaryVectorBuilderInitial<'', D>;\nexport function bit<TName extends string, D extends number>(\n\tname: TName,\n\tconfig: PgBinaryVectorConfig<D>,\n): PgBinaryVectorBuilderInitial<TName, D>;\nexport function bit(a: string | PgBinaryVectorConfig, b?: PgBinaryVectorConfig) {\n\tconst { name, config } = getColumnNameAndConfig<PgBinaryVectorConfig>(a, b);\n\treturn new PgBinaryVectorBuilder(name, config);\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from '../common.ts';\n\nexport type PgHalfVectorBuilderInitial<TName extends string, TDimensions extends number> = PgHalfVectorBuilder<{\n\tname: TName;\n\tdataType: 'array';\n\tcolumnType: 'PgHalfVector';\n\tdata: number[];\n\tdriverParam: string;\n\tenumValues: undefined;\n\tdimensions: TDimensions;\n}>;\n\nexport class PgHalfVectorBuilder<T extends ColumnBuilderBaseConfig<'array', 'PgHalfVector'> & { dimensions: number }>\n\textends PgColumnBuilder<\n\t\tT,\n\t\t{ dimensions: T['dimensions'] },\n\t\t{ dimensions: T['dimensions'] }\n\t>\n{\n\tstatic override readonly [entityKind]: string = 'PgHalfVectorBuilder';\n\n\tconstructor(name: string, config: PgHalfVectorConfig<T['dimensions']>) {\n\t\tsuper(name, 'array', 'PgHalfVector');\n\t\tthis.config.dimensions = config.dimensions;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgHalfVector<MakeColumnConfig<T, TTableName> & { dimensions: T['dimensions'] }> {\n\t\treturn new PgHalfVector<MakeColumnConfig<T, TTableName> & { dimensions: T['dimensions'] }>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgHalfVector<T extends ColumnBaseConfig<'array', 'PgHalfVector'> & { dimensions: number }>\n\textends PgColumn<T, { dimensions: T['dimensions'] }, { dimensions: T['dimensions'] }>\n{\n\tstatic override readonly [entityKind]: string = 'PgHalfVector';\n\n\treadonly dimensions: T['dimensions'] = this.config.dimensions;\n\n\tgetSQLType(): string {\n\t\treturn `halfvec(${this.dimensions})`;\n\t}\n\n\toverride mapToDriverValue(value: unknown): unknown {\n\t\treturn JSON.stringify(value);\n\t}\n\n\toverride mapFromDriverValue(value: string): unknown {\n\t\treturn value\n\t\t\t.slice(1, -1)\n\t\t\t.split(',')\n\t\t\t.map((v) => Number.parseFloat(v));\n\t}\n}\n\nexport interface PgHalfVectorConfig<TDimensions extends number = number> {\n\tdimensions: TDimensions;\n}\n\nexport function halfvec<D extends number>(\n\tconfig: PgHalfVectorConfig<D>,\n): PgHalfVectorBuilderInitial<'', D>;\nexport function halfvec<TName extends string, D extends number>(\n\tname: TName,\n\tconfig: PgHalfVectorConfig,\n): PgHalfVectorBuilderInitial<TName, D>;\nexport function halfvec(a: string | PgHalfVectorConfig, b?: PgHalfVectorConfig) {\n\tconst { name, config } = getColumnNameAndConfig<PgHalfVectorConfig>(a, b);\n\treturn new PgHalfVectorBuilder(name, config);\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from '../common.ts';\n\nexport type PgSparseVectorBuilderInitial<TName extends string> = PgSparseVectorBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'PgSparseVector';\n\tdata: string;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class PgSparseVectorBuilder<T extends ColumnBuilderBaseConfig<'string', 'PgSparseVector'>>\n\textends PgColumnBuilder<\n\t\tT,\n\t\t{ dimensions: number | undefined }\n\t>\n{\n\tstatic override readonly [entityKind]: string = 'PgSparseVectorBuilder';\n\n\tconstructor(name: string, config: PgSparseVectorConfig) {\n\t\tsuper(name, 'string', 'PgSparseVector');\n\t\tthis.config.dimensions = config.dimensions;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgSparseVector<MakeColumnConfig<T, TTableName>> {\n\t\treturn new PgSparseVector<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgSparseVector<T extends ColumnBaseConfig<'string', 'PgSparseVector'>>\n\textends PgColumn<T, { dimensions: number | undefined }>\n{\n\tstatic override readonly [entityKind]: string = 'PgSparseVector';\n\n\treadonly dimensions = this.config.dimensions;\n\n\tgetSQLType(): string {\n\t\treturn `sparsevec(${this.dimensions})`;\n\t}\n}\n\nexport interface PgSparseVectorConfig {\n\tdimensions: number;\n}\n\nexport function sparsevec(\n\tconfig: PgSparseVectorConfig,\n): PgSparseVectorBuilderInitial<''>;\nexport function sparsevec<TName extends string>(\n\tname: TName,\n\tconfig: PgSparseVectorConfig,\n): PgSparseVectorBuilderInitial<TName>;\nexport function sparsevec(a: string | PgSparseVectorConfig, b?: PgSparseVectorConfig) {\n\tconst { name, config } = getColumnNameAndConfig<PgSparseVectorConfig>(a, b);\n\treturn new PgSparseVectorBuilder(name, config);\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnyPgTable } from '~/pg-core/table.ts';\nimport { getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from '../common.ts';\n\nexport type PgVectorBuilderInitial<TName extends string, TDimensions extends number> = PgVectorBuilder<{\n\tname: TName;\n\tdataType: 'array';\n\tcolumnType: 'PgVector';\n\tdata: number[];\n\tdriverParam: string;\n\tenumValues: undefined;\n\tdimensions: TDimensions;\n}>;\n\nexport class PgVectorBuilder<T extends ColumnBuilderBaseConfig<'array', 'PgVector'> & { dimensions: number }>\n\textends PgColumnBuilder<\n\t\tT,\n\t\t{ dimensions: T['dimensions'] },\n\t\t{ dimensions: T['dimensions'] }\n\t>\n{\n\tstatic override readonly [entityKind]: string = 'PgVectorBuilder';\n\n\tconstructor(name: string, config: PgVectorConfig<T['dimensions']>) {\n\t\tsuper(name, 'array', 'PgVector');\n\t\tthis.config.dimensions = config.dimensions;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): PgVector<MakeColumnConfig<T, TTableName> & { dimensions: T['dimensions'] }> {\n\t\treturn new PgVector<MakeColumnConfig<T, TTableName> & { dimensions: T['dimensions'] }>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class PgVector<T extends ColumnBaseConfig<'array', 'PgVector'> & { dimensions: number | undefined }>\n\textends PgColumn<T, { dimensions: T['dimensions'] }, { dimensions: T['dimensions'] }>\n{\n\tstatic override readonly [entityKind]: string = 'PgVector';\n\n\treadonly dimensions: T['dimensions'] = this.config.dimensions;\n\n\tgetSQLType(): string {\n\t\treturn `vector(${this.dimensions})`;\n\t}\n\n\toverride mapToDriverValue(value: unknown): unknown {\n\t\treturn JSON.stringify(value);\n\t}\n\n\toverride mapFromDriverValue(value: string): unknown {\n\t\treturn value\n\t\t\t.slice(1, -1)\n\t\t\t.split(',')\n\t\t\t.map((v) => Number.parseFloat(v));\n\t}\n}\n\nexport interface PgVectorConfig<TDimensions extends number = number> {\n\tdimensions: TDimensions;\n}\n\nexport function vector<D extends number>(\n\tconfig: PgVectorConfig<D>,\n): PgVectorBuilderInitial<'', D>;\nexport function vector<TName extends string, D extends number>(\n\tname: TName,\n\tconfig: PgVectorConfig<D>,\n): PgVectorBuilderInitial<TName, D>;\nexport function vector(a: string | PgVectorConfig, b?: PgVectorConfig) {\n\tconst { name, config } = getColumnNameAndConfig<PgVectorConfig>(a, b);\n\treturn new PgVectorBuilder(name, config);\n}\n","import { bigint } from './bigint.ts';\nimport { bigserial } from './bigserial.ts';\nimport { boolean } from './boolean.ts';\nimport { char } from './char.ts';\nimport { cidr } from './cidr.ts';\nimport { customType } from './custom.ts';\nimport { date } from './date.ts';\nimport { doublePrecision } from './double-precision.ts';\nimport { inet } from './inet.ts';\nimport { integer } from './integer.ts';\nimport { interval } from './interval.ts';\nimport { json } from './json.ts';\nimport { jsonb } from './jsonb.ts';\nimport { line } from './line.ts';\nimport { macaddr } from './macaddr.ts';\nimport { macaddr8 } from './macaddr8.ts';\nimport { numeric } from './numeric.ts';\nimport { point } from './point.ts';\nimport { geometry } from './postgis_extension/geometry.ts';\nimport { real } from './real.ts';\nimport { serial } from './serial.ts';\nimport { smallint } from './smallint.ts';\nimport { smallserial } from './smallserial.ts';\nimport { text } from './text.ts';\nimport { time } from './time.ts';\nimport { timestamp } from './timestamp.ts';\nimport { uuid } from './uuid.ts';\nimport { varchar } from './varchar.ts';\nimport { bit } from './vector_extension/bit.ts';\nimport { halfvec } from './vector_extension/halfvec.ts';\nimport { sparsevec } from './vector_extension/sparsevec.ts';\nimport { vector } from './vector_extension/vector.ts';\n\nexport function getPgColumnBuilders() {\n\treturn {\n\t\tbigint,\n\t\tbigserial,\n\t\tboolean,\n\t\tchar,\n\t\tcidr,\n\t\tcustomType,\n\t\tdate,\n\t\tdoublePrecision,\n\t\tinet,\n\t\tinteger,\n\t\tinterval,\n\t\tjson,\n\t\tjsonb,\n\t\tline,\n\t\tmacaddr,\n\t\tmacaddr8,\n\t\tnumeric,\n\t\tpoint,\n\t\tgeometry,\n\t\treal,\n\t\tserial,\n\t\tsmallint,\n\t\tsmallserial,\n\t\ttext,\n\t\ttime,\n\t\ttimestamp,\n\t\tuuid,\n\t\tvarchar,\n\t\tbit,\n\t\thalfvec,\n\t\tsparsevec,\n\t\tvector,\n\t};\n}\n\nexport type PgColumnsBuilders = ReturnType<typeof getPgColumnBuilders>;\n","import type { BuildColumns, BuildExtraConfigColumns } from '~/column-builder.ts';\nimport { entityKind } from '~/entity.ts';\nimport { Table, type TableConfig as TableConfigBase, type UpdateTableConfig } from '~/table.ts';\nimport type { CheckBuilder } from './checks.ts';\nimport { getPgColumnBuilders, type PgColumnsBuilders } from './columns/all.ts';\nimport type { ExtraConfigColumn, PgColumn, PgColumnBuilder, PgColumnBuilderBase } from './columns/common.ts';\nimport type { ForeignKey, ForeignKeyBuilder } from './foreign-keys.ts';\nimport type { AnyIndexBuilder } from './indexes.ts';\nimport type { PgPolicy } from './policies.ts';\nimport type { PrimaryKeyBuilder } from './primary-keys.ts';\nimport type { UniqueConstraintBuilder } from './unique-constraint.ts';\n\nexport type PgTableExtraConfigValue =\n\t| AnyIndexBuilder\n\t| CheckBuilder\n\t| ForeignKeyBuilder\n\t| PrimaryKeyBuilder\n\t| UniqueConstraintBuilder\n\t| PgPolicy;\n\nexport type PgTableExtraConfig = Record<\n\tstring,\n\tPgTableExtraConfigValue\n>;\n\nexport type TableConfig = TableConfigBase<PgColumn>;\n\n/** @internal */\nexport const InlineForeignKeys = Symbol.for('drizzle:PgInlineForeignKeys');\n/** @internal */\nexport const EnableRLS = Symbol.for('drizzle:EnableRLS');\n\nexport class PgTable<T extends TableConfig = TableConfig> extends Table<T> {\n\tstatic override readonly [entityKind]: string = 'PgTable';\n\n\t/** @internal */\n\tstatic override readonly Symbol = Object.assign({}, Table.Symbol, {\n\t\tInlineForeignKeys: InlineForeignKeys as typeof InlineForeignKeys,\n\t\tEnableRLS: EnableRLS as typeof EnableRLS,\n\t});\n\n\t/**@internal */\n\t[InlineForeignKeys]: ForeignKey[] = [];\n\n\t/** @internal */\n\t[EnableRLS]: boolean = false;\n\n\t/** @internal */\n\toverride [Table.Symbol.ExtraConfigBuilder]: ((self: Record<string, PgColumn>) => PgTableExtraConfig) | undefined =\n\t\tundefined;\n\n\t/** @internal */\n\toverride [Table.Symbol.ExtraConfigColumns]: Record<string, ExtraConfigColumn> = {};\n}\n\nexport type AnyPgTable<TPartial extends Partial<TableConfig> = {}> = PgTable<UpdateTableConfig<TableConfig, TPartial>>;\n\nexport type PgTableWithColumns<T extends TableConfig> =\n\t& PgTable<T>\n\t& {\n\t\t[Key in keyof T['columns']]: T['columns'][Key];\n\t}\n\t& {\n\t\tenableRLS: () => Omit<\n\t\t\tPgTableWithColumns<T>,\n\t\t\t'enableRLS'\n\t\t>;\n\t};\n\n/** @internal */\nexport function pgTableWithSchema<\n\tTTableName extends string,\n\tTSchemaName extends string | undefined,\n\tTColumnsMap extends Record<string, PgColumnBuilderBase>,\n>(\n\tname: TTableName,\n\tcolumns: TColumnsMap | ((columnTypes: PgColumnsBuilders) => TColumnsMap),\n\textraConfig:\n\t\t| ((self: BuildExtraConfigColumns<TTableName, TColumnsMap, 'pg'>) => PgTableExtraConfig | PgTableExtraConfigValue[])\n\t\t| undefined,\n\tschema: TSchemaName,\n\tbaseName = name,\n): PgTableWithColumns<{\n\tname: TTableName;\n\tschema: TSchemaName;\n\tcolumns: BuildColumns<TTableName, TColumnsMap, 'pg'>;\n\tdialect: 'pg';\n}> {\n\tconst rawTable = new PgTable<{\n\t\tname: TTableName;\n\t\tschema: TSchemaName;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'pg'>;\n\t\tdialect: 'pg';\n\t}>(name, schema, baseName);\n\n\tconst parsedColumns: TColumnsMap = typeof columns === 'function' ? columns(getPgColumnBuilders()) : columns;\n\n\tconst builtColumns = Object.fromEntries(\n\t\tObject.entries(parsedColumns).map(([name, colBuilderBase]) => {\n\t\t\tconst colBuilder = colBuilderBase as PgColumnBuilder;\n\t\t\tcolBuilder.setName(name);\n\t\t\tconst column = colBuilder.build(rawTable);\n\t\t\trawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n\t\t\treturn [name, column];\n\t\t}),\n\t) as unknown as BuildColumns<TTableName, TColumnsMap, 'pg'>;\n\n\tconst builtColumnsForExtraConfig = Object.fromEntries(\n\t\tObject.entries(parsedColumns).map(([name, colBuilderBase]) => {\n\t\t\tconst colBuilder = colBuilderBase as PgColumnBuilder;\n\t\t\tcolBuilder.setName(name);\n\t\t\tconst column = colBuilder.buildExtraConfigColumn(rawTable);\n\t\t\treturn [name, column];\n\t\t}),\n\t) as unknown as BuildExtraConfigColumns<TTableName, TColumnsMap, 'pg'>;\n\n\tconst table = Object.assign(rawTable, builtColumns);\n\n\ttable[Table.Symbol.Columns] = builtColumns;\n\ttable[Table.Symbol.ExtraConfigColumns] = builtColumnsForExtraConfig;\n\n\tif (extraConfig) {\n\t\ttable[PgTable.Symbol.ExtraConfigBuilder] = extraConfig as any;\n\t}\n\n\treturn Object.assign(table, {\n\t\tenableRLS: () => {\n\t\t\ttable[PgTable.Symbol.EnableRLS] = true;\n\t\t\treturn table as PgTableWithColumns<{\n\t\t\t\tname: TTableName;\n\t\t\t\tschema: TSchemaName;\n\t\t\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'pg'>;\n\t\t\t\tdialect: 'pg';\n\t\t\t}>;\n\t\t},\n\t});\n}\n\nexport interface PgTableFn<TSchema extends string | undefined = undefined> {\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, PgColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig?: (\n\t\t\tself: BuildExtraConfigColumns<TTableName, TColumnsMap, 'pg'>,\n\t\t) => PgTableExtraConfigValue[],\n\t): PgTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'pg'>;\n\t\tdialect: 'pg';\n\t}>;\n\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, PgColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: (columnTypes: PgColumnsBuilders) => TColumnsMap,\n\t\textraConfig?: (self: BuildExtraConfigColumns<TTableName, TColumnsMap, 'pg'>) => PgTableExtraConfigValue[],\n\t): PgTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'pg'>;\n\t\tdialect: 'pg';\n\t}>;\n\t/**\n\t * @deprecated The third parameter of pgTable is changing and will only accept an array instead of an object\n\t *\n\t * @example\n\t * Deprecated version:\n\t * ```ts\n\t * export const users = pgTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => ({\n\t * \tidx: index('custom_name').on(t.id)\n\t * }));\n\t * ```\n\t *\n\t * New API:\n\t * ```ts\n\t * export const users = pgTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => [\n\t * \tindex('custom_name').on(t.id)\n\t * ]);\n\t * ```\n\t */\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, PgColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig: (\n\t\t\tself: BuildExtraConfigColumns<TTableName, TColumnsMap, 'pg'>,\n\t\t) => PgTableExtraConfig,\n\t): PgTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'pg'>;\n\t\tdialect: 'pg';\n\t}>;\n\n\t/**\n\t * @deprecated The third parameter of pgTable is changing and will only accept an array instead of an object\n\t *\n\t * @example\n\t * Deprecated version:\n\t * ```ts\n\t * export const users = pgTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => ({\n\t * \tidx: index('custom_name').on(t.id)\n\t * }));\n\t * ```\n\t *\n\t * New API:\n\t * ```ts\n\t * export const users = pgTable(\"users\", {\n\t * \tid: integer(),\n\t * }, (t) => [\n\t * \tindex('custom_name').on(t.id)\n\t * ]);\n\t * ```\n\t */\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, PgColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: (columnTypes: PgColumnsBuilders) => TColumnsMap,\n\t\textraConfig: (self: BuildExtraConfigColumns<TTableName, TColumnsMap, 'pg'>) => PgTableExtraConfig,\n\t): PgTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'pg'>;\n\t\tdialect: 'pg';\n\t}>;\n}\n\nexport const pgTable: PgTableFn = (name, columns, extraConfig) => {\n\treturn pgTableWithSchema(name, columns, extraConfig, undefined);\n};\n\nexport function pgTableCreator(customizeTableName: (name: string) => string): PgTableFn {\n\treturn (name, columns, extraConfig) => {\n\t\treturn pgTableWithSchema(customizeTableName(name) as typeof name, columns, extraConfig, undefined, name);\n\t};\n}\n","import { entityKind } from '~/entity.ts';\nimport type { AnyPgColumn, PgColumn } from './columns/index.ts';\nimport { PgTable } from './table.ts';\n\nexport function primaryKey<\n\tTTableName extends string,\n\tTColumn extends AnyPgColumn<{ tableName: TTableName }>,\n\tTColumns extends AnyPgColumn<{ tableName: TTableName }>[],\n>(config: { name?: string; columns: [TColumn, ...TColumns] }): PrimaryKeyBuilder;\n/**\n * @deprecated: Please use primaryKey({ columns: [] }) instead of this function\n * @param columns\n */\nexport function primaryKey<\n\tTTableName extends string,\n\tTColumns extends AnyPgColumn<{ tableName: TTableName }>[],\n>(...columns: TColumns): PrimaryKeyBuilder;\nexport function primaryKey(...config: any) {\n\tif (config[0].columns) {\n\t\treturn new PrimaryKeyBuilder(config[0].columns, config[0].name);\n\t}\n\treturn new PrimaryKeyBuilder(config);\n}\n\nexport class PrimaryKeyBuilder {\n\tstatic readonly [entityKind]: string = 'PgPrimaryKeyBuilder';\n\n\t/** @internal */\n\tcolumns: PgColumn[];\n\n\t/** @internal */\n\tname?: string;\n\n\tconstructor(\n\t\tcolumns: PgColumn[],\n\t\tname?: string,\n\t) {\n\t\tthis.columns = columns;\n\t\tthis.name = name;\n\t}\n\n\t/** @internal */\n\tbuild(table: PgTable): PrimaryKey {\n\t\treturn new PrimaryKey(table, this.columns, this.name);\n\t}\n}\n\nexport class PrimaryKey {\n\tstatic readonly [entityKind]: string = 'PgPrimaryKey';\n\n\treadonly columns: AnyPgColumn<{}>[];\n\treadonly name?: string;\n\n\tconstructor(readonly table: PgTable, columns: AnyPgColumn<{}>[], name?: string) {\n\t\tthis.columns = columns;\n\t\tthis.name = name;\n\t}\n\n\tgetName(): string {\n\t\treturn this.name ?? `${this.table[PgTable.Symbol.Name]}_${this.columns.map((column) => column.name).join('_')}_pk`;\n\t}\n}\n","import { type AnyColumn, Column, type GetColumnData } from '~/column.ts';\nimport { is } from '~/entity.ts';\nimport { Table } from '~/table.ts';\nimport {\n\tisDriverValueEncoder,\n\tisSQLWrapper,\n\tParam,\n\tPlaceholder,\n\tSQL,\n\tsql,\n\ttype SQLChunk,\n\ttype SQLWrapper,\n\tStringChunk,\n\tView,\n} from '../sql.ts';\n\nexport function bindIfParam(value: unknown, column: SQLWrapper): SQLChunk {\n\tif (\n\t\tisDriverValueEncoder(column)\n\t\t&& !isSQLWrapper(value)\n\t\t&& !is(value, Param)\n\t\t&& !is(value, Placeholder)\n\t\t&& !is(value, Column)\n\t\t&& !is(value, Table)\n\t\t&& !is(value, View)\n\t) {\n\t\treturn new Param(value, column);\n\t}\n\treturn value as SQLChunk;\n}\n\nexport interface BinaryOperator {\n\t<TColumn extends Column>(\n\t\tleft: TColumn,\n\t\tright: GetColumnData<TColumn, 'raw'> | SQLWrapper,\n\t): SQL;\n\t<T>(left: SQL.Aliased<T>, right: T | SQLWrapper): SQL;\n\t<T extends SQLWrapper>(\n\t\tleft: Exclude<T, SQL.Aliased | Column>,\n\t\tright: unknown,\n\t): SQL;\n}\n\n/**\n * Test that two values are equal.\n *\n * Remember that the SQL standard dictates that\n * two NULL values are not equal, so if you want to test\n * whether a value is null, you may want to use\n * `isNull` instead.\n *\n * ## Examples\n *\n * ```ts\n * // Select cars made by Ford\n * db.select().from(cars)\n * .where(eq(cars.make, 'Ford'))\n * ```\n *\n * @see isNull for a way to test equality to NULL.\n */\nexport const eq: BinaryOperator = (left: SQLWrapper, right: unknown): SQL => {\n\treturn sql`${left} = ${bindIfParam(right, left)}`;\n};\n\n/**\n * Test that two values are not equal.\n *\n * Remember that the SQL standard dictates that\n * two NULL values are not equal, so if you want to test\n * whether a value is not null, you may want to use\n * `isNotNull` instead.\n *\n * ## Examples\n *\n * ```ts\n * // Select cars not made by Ford\n * db.select().from(cars)\n * .where(ne(cars.make, 'Ford'))\n * ```\n *\n * @see isNotNull for a way to test whether a value is not null.\n */\nexport const ne: BinaryOperator = (left: SQLWrapper, right: unknown): SQL => {\n\treturn sql`${left} <> ${bindIfParam(right, left)}`;\n};\n\n/**\n * Combine a list of conditions with the `and` operator. Conditions\n * that are equal `undefined` are automatically ignored.\n *\n * ## Examples\n *\n * ```ts\n * db.select().from(cars)\n * .where(\n * and(\n * eq(cars.make, 'Volvo'),\n * eq(cars.year, 1950),\n * )\n * )\n * ```\n */\nexport function and(...conditions: (SQLWrapper | undefined)[]): SQL | undefined;\nexport function and(\n\t...unfilteredConditions: (SQLWrapper | undefined)[]\n): SQL | undefined {\n\tconst conditions = unfilteredConditions.filter(\n\t\t(c): c is Exclude<typeof c, undefined> => c !== undefined,\n\t);\n\n\tif (conditions.length === 0) {\n\t\treturn undefined;\n\t}\n\n\tif (conditions.length === 1) {\n\t\treturn new SQL(conditions);\n\t}\n\n\treturn new SQL([\n\t\tnew StringChunk('('),\n\t\tsql.join(conditions, new StringChunk(' and ')),\n\t\tnew StringChunk(')'),\n\t]);\n}\n\n/**\n * Combine a list of conditions with the `or` operator. Conditions\n * that are equal `undefined` are automatically ignored.\n *\n * ## Examples\n *\n * ```ts\n * db.select().from(cars)\n * .where(\n * or(\n * eq(cars.make, 'GM'),\n * eq(cars.make, 'Ford'),\n * )\n * )\n * ```\n */\nexport function or(...conditions: (SQLWrapper | undefined)[]): SQL | undefined;\nexport function or(\n\t...unfilteredConditions: (SQLWrapper | undefined)[]\n): SQL | undefined {\n\tconst conditions = unfilteredConditions.filter(\n\t\t(c): c is Exclude<typeof c, undefined> => c !== undefined,\n\t);\n\n\tif (conditions.length === 0) {\n\t\treturn undefined;\n\t}\n\n\tif (conditions.length === 1) {\n\t\treturn new SQL(conditions);\n\t}\n\n\treturn new SQL([\n\t\tnew StringChunk('('),\n\t\tsql.join(conditions, new StringChunk(' or ')),\n\t\tnew StringChunk(')'),\n\t]);\n}\n\n/**\n * Negate the meaning of an expression using the `not` keyword.\n *\n * ## Examples\n *\n * ```ts\n * // Select cars _not_ made by GM or Ford.\n * db.select().from(cars)\n * .where(not(inArray(cars.make, ['GM', 'Ford'])))\n * ```\n */\nexport function not(condition: SQLWrapper): SQL {\n\treturn sql`not ${condition}`;\n}\n\n/**\n * Test that the first expression passed is greater than\n * the second expression.\n *\n * ## Examples\n *\n * ```ts\n * // Select cars made after 2000.\n * db.select().from(cars)\n * .where(gt(cars.year, 2000))\n * ```\n *\n * @see gte for greater-than-or-equal\n */\nexport const gt: BinaryOperator = (left: SQLWrapper, right: unknown): SQL => {\n\treturn sql`${left} > ${bindIfParam(right, left)}`;\n};\n\n/**\n * Test that the first expression passed is greater than\n * or equal to the second expression. Use `gt` to\n * test whether an expression is strictly greater\n * than another.\n *\n * ## Examples\n *\n * ```ts\n * // Select cars made on or after 2000.\n * db.select().from(cars)\n * .where(gte(cars.year, 2000))\n * ```\n *\n * @see gt for a strictly greater-than condition\n */\nexport const gte: BinaryOperator = (left: SQLWrapper, right: unknown): SQL => {\n\treturn sql`${left} >= ${bindIfParam(right, left)}`;\n};\n\n/**\n * Test that the first expression passed is less than\n * the second expression.\n *\n * ## Examples\n *\n * ```ts\n * // Select cars made before 2000.\n * db.select().from(cars)\n * .where(lt(cars.year, 2000))\n * ```\n *\n * @see lte for less-than-or-equal\n */\nexport const lt: BinaryOperator = (left: SQLWrapper, right: unknown): SQL => {\n\treturn sql`${left} < ${bindIfParam(right, left)}`;\n};\n\n/**\n * Test that the first expression passed is less than\n * or equal to the second expression.\n *\n * ## Examples\n *\n * ```ts\n * // Select cars made before 2000.\n * db.select().from(cars)\n * .where(lte(cars.year, 2000))\n * ```\n *\n * @see lt for a strictly less-than condition\n */\nexport const lte: BinaryOperator = (left: SQLWrapper, right: unknown): SQL => {\n\treturn sql`${left} <= ${bindIfParam(right, left)}`;\n};\n\n/**\n * Test whether the first parameter, a column or expression,\n * has a value from a list passed as the second argument.\n *\n * ## Examples\n *\n * ```ts\n * // Select cars made by Ford or GM.\n * db.select().from(cars)\n * .where(inArray(cars.make, ['Ford', 'GM']))\n * ```\n *\n * @see notInArray for the inverse of this test\n */\nexport function inArray<T>(\n\tcolumn: SQL.Aliased<T>,\n\tvalues: (T | Placeholder)[] | SQLWrapper,\n): SQL;\nexport function inArray<TColumn extends Column>(\n\tcolumn: TColumn,\n\tvalues: ReadonlyArray<GetColumnData<TColumn, 'raw'> | Placeholder> | SQLWrapper,\n): SQL;\nexport function inArray<T extends SQLWrapper>(\n\tcolumn: Exclude<T, SQL.Aliased | Column>,\n\tvalues: ReadonlyArray<unknown | Placeholder> | SQLWrapper,\n): SQL;\nexport function inArray(\n\tcolumn: SQLWrapper,\n\tvalues: ReadonlyArray<unknown | Placeholder> | SQLWrapper,\n): SQL {\n\tif (Array.isArray(values)) {\n\t\tif (values.length === 0) {\n\t\t\treturn sql`false`;\n\t\t}\n\t\treturn sql`${column} in ${values.map((v) => bindIfParam(v, column))}`;\n\t}\n\n\treturn sql`${column} in ${bindIfParam(values, column)}`;\n}\n\n/**\n * Test whether the first parameter, a column or expression,\n * has a value that is not present in a list passed as the\n * second argument.\n *\n * ## Examples\n *\n * ```ts\n * // Select cars made by any company except Ford or GM.\n * db.select().from(cars)\n * .where(notInArray(cars.make, ['Ford', 'GM']))\n * ```\n *\n * @see inArray for the inverse of this test\n */\nexport function notInArray<T>(\n\tcolumn: SQL.Aliased<T>,\n\tvalues: (T | Placeholder)[] | SQLWrapper,\n): SQL;\nexport function notInArray<TColumn extends Column>(\n\tcolumn: TColumn,\n\tvalues: (GetColumnData<TColumn, 'raw'> | Placeholder)[] | SQLWrapper,\n): SQL;\nexport function notInArray<T extends SQLWrapper>(\n\tcolumn: Exclude<T, SQL.Aliased | Column>,\n\tvalues: (unknown | Placeholder)[] | SQLWrapper,\n): SQL;\nexport function notInArray(\n\tcolumn: SQLWrapper,\n\tvalues: (unknown | Placeholder)[] | SQLWrapper,\n): SQL {\n\tif (Array.isArray(values)) {\n\t\tif (values.length === 0) {\n\t\t\treturn sql`true`;\n\t\t}\n\t\treturn sql`${column} not in ${values.map((v) => bindIfParam(v, column))}`;\n\t}\n\n\treturn sql`${column} not in ${bindIfParam(values, column)}`;\n}\n\n/**\n * Test whether an expression is NULL. By the SQL standard,\n * NULL is neither equal nor not equal to itself, so\n * it's recommended to use `isNull` and `notIsNull` for\n * comparisons to NULL.\n *\n * ## Examples\n *\n * ```ts\n * // Select cars that have no discontinuedAt date.\n * db.select().from(cars)\n * .where(isNull(cars.discontinuedAt))\n * ```\n *\n * @see isNotNull for the inverse of this test\n */\nexport function isNull(value: SQLWrapper): SQL {\n\treturn sql`${value} is null`;\n}\n\n/**\n * Test whether an expression is not NULL. By the SQL standard,\n * NULL is neither equal nor not equal to itself, so\n * it's recommended to use `isNull` and `notIsNull` for\n * comparisons to NULL.\n *\n * ## Examples\n *\n * ```ts\n * // Select cars that have been discontinued.\n * db.select().from(cars)\n * .where(isNotNull(cars.discontinuedAt))\n * ```\n *\n * @see isNull for the inverse of this test\n */\nexport function isNotNull(value: SQLWrapper): SQL {\n\treturn sql`${value} is not null`;\n}\n\n/**\n * Test whether a subquery evaluates to have any rows.\n *\n * ## Examples\n *\n * ```ts\n * // Users whose `homeCity` column has a match in a cities\n * // table.\n * db\n * .select()\n * .from(users)\n * .where(\n * exists(db.select()\n * .from(cities)\n * .where(eq(users.homeCity, cities.id))),\n * );\n * ```\n *\n * @see notExists for the inverse of this test\n */\nexport function exists(subquery: SQLWrapper): SQL {\n\treturn sql`exists ${subquery}`;\n}\n\n/**\n * Test whether a subquery doesn't include any result\n * rows.\n *\n * ## Examples\n *\n * ```ts\n * // Users whose `homeCity` column doesn't match\n * // a row in the cities table.\n * db\n * .select()\n * .from(users)\n * .where(\n * notExists(db.select()\n * .from(cities)\n * .where(eq(users.homeCity, cities.id))),\n * );\n * ```\n *\n * @see exists for the inverse of this test\n */\nexport function notExists(subquery: SQLWrapper): SQL {\n\treturn sql`not exists ${subquery}`;\n}\n\n/**\n * Test whether an expression is between two values. This\n * is an easier way to express range tests, which would be\n * expressed mathematically as `x <= a <= y` but in SQL\n * would have to be like `a >= x AND a <= y`.\n *\n * Between is inclusive of the endpoints: if `column`\n * is equal to `min` or `max`, it will be TRUE.\n *\n * ## Examples\n *\n * ```ts\n * // Select cars made between 1990 and 2000\n * db.select().from(cars)\n * .where(between(cars.year, 1990, 2000))\n * ```\n *\n * @see notBetween for the inverse of this test\n */\nexport function between<T>(\n\tcolumn: SQL.Aliased,\n\tmin: T | SQLWrapper,\n\tmax: T | SQLWrapper,\n): SQL;\nexport function between<TColumn extends AnyColumn>(\n\tcolumn: TColumn,\n\tmin: GetColumnData<TColumn, 'raw'> | SQLWrapper,\n\tmax: GetColumnData<TColumn, 'raw'> | SQLWrapper,\n): SQL;\nexport function between<T extends SQLWrapper>(\n\tcolumn: Exclude<T, SQL.Aliased | Column>,\n\tmin: unknown,\n\tmax: unknown,\n): SQL;\nexport function between(column: SQLWrapper, min: unknown, max: unknown): SQL {\n\treturn sql`${column} between ${bindIfParam(min, column)} and ${\n\t\tbindIfParam(\n\t\t\tmax,\n\t\t\tcolumn,\n\t\t)\n\t}`;\n}\n\n/**\n * Test whether an expression is not between two values.\n *\n * This, like `between`, includes its endpoints, so if\n * the `column` is equal to `min` or `max`, in this case\n * it will evaluate to FALSE.\n *\n * ## Examples\n *\n * ```ts\n * // Exclude cars made in the 1970s\n * db.select().from(cars)\n * .where(notBetween(cars.year, 1970, 1979))\n * ```\n *\n * @see between for the inverse of this test\n */\nexport function notBetween<T>(\n\tcolumn: SQL.Aliased,\n\tmin: T | SQLWrapper,\n\tmax: T | SQLWrapper,\n): SQL;\nexport function notBetween<TColumn extends AnyColumn>(\n\tcolumn: TColumn,\n\tmin: GetColumnData<TColumn, 'raw'> | SQLWrapper,\n\tmax: GetColumnData<TColumn, 'raw'> | SQLWrapper,\n): SQL;\nexport function notBetween<T extends SQLWrapper>(\n\tcolumn: Exclude<T, SQL.Aliased | Column>,\n\tmin: unknown,\n\tmax: unknown,\n): SQL;\nexport function notBetween(\n\tcolumn: SQLWrapper,\n\tmin: unknown,\n\tmax: unknown,\n): SQL {\n\treturn sql`${column} not between ${\n\t\tbindIfParam(\n\t\t\tmin,\n\t\t\tcolumn,\n\t\t)\n\t} and ${bindIfParam(max, column)}`;\n}\n\n/**\n * Compare a column to a pattern, which can include `%` and `_`\n * characters to match multiple variations. Including `%`\n * in the pattern matches zero or more characters, and including\n * `_` will match a single character.\n *\n * ## Examples\n *\n * ```ts\n * // Select all cars with 'Turbo' in their names.\n * db.select().from(cars)\n * .where(like(cars.name, '%Turbo%'))\n * ```\n *\n * @see ilike for a case-insensitive version of this condition\n */\nexport function like(column: Column | SQL.Aliased | SQL, value: string | SQLWrapper): SQL {\n\treturn sql`${column} like ${value}`;\n}\n\n/**\n * The inverse of like - this tests that a given column\n * does not match a pattern, which can include `%` and `_`\n * characters to match multiple variations. Including `%`\n * in the pattern matches zero or more characters, and including\n * `_` will match a single character.\n *\n * ## Examples\n *\n * ```ts\n * // Select all cars that don't have \"ROver\" in their name.\n * db.select().from(cars)\n * .where(notLike(cars.name, '%Rover%'))\n * ```\n *\n * @see like for the inverse condition\n * @see notIlike for a case-insensitive version of this condition\n */\nexport function notLike(column: Column | SQL.Aliased | SQL, value: string | SQLWrapper): SQL {\n\treturn sql`${column} not like ${value}`;\n}\n\n/**\n * Case-insensitively compare a column to a pattern,\n * which can include `%` and `_`\n * characters to match multiple variations. Including `%`\n * in the pattern matches zero or more characters, and including\n * `_` will match a single character.\n *\n * Unlike like, this performs a case-insensitive comparison.\n *\n * ## Examples\n *\n * ```ts\n * // Select all cars with 'Turbo' in their names.\n * db.select().from(cars)\n * .where(ilike(cars.name, '%Turbo%'))\n * ```\n *\n * @see like for a case-sensitive version of this condition\n */\nexport function ilike(column: Column | SQL.Aliased | SQL, value: string | SQLWrapper): SQL {\n\treturn sql`${column} ilike ${value}`;\n}\n\n/**\n * The inverse of ilike - this case-insensitively tests that a given column\n * does not match a pattern, which can include `%` and `_`\n * characters to match multiple variations. Including `%`\n * in the pattern matches zero or more characters, and including\n * `_` will match a single character.\n *\n * ## Examples\n *\n * ```ts\n * // Select all cars that don't have \"Rover\" in their name.\n * db.select().from(cars)\n * .where(notLike(cars.name, '%Rover%'))\n * ```\n *\n * @see ilike for the inverse condition\n * @see notLike for a case-sensitive version of this condition\n */\nexport function notIlike(column: Column | SQL.Aliased | SQL, value: string | SQLWrapper): SQL {\n\treturn sql`${column} not ilike ${value}`;\n}\n\n/**\n * Test that a column or expression contains all elements of\n * the list passed as the second argument.\n *\n * ## Throws\n *\n * The argument passed in the second array can't be empty:\n * if an empty is provided, this method will throw.\n *\n * ## Examples\n *\n * ```ts\n * // Select posts where its tags contain \"Typescript\" and \"ORM\".\n * db.select().from(posts)\n * .where(arrayContains(posts.tags, ['Typescript', 'ORM']))\n * ```\n *\n * @see arrayContained to find if an array contains all elements of a column or expression\n * @see arrayOverlaps to find if a column or expression contains any elements of an array\n */\nexport function arrayContains<T>(\n\tcolumn: SQL.Aliased<T>,\n\tvalues: (T | Placeholder) | SQLWrapper,\n): SQL;\nexport function arrayContains<TColumn extends Column>(\n\tcolumn: TColumn,\n\tvalues: (GetColumnData<TColumn, 'raw'> | Placeholder) | SQLWrapper,\n): SQL;\nexport function arrayContains<T extends SQLWrapper>(\n\tcolumn: Exclude<T, SQL.Aliased | Column>,\n\tvalues: (unknown | Placeholder)[] | SQLWrapper,\n): SQL;\nexport function arrayContains(\n\tcolumn: SQLWrapper,\n\tvalues: (unknown | Placeholder)[] | SQLWrapper,\n): SQL {\n\tif (Array.isArray(values)) {\n\t\tif (values.length === 0) {\n\t\t\tthrow new Error('arrayContains requires at least one value');\n\t\t}\n\t\tconst array = sql`${bindIfParam(values, column)}`;\n\t\treturn sql`${column} @> ${array}`;\n\t}\n\n\treturn sql`${column} @> ${bindIfParam(values, column)}`;\n}\n\n/**\n * Test that the list passed as the second argument contains\n * all elements of a column or expression.\n *\n * ## Throws\n *\n * The argument passed in the second array can't be empty:\n * if an empty is provided, this method will throw.\n *\n * ## Examples\n *\n * ```ts\n * // Select posts where its tags contain \"Typescript\", \"ORM\" or both,\n * // but filtering posts that have additional tags.\n * db.select().from(posts)\n * .where(arrayContained(posts.tags, ['Typescript', 'ORM']))\n * ```\n *\n * @see arrayContains to find if a column or expression contains all elements of an array\n * @see arrayOverlaps to find if a column or expression contains any elements of an array\n */\nexport function arrayContained<T>(\n\tcolumn: SQL.Aliased<T>,\n\tvalues: (T | Placeholder) | SQLWrapper,\n): SQL;\nexport function arrayContained<TColumn extends Column>(\n\tcolumn: TColumn,\n\tvalues: (GetColumnData<TColumn, 'raw'> | Placeholder) | SQLWrapper,\n): SQL;\nexport function arrayContained<T extends SQLWrapper>(\n\tcolumn: Exclude<T, SQL.Aliased | Column>,\n\tvalues: (unknown | Placeholder)[] | SQLWrapper,\n): SQL;\nexport function arrayContained(\n\tcolumn: SQLWrapper,\n\tvalues: (unknown | Placeholder)[] | SQLWrapper,\n): SQL {\n\tif (Array.isArray(values)) {\n\t\tif (values.length === 0) {\n\t\t\tthrow new Error('arrayContained requires at least one value');\n\t\t}\n\t\tconst array = sql`${bindIfParam(values, column)}`;\n\t\treturn sql`${column} <@ ${array}`;\n\t}\n\n\treturn sql`${column} <@ ${bindIfParam(values, column)}`;\n}\n\n/**\n * Test that a column or expression contains any elements of\n * the list passed as the second argument.\n *\n * ## Throws\n *\n * The argument passed in the second array can't be empty:\n * if an empty is provided, this method will throw.\n *\n * ## Examples\n *\n * ```ts\n * // Select posts where its tags contain \"Typescript\", \"ORM\" or both.\n * db.select().from(posts)\n * .where(arrayOverlaps(posts.tags, ['Typescript', 'ORM']))\n * ```\n *\n * @see arrayContains to find if a column or expression contains all elements of an array\n * @see arrayContained to find if an array contains all elements of a column or expression\n */\nexport function arrayOverlaps<T>(\n\tcolumn: SQL.Aliased<T>,\n\tvalues: (T | Placeholder) | SQLWrapper,\n): SQL;\nexport function arrayOverlaps<TColumn extends Column>(\n\tcolumn: TColumn,\n\tvalues: (GetColumnData<TColumn, 'raw'> | Placeholder) | SQLWrapper,\n): SQL;\nexport function arrayOverlaps<T extends SQLWrapper>(\n\tcolumn: Exclude<T, SQL.Aliased | Column>,\n\tvalues: (unknown | Placeholder)[] | SQLWrapper,\n): SQL;\nexport function arrayOverlaps(\n\tcolumn: SQLWrapper,\n\tvalues: (unknown | Placeholder)[] | SQLWrapper,\n): SQL {\n\tif (Array.isArray(values)) {\n\t\tif (values.length === 0) {\n\t\t\tthrow new Error('arrayOverlaps requires at least one value');\n\t\t}\n\t\tconst array = sql`${bindIfParam(values, column)}`;\n\t\treturn sql`${column} && ${array}`;\n\t}\n\n\treturn sql`${column} && ${bindIfParam(values, column)}`;\n}\n","import type { AnyColumn } from '../../column.ts';\nimport type { SQL, SQLWrapper } from '../sql.ts';\nimport { sql } from '../sql.ts';\n\n/**\n * Used in sorting, this specifies that the given\n * column or expression should be sorted in ascending\n * order. By the SQL standard, ascending order is the\n * default, so it is not usually necessary to specify\n * ascending sort order.\n *\n * ## Examples\n *\n * ```ts\n * // Return cars, starting with the oldest models\n * // and going in ascending order to the newest.\n * db.select().from(cars)\n * .orderBy(asc(cars.year));\n * ```\n *\n * @see desc to sort in descending order\n */\nexport function asc(column: AnyColumn | SQLWrapper): SQL {\n\treturn sql`${column} asc`;\n}\n\n/**\n * Used in sorting, this specifies that the given\n * column or expression should be sorted in descending\n * order.\n *\n * ## Examples\n *\n * ```ts\n * // Select users, with the most recently created\n * // records coming first.\n * db.select().from(users)\n * .orderBy(desc(users.createdAt));\n * ```\n *\n * @see asc to sort in ascending order\n */\nexport function desc(column: AnyColumn | SQLWrapper): SQL {\n\treturn sql`${column} desc`;\n}\n","export * from './conditions.ts';\nexport * from './select.ts';\n","import { type AnyTable, getTableUniqueName, type InferModelFromColumns, Table } from '~/table.ts';\nimport { type AnyColumn, Column } from './column.ts';\nimport { entityKind, is } from './entity.ts';\nimport { PrimaryKeyBuilder } from './pg-core/primary-keys.ts';\nimport {\n\tand,\n\tasc,\n\tbetween,\n\tdesc,\n\teq,\n\texists,\n\tgt,\n\tgte,\n\tilike,\n\tinArray,\n\tisNotNull,\n\tisNull,\n\tlike,\n\tlt,\n\tlte,\n\tne,\n\tnot,\n\tnotBetween,\n\tnotExists,\n\tnotIlike,\n\tnotInArray,\n\tnotLike,\n\tor,\n} from './sql/expressions/index.ts';\nimport { type Placeholder, SQL, sql } from './sql/sql.ts';\nimport type { Assume, ColumnsWithTable, Equal, Simplify, ValueOrArray } from './utils.ts';\n\nexport abstract class Relation<TTableName extends string = string> {\n\tstatic readonly [entityKind]: string = 'Relation';\n\n\tdeclare readonly $brand: 'Relation';\n\treadonly referencedTableName: TTableName;\n\tfieldName!: string;\n\n\tconstructor(\n\t\treadonly sourceTable: Table,\n\t\treadonly referencedTable: AnyTable<{ name: TTableName }>,\n\t\treadonly relationName: string | undefined,\n\t) {\n\t\tthis.referencedTableName = referencedTable[Table.Symbol.Name] as TTableName;\n\t}\n\n\tabstract withFieldName(fieldName: string): Relation<TTableName>;\n}\n\nexport class Relations<\n\tTTableName extends string = string,\n\tTConfig extends Record<string, Relation> = Record<string, Relation>,\n> {\n\tstatic readonly [entityKind]: string = 'Relations';\n\n\tdeclare readonly $brand: 'Relations';\n\n\tconstructor(\n\t\treadonly table: AnyTable<{ name: TTableName }>,\n\t\treadonly config: (helpers: TableRelationsHelpers<TTableName>) => TConfig,\n\t) {}\n}\n\nexport class One<\n\tTTableName extends string = string,\n\tTIsNullable extends boolean = boolean,\n> extends Relation<TTableName> {\n\tstatic override readonly [entityKind]: string = 'One';\n\n\tdeclare protected $relationBrand: 'One';\n\n\tconstructor(\n\t\tsourceTable: Table,\n\t\treferencedTable: AnyTable<{ name: TTableName }>,\n\t\treadonly config:\n\t\t\t| RelationConfig<\n\t\t\t\tTTableName,\n\t\t\t\tstring,\n\t\t\t\tAnyColumn<{ tableName: TTableName }>[]\n\t\t\t>\n\t\t\t| undefined,\n\t\treadonly isNullable: TIsNullable,\n\t) {\n\t\tsuper(sourceTable, referencedTable, config?.relationName);\n\t}\n\n\twithFieldName(fieldName: string): One<TTableName> {\n\t\tconst relation = new One(\n\t\t\tthis.sourceTable,\n\t\t\tthis.referencedTable,\n\t\t\tthis.config,\n\t\t\tthis.isNullable,\n\t\t);\n\t\trelation.fieldName = fieldName;\n\t\treturn relation;\n\t}\n}\n\nexport class Many<TTableName extends string> extends Relation<TTableName> {\n\tstatic override readonly [entityKind]: string = 'Many';\n\n\tdeclare protected $relationBrand: 'Many';\n\n\tconstructor(\n\t\tsourceTable: Table,\n\t\treferencedTable: AnyTable<{ name: TTableName }>,\n\t\treadonly config: { relationName: string } | undefined,\n\t) {\n\t\tsuper(sourceTable, referencedTable, config?.relationName);\n\t}\n\n\twithFieldName(fieldName: string): Many<TTableName> {\n\t\tconst relation = new Many(\n\t\t\tthis.sourceTable,\n\t\t\tthis.referencedTable,\n\t\t\tthis.config,\n\t\t);\n\t\trelation.fieldName = fieldName;\n\t\treturn relation;\n\t}\n}\n\nexport type TableRelationsKeysOnly<\n\tTSchema extends Record<string, unknown>,\n\tTTableName extends string,\n\tK extends keyof TSchema,\n> = TSchema[K] extends Relations<TTableName> ? K : never;\n\nexport type ExtractTableRelationsFromSchema<\n\tTSchema extends Record<string, unknown>,\n\tTTableName extends string,\n> = ExtractObjectValues<\n\t{\n\t\t[\n\t\t\tK in keyof TSchema as TableRelationsKeysOnly<\n\t\t\t\tTSchema,\n\t\t\t\tTTableName,\n\t\t\t\tK\n\t\t\t>\n\t\t]: TSchema[K] extends Relations<TTableName, infer TConfig> ? TConfig : never;\n\t}\n>;\n\nexport type ExtractObjectValues<T> = T[keyof T];\n\nexport type ExtractRelationsFromTableExtraConfigSchema<\n\tTConfig extends unknown[],\n> = ExtractObjectValues<\n\t{\n\t\t[\n\t\t\tK in keyof TConfig as TConfig[K] extends Relations<any> ? K\n\t\t\t\t: never\n\t\t]: TConfig[K] extends Relations<infer TRelationConfig> ? TRelationConfig\n\t\t\t: never;\n\t}\n>;\n\nexport function getOperators() {\n\treturn {\n\t\tand,\n\t\tbetween,\n\t\teq,\n\t\texists,\n\t\tgt,\n\t\tgte,\n\t\tilike,\n\t\tinArray,\n\t\tisNull,\n\t\tisNotNull,\n\t\tlike,\n\t\tlt,\n\t\tlte,\n\t\tne,\n\t\tnot,\n\t\tnotBetween,\n\t\tnotExists,\n\t\tnotLike,\n\t\tnotIlike,\n\t\tnotInArray,\n\t\tor,\n\t\tsql,\n\t};\n}\n\nexport type Operators = ReturnType<typeof getOperators>;\n\nexport function getOrderByOperators() {\n\treturn {\n\t\tsql,\n\t\tasc,\n\t\tdesc,\n\t};\n}\n\nexport type OrderByOperators = ReturnType<typeof getOrderByOperators>;\n\nexport type FindTableByDBName<\n\tTSchema extends TablesRelationalConfig,\n\tTTableName extends string,\n> = ExtractObjectValues<\n\t{\n\t\t[\n\t\t\tK in keyof TSchema as TSchema[K]['dbName'] extends TTableName ? K\n\t\t\t\t: never\n\t\t]: TSchema[K];\n\t}\n>;\n\nexport type DBQueryConfig<\n\tTRelationType extends 'one' | 'many' = 'one' | 'many',\n\tTIsRoot extends boolean = boolean,\n\tTSchema extends TablesRelationalConfig = TablesRelationalConfig,\n\tTTableConfig extends TableRelationalConfig = TableRelationalConfig,\n> =\n\t& {\n\t\tcolumns?:\n\t\t\t| {\n\t\t\t\t[K in keyof TTableConfig['columns']]?: boolean;\n\t\t\t}\n\t\t\t| undefined;\n\t\twith?:\n\t\t\t| {\n\t\t\t\t[K in keyof TTableConfig['relations']]?:\n\t\t\t\t\t| true\n\t\t\t\t\t| DBQueryConfig<\n\t\t\t\t\t\tTTableConfig['relations'][K] extends One ? 'one' : 'many',\n\t\t\t\t\t\tfalse,\n\t\t\t\t\t\tTSchema,\n\t\t\t\t\t\tFindTableByDBName<\n\t\t\t\t\t\t\tTSchema,\n\t\t\t\t\t\t\tTTableConfig['relations'][K]['referencedTableName']\n\t\t\t\t\t\t>\n\t\t\t\t\t>\n\t\t\t\t\t| undefined;\n\t\t\t}\n\t\t\t| undefined;\n\t\textras?:\n\t\t\t| Record<string, SQL.Aliased>\n\t\t\t| ((\n\t\t\t\tfields: Simplify<\n\t\t\t\t\t[TTableConfig['columns']] extends [never] ? {}\n\t\t\t\t\t\t: TTableConfig['columns']\n\t\t\t\t>,\n\t\t\t\toperators: { sql: Operators['sql'] },\n\t\t\t) => Record<string, SQL.Aliased>)\n\t\t\t| undefined;\n\t}\n\t& (TRelationType extends 'many' ?\n\t\t\t& {\n\t\t\t\twhere?:\n\t\t\t\t\t| SQL\n\t\t\t\t\t| undefined\n\t\t\t\t\t| ((\n\t\t\t\t\t\tfields: Simplify<\n\t\t\t\t\t\t\t[TTableConfig['columns']] extends [never] ? {}\n\t\t\t\t\t\t\t\t: TTableConfig['columns']\n\t\t\t\t\t\t>,\n\t\t\t\t\t\toperators: Operators,\n\t\t\t\t\t) => SQL | undefined);\n\t\t\t\torderBy?:\n\t\t\t\t\t| ValueOrArray<AnyColumn | SQL>\n\t\t\t\t\t| ((\n\t\t\t\t\t\tfields: Simplify<\n\t\t\t\t\t\t\t[TTableConfig['columns']] extends [never] ? {}\n\t\t\t\t\t\t\t\t: TTableConfig['columns']\n\t\t\t\t\t\t>,\n\t\t\t\t\t\toperators: OrderByOperators,\n\t\t\t\t\t) => ValueOrArray<AnyColumn | SQL>)\n\t\t\t\t\t| undefined;\n\t\t\t\tlimit?: number | Placeholder | undefined;\n\t\t\t}\n\t\t\t& (TIsRoot extends true ? {\n\t\t\t\t\toffset?: number | Placeholder | undefined;\n\t\t\t\t}\n\t\t\t\t: {})\n\t\t: {});\n\nexport interface TableRelationalConfig {\n\ttsName: string;\n\tdbName: string;\n\tcolumns: Record<string, Column>;\n\trelations: Record<string, Relation>;\n\tprimaryKey: AnyColumn[];\n\tschema?: string;\n}\n\nexport type TablesRelationalConfig = Record<string, TableRelationalConfig>;\n\nexport interface RelationalSchemaConfig<\n\tTSchema extends TablesRelationalConfig,\n> {\n\tfullSchema: Record<string, unknown>;\n\tschema: TSchema;\n\ttableNamesMap: Record<string, string>;\n}\n\nexport type ExtractTablesWithRelations<\n\tTSchema extends Record<string, unknown>,\n> = {\n\t[\n\t\tK in keyof TSchema as TSchema[K] extends Table ? K\n\t\t\t: never\n\t]: TSchema[K] extends Table ? {\n\t\t\ttsName: K & string;\n\t\t\tdbName: TSchema[K]['_']['name'];\n\t\t\tcolumns: TSchema[K]['_']['columns'];\n\t\t\trelations: ExtractTableRelationsFromSchema<\n\t\t\t\tTSchema,\n\t\t\t\tTSchema[K]['_']['name']\n\t\t\t>;\n\t\t\tprimaryKey: AnyColumn[];\n\t\t}\n\t\t: never;\n};\n\nexport type ReturnTypeOrValue<T> = T extends (...args: any[]) => infer R ? R\n\t: T;\n\nexport type BuildRelationResult<\n\tTSchema extends TablesRelationalConfig,\n\tTInclude,\n\tTRelations extends Record<string, Relation>,\n> = {\n\t[\n\t\tK in\n\t\t\t& NonUndefinedKeysOnly<TInclude>\n\t\t\t& keyof TRelations\n\t]: TRelations[K] extends infer TRel extends Relation ? BuildQueryResult<\n\t\t\tTSchema,\n\t\t\tFindTableByDBName<TSchema, TRel['referencedTableName']>,\n\t\t\tAssume<TInclude[K], true | Record<string, unknown>>\n\t\t> extends infer TResult ? TRel extends One ?\n\t\t\t\t\t| TResult\n\t\t\t\t\t| (Equal<TRel['isNullable'], false> extends true ? null : never)\n\t\t\t: TResult[]\n\t\t: never\n\t\t: never;\n};\n\nexport type NonUndefinedKeysOnly<T> =\n\t& ExtractObjectValues<\n\t\t{\n\t\t\t[K in keyof T as T[K] extends undefined ? never : K]: K;\n\t\t}\n\t>\n\t& keyof T;\n\nexport type BuildQueryResult<\n\tTSchema extends TablesRelationalConfig,\n\tTTableConfig extends TableRelationalConfig,\n\tTFullSelection extends true | Record<string, unknown>,\n> = Equal<TFullSelection, true> extends true ? InferModelFromColumns<TTableConfig['columns']>\n\t: TFullSelection extends Record<string, unknown> ? Simplify<\n\t\t\t& (TFullSelection['columns'] extends Record<string, unknown> ? InferModelFromColumns<\n\t\t\t\t\t{\n\t\t\t\t\t\t[\n\t\t\t\t\t\t\tK in Equal<\n\t\t\t\t\t\t\t\tExclude<\n\t\t\t\t\t\t\t\t\tTFullSelection['columns'][\n\t\t\t\t\t\t\t\t\t\t& keyof TFullSelection['columns']\n\t\t\t\t\t\t\t\t\t\t& keyof TTableConfig['columns']\n\t\t\t\t\t\t\t\t\t],\n\t\t\t\t\t\t\t\t\tundefined\n\t\t\t\t\t\t\t\t>,\n\t\t\t\t\t\t\t\tfalse\n\t\t\t\t\t\t\t> extends true ? Exclude<\n\t\t\t\t\t\t\t\t\tkeyof TTableConfig['columns'],\n\t\t\t\t\t\t\t\t\tNonUndefinedKeysOnly<TFullSelection['columns']>\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t:\n\t\t\t\t\t\t\t\t\t& {\n\t\t\t\t\t\t\t\t\t\t[K in keyof TFullSelection['columns']]: Equal<\n\t\t\t\t\t\t\t\t\t\t\tTFullSelection['columns'][K],\n\t\t\t\t\t\t\t\t\t\t\ttrue\n\t\t\t\t\t\t\t\t\t\t> extends true ? K\n\t\t\t\t\t\t\t\t\t\t\t: never;\n\t\t\t\t\t\t\t\t\t}[keyof TFullSelection['columns']]\n\t\t\t\t\t\t\t\t\t& keyof TTableConfig['columns']\n\t\t\t\t\t\t]: TTableConfig['columns'][K];\n\t\t\t\t\t}\n\t\t\t\t>\n\t\t\t\t: InferModelFromColumns<TTableConfig['columns']>)\n\t\t\t& (TFullSelection['extras'] extends\n\t\t\t\t| Record<string, unknown>\n\t\t\t\t| ((...args: any[]) => Record<string, unknown>) ? {\n\t\t\t\t\t[\n\t\t\t\t\t\tK in NonUndefinedKeysOnly<\n\t\t\t\t\t\t\tReturnTypeOrValue<TFullSelection['extras']>\n\t\t\t\t\t\t>\n\t\t\t\t\t]: Assume<\n\t\t\t\t\t\tReturnTypeOrValue<TFullSelection['extras']>[K],\n\t\t\t\t\t\tSQL.Aliased\n\t\t\t\t\t>['_']['type'];\n\t\t\t\t}\n\t\t\t\t: {})\n\t\t\t& (TFullSelection['with'] extends Record<string, unknown> ? BuildRelationResult<\n\t\t\t\t\tTSchema,\n\t\t\t\t\tTFullSelection['with'],\n\t\t\t\t\tTTableConfig['relations']\n\t\t\t\t>\n\t\t\t\t: {})\n\t\t>\n\t: never;\n\nexport interface RelationConfig<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends AnyColumn<{ tableName: TTableName }>[],\n> {\n\trelationName?: string;\n\tfields: TColumns;\n\treferences: ColumnsWithTable<TTableName, TForeignTableName, TColumns>;\n}\n\nexport function extractTablesRelationalConfig<\n\tTTables extends TablesRelationalConfig,\n>(\n\tschema: Record<string, unknown>,\n\tconfigHelpers: (table: Table) => any,\n): { tables: TTables; tableNamesMap: Record<string, string> } {\n\tif (\n\t\tObject.keys(schema).length === 1\n\t\t&& 'default' in schema\n\t\t&& !is(schema['default'], Table)\n\t) {\n\t\tschema = schema['default'] as Record<string, unknown>;\n\t}\n\n\t// table DB name -> schema table key\n\tconst tableNamesMap: Record<string, string> = {};\n\t// Table relations found before their tables - need to buffer them until we know the schema table key\n\tconst relationsBuffer: Record<\n\t\tstring,\n\t\t{ relations: Record<string, Relation>; primaryKey?: AnyColumn[] }\n\t> = {};\n\tconst tablesConfig: TablesRelationalConfig = {};\n\tfor (const [key, value] of Object.entries(schema)) {\n\t\tif (is(value, Table)) {\n\t\t\tconst dbName = getTableUniqueName(value);\n\t\t\tconst bufferedRelations = relationsBuffer[dbName];\n\t\t\ttableNamesMap[dbName] = key;\n\t\t\ttablesConfig[key] = {\n\t\t\t\ttsName: key,\n\t\t\t\tdbName: value[Table.Symbol.Name],\n\t\t\t\tschema: value[Table.Symbol.Schema],\n\t\t\t\tcolumns: value[Table.Symbol.Columns],\n\t\t\t\trelations: bufferedRelations?.relations ?? {},\n\t\t\t\tprimaryKey: bufferedRelations?.primaryKey ?? [],\n\t\t\t};\n\n\t\t\t// Fill in primary keys\n\t\t\tfor (\n\t\t\t\tconst column of Object.values(\n\t\t\t\t\t(value as Table)[Table.Symbol.Columns],\n\t\t\t\t)\n\t\t\t) {\n\t\t\t\tif (column.primary) {\n\t\t\t\t\ttablesConfig[key]!.primaryKey.push(column);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst extraConfig = value[Table.Symbol.ExtraConfigBuilder]?.((value as Table)[Table.Symbol.ExtraConfigColumns]);\n\t\t\tif (extraConfig) {\n\t\t\t\tfor (const configEntry of Object.values(extraConfig)) {\n\t\t\t\t\tif (is(configEntry, PrimaryKeyBuilder)) {\n\t\t\t\t\t\ttablesConfig[key]!.primaryKey.push(...configEntry.columns);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t} else if (is(value, Relations)) {\n\t\t\tconst dbName = getTableUniqueName(value.table);\n\t\t\tconst tableName = tableNamesMap[dbName];\n\t\t\tconst relations: Record<string, Relation> = value.config(\n\t\t\t\tconfigHelpers(value.table),\n\t\t\t);\n\t\t\tlet primaryKey: AnyColumn[] | undefined;\n\n\t\t\tfor (const [relationName, relation] of Object.entries(relations)) {\n\t\t\t\tif (tableName) {\n\t\t\t\t\tconst tableConfig = tablesConfig[tableName]!;\n\t\t\t\t\ttableConfig.relations[relationName] = relation;\n\t\t\t\t\tif (primaryKey) {\n\t\t\t\t\t\ttableConfig.primaryKey.push(...primaryKey);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tif (!(dbName in relationsBuffer)) {\n\t\t\t\t\t\trelationsBuffer[dbName] = {\n\t\t\t\t\t\t\trelations: {},\n\t\t\t\t\t\t\tprimaryKey,\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t\trelationsBuffer[dbName]!.relations[relationName] = relation;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn { tables: tablesConfig as TTables, tableNamesMap };\n}\n\nexport function relations<\n\tTTableName extends string,\n\tTRelations extends Record<string, Relation<any>>,\n>(\n\ttable: AnyTable<{ name: TTableName }>,\n\trelations: (helpers: TableRelationsHelpers<TTableName>) => TRelations,\n): Relations<TTableName, TRelations> {\n\treturn new Relations<TTableName, TRelations>(\n\t\ttable,\n\t\t(helpers: TableRelationsHelpers<TTableName>) =>\n\t\t\tObject.fromEntries(\n\t\t\t\tObject.entries(relations(helpers)).map(([key, value]) => [\n\t\t\t\t\tkey,\n\t\t\t\t\tvalue.withFieldName(key),\n\t\t\t\t]),\n\t\t\t) as TRelations,\n\t);\n}\n\nexport function createOne<TTableName extends string>(sourceTable: Table) {\n\treturn function one<\n\t\tTForeignTable extends Table,\n\t\tTColumns extends [\n\t\t\tAnyColumn<{ tableName: TTableName }>,\n\t\t\t...AnyColumn<{ tableName: TTableName }>[],\n\t\t],\n\t>(\n\t\ttable: TForeignTable,\n\t\tconfig?: RelationConfig<TTableName, TForeignTable['_']['name'], TColumns>,\n\t): One<\n\t\tTForeignTable['_']['name'],\n\t\tEqual<TColumns[number]['_']['notNull'], true>\n\t> {\n\t\treturn new One(\n\t\t\tsourceTable,\n\t\t\ttable,\n\t\t\tconfig,\n\t\t\t(config?.fields.reduce<boolean>((res, f) => res && f.notNull, true)\n\t\t\t\t?? false) as Equal<TColumns[number]['_']['notNull'], true>,\n\t\t);\n\t};\n}\n\nexport function createMany(sourceTable: Table) {\n\treturn function many<TForeignTable extends Table>(\n\t\treferencedTable: TForeignTable,\n\t\tconfig?: { relationName: string },\n\t): Many<TForeignTable['_']['name']> {\n\t\treturn new Many(sourceTable, referencedTable, config);\n\t};\n}\n\nexport interface NormalizedRelation {\n\tfields: AnyColumn[];\n\treferences: AnyColumn[];\n}\n\nexport function normalizeRelation(\n\tschema: TablesRelationalConfig,\n\ttableNamesMap: Record<string, string>,\n\trelation: Relation,\n): NormalizedRelation {\n\tif (is(relation, One) && relation.config) {\n\t\treturn {\n\t\t\tfields: relation.config.fields,\n\t\t\treferences: relation.config.references,\n\t\t};\n\t}\n\n\tconst referencedTableTsName = tableNamesMap[getTableUniqueName(relation.referencedTable)];\n\tif (!referencedTableTsName) {\n\t\tthrow new Error(\n\t\t\t`Table \"${relation.referencedTable[Table.Symbol.Name]}\" not found in schema`,\n\t\t);\n\t}\n\n\tconst referencedTableConfig = schema[referencedTableTsName];\n\tif (!referencedTableConfig) {\n\t\tthrow new Error(`Table \"${referencedTableTsName}\" not found in schema`);\n\t}\n\n\tconst sourceTable = relation.sourceTable;\n\tconst sourceTableTsName = tableNamesMap[getTableUniqueName(sourceTable)];\n\tif (!sourceTableTsName) {\n\t\tthrow new Error(\n\t\t\t`Table \"${sourceTable[Table.Symbol.Name]}\" not found in schema`,\n\t\t);\n\t}\n\n\tconst reverseRelations: Relation[] = [];\n\tfor (\n\t\tconst referencedTableRelation of Object.values(\n\t\t\treferencedTableConfig.relations,\n\t\t)\n\t) {\n\t\tif (\n\t\t\t(relation.relationName\n\t\t\t\t&& relation !== referencedTableRelation\n\t\t\t\t&& referencedTableRelation.relationName === relation.relationName)\n\t\t\t|| (!relation.relationName\n\t\t\t\t&& referencedTableRelation.referencedTable === relation.sourceTable)\n\t\t) {\n\t\t\treverseRelations.push(referencedTableRelation);\n\t\t}\n\t}\n\n\tif (reverseRelations.length > 1) {\n\t\tthrow relation.relationName\n\t\t\t? new Error(\n\t\t\t\t`There are multiple relations with name \"${relation.relationName}\" in table \"${referencedTableTsName}\"`,\n\t\t\t)\n\t\t\t: new Error(\n\t\t\t\t`There are multiple relations between \"${referencedTableTsName}\" and \"${\n\t\t\t\t\trelation.sourceTable[Table.Symbol.Name]\n\t\t\t\t}\". Please specify relation name`,\n\t\t\t);\n\t}\n\n\tif (\n\t\treverseRelations[0]\n\t\t&& is(reverseRelations[0], One)\n\t\t&& reverseRelations[0].config\n\t) {\n\t\treturn {\n\t\t\tfields: reverseRelations[0].config.references,\n\t\t\treferences: reverseRelations[0].config.fields,\n\t\t};\n\t}\n\n\tthrow new Error(\n\t\t`There is not enough information to infer relation \"${sourceTableTsName}.${relation.fieldName}\"`,\n\t);\n}\n\nexport function createTableRelationsHelpers<TTableName extends string>(\n\tsourceTable: AnyTable<{ name: TTableName }>,\n) {\n\treturn {\n\t\tone: createOne<TTableName>(sourceTable),\n\t\tmany: createMany(sourceTable),\n\t};\n}\n\nexport type TableRelationsHelpers<TTableName extends string> = ReturnType<\n\ttypeof createTableRelationsHelpers<TTableName>\n>;\n\nexport interface BuildRelationalQueryResult<\n\tTTable extends Table = Table,\n\tTColumn extends Column = Column,\n> {\n\ttableTsKey: string;\n\tselection: {\n\t\tdbKey: string;\n\t\ttsKey: string;\n\t\tfield: TColumn | SQL | SQL.Aliased;\n\t\trelationTableTsKey: string | undefined;\n\t\tisJson: boolean;\n\t\tisExtra?: boolean;\n\t\tselection: BuildRelationalQueryResult<TTable>['selection'];\n\t}[];\n\tsql: TTable | SQL;\n}\n\nexport function mapRelationalRow(\n\ttablesConfig: TablesRelationalConfig,\n\ttableConfig: TableRelationalConfig,\n\trow: unknown[],\n\tbuildQueryResultSelection: BuildRelationalQueryResult['selection'],\n\tmapColumnValue: (value: unknown) => unknown = (value) => value,\n): Record<string, unknown> {\n\tconst result: Record<string, unknown> = {};\n\n\tfor (\n\t\tconst [\n\t\t\tselectionItemIndex,\n\t\t\tselectionItem,\n\t\t] of buildQueryResultSelection.entries()\n\t) {\n\t\tif (selectionItem.isJson) {\n\t\t\tconst relation = tableConfig.relations[selectionItem.tsKey]!;\n\t\t\tconst rawSubRows = row[selectionItemIndex] as\n\t\t\t\t| unknown[]\n\t\t\t\t| null\n\t\t\t\t| [null]\n\t\t\t\t| string;\n\t\t\tconst subRows = typeof rawSubRows === 'string'\n\t\t\t\t? (JSON.parse(rawSubRows) as unknown[])\n\t\t\t\t: rawSubRows;\n\t\t\tresult[selectionItem.tsKey] = is(relation, One)\n\t\t\t\t? subRows\n\t\t\t\t\t&& mapRelationalRow(\n\t\t\t\t\t\ttablesConfig,\n\t\t\t\t\t\ttablesConfig[selectionItem.relationTableTsKey!]!,\n\t\t\t\t\t\tsubRows,\n\t\t\t\t\t\tselectionItem.selection,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t)\n\t\t\t\t: (subRows as unknown[][]).map((subRow) =>\n\t\t\t\t\tmapRelationalRow(\n\t\t\t\t\t\ttablesConfig,\n\t\t\t\t\t\ttablesConfig[selectionItem.relationTableTsKey!]!,\n\t\t\t\t\t\tsubRow,\n\t\t\t\t\t\tselectionItem.selection,\n\t\t\t\t\t\tmapColumnValue,\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t} else {\n\t\t\tconst value = mapColumnValue(row[selectionItemIndex]);\n\t\t\tconst field = selectionItem.field!;\n\t\t\tlet decoder;\n\t\t\tif (is(field, Column)) {\n\t\t\t\tdecoder = field;\n\t\t\t} else if (is(field, SQL)) {\n\t\t\t\tdecoder = field.decoder;\n\t\t\t} else {\n\t\t\t\tdecoder = field.sql.decoder;\n\t\t\t}\n\t\t\tresult[selectionItem.tsKey] = value === null ? null : decoder.mapFromDriverValue(value);\n\t\t}\n\t}\n\n\treturn result;\n}\n","import type { AnyColumn } from './column.ts';\nimport { Column } from './column.ts';\nimport { entityKind, is } from './entity.ts';\nimport type { Relation } from './relations.ts';\nimport type { View } from './sql/sql.ts';\nimport { SQL, sql } from './sql/sql.ts';\nimport { Table } from './table.ts';\nimport { ViewBaseConfig } from './view-common.ts';\n\nexport class ColumnAliasProxyHandler<TColumn extends Column> implements ProxyHandler<TColumn> {\n\tstatic readonly [entityKind]: string = 'ColumnAliasProxyHandler';\n\n\tconstructor(private table: Table | View) {}\n\n\tget(columnObj: TColumn, prop: string | symbol): any {\n\t\tif (prop === 'table') {\n\t\t\treturn this.table;\n\t\t}\n\n\t\treturn columnObj[prop as keyof TColumn];\n\t}\n}\n\nexport class TableAliasProxyHandler<T extends Table | View> implements ProxyHandler<T> {\n\tstatic readonly [entityKind]: string = 'TableAliasProxyHandler';\n\n\tconstructor(private alias: string, private replaceOriginalName: boolean) {}\n\n\tget(target: T, prop: string | symbol): any {\n\t\tif (prop === Table.Symbol.IsAlias) {\n\t\t\treturn true;\n\t\t}\n\n\t\tif (prop === Table.Symbol.Name) {\n\t\t\treturn this.alias;\n\t\t}\n\n\t\tif (this.replaceOriginalName && prop === Table.Symbol.OriginalName) {\n\t\t\treturn this.alias;\n\t\t}\n\n\t\tif (prop === ViewBaseConfig) {\n\t\t\treturn {\n\t\t\t\t...target[ViewBaseConfig as keyof typeof target],\n\t\t\t\tname: this.alias,\n\t\t\t\tisAlias: true,\n\t\t\t};\n\t\t}\n\n\t\tif (prop === Table.Symbol.Columns) {\n\t\t\tconst columns = (target as Table)[Table.Symbol.Columns];\n\t\t\tif (!columns) {\n\t\t\t\treturn columns;\n\t\t\t}\n\n\t\t\tconst proxiedColumns: { [key: string]: any } = {};\n\n\t\t\tObject.keys(columns).map((key) => {\n\t\t\t\tproxiedColumns[key] = new Proxy(\n\t\t\t\t\tcolumns[key]!,\n\t\t\t\t\tnew ColumnAliasProxyHandler(new Proxy(target, this)),\n\t\t\t\t);\n\t\t\t});\n\n\t\t\treturn proxiedColumns;\n\t\t}\n\n\t\tconst value = target[prop as keyof typeof target];\n\t\tif (is(value, Column)) {\n\t\t\treturn new Proxy(value as AnyColumn, new ColumnAliasProxyHandler(new Proxy(target, this)));\n\t\t}\n\n\t\treturn value;\n\t}\n}\n\nexport class RelationTableAliasProxyHandler<T extends Relation> implements ProxyHandler<T> {\n\tstatic readonly [entityKind]: string = 'RelationTableAliasProxyHandler';\n\n\tconstructor(private alias: string) {}\n\n\tget(target: T, prop: string | symbol): any {\n\t\tif (prop === 'sourceTable') {\n\t\t\treturn aliasedTable(target.sourceTable, this.alias);\n\t\t}\n\n\t\treturn target[prop as keyof typeof target];\n\t}\n}\n\nexport function aliasedTable<T extends Table | View>(\n\ttable: T,\n\ttableAlias: string,\n): T {\n\treturn new Proxy(table, new TableAliasProxyHandler(tableAlias, false)) as any;\n}\n\nexport function aliasedRelation<T extends Relation>(relation: T, tableAlias: string): T {\n\treturn new Proxy(relation, new RelationTableAliasProxyHandler(tableAlias));\n}\n\nexport function aliasedTableColumn<T extends AnyColumn>(column: T, tableAlias: string): T {\n\treturn new Proxy(\n\t\tcolumn,\n\t\tnew ColumnAliasProxyHandler(new Proxy(column.table, new TableAliasProxyHandler(tableAlias, false))),\n\t);\n}\n\nexport function mapColumnsInAliasedSQLToAlias(query: SQL.Aliased, alias: string): SQL.Aliased {\n\treturn new SQL.Aliased(mapColumnsInSQLToAlias(query.sql, alias), query.fieldAlias);\n}\n\nexport function mapColumnsInSQLToAlias(query: SQL, alias: string): SQL {\n\treturn sql.join(query.queryChunks.map((c) => {\n\t\tif (is(c, Column)) {\n\t\t\treturn aliasedTableColumn(c, alias);\n\t\t}\n\t\tif (is(c, SQL)) {\n\t\t\treturn mapColumnsInSQLToAlias(c, alias);\n\t\t}\n\t\tif (is(c, SQL.Aliased)) {\n\t\t\treturn mapColumnsInAliasedSQLToAlias(c, alias);\n\t\t}\n\t\treturn c;\n\t}));\n}\n","import { ColumnAliasProxyHandler, TableAliasProxyHandler } from './alias.ts';\nimport { Column } from './column.ts';\nimport { entityKind, is } from './entity.ts';\nimport { SQL, View } from './sql/sql.ts';\nimport { Subquery } from './subquery.ts';\nimport { ViewBaseConfig } from './view-common.ts';\n\nexport class SelectionProxyHandler<T extends Subquery | Record<string, unknown> | View>\n\timplements ProxyHandler<Subquery | Record<string, unknown> | View>\n{\n\tstatic readonly [entityKind]: string = 'SelectionProxyHandler';\n\n\tprivate config: {\n\t\t/**\n\t\t * Table alias for the columns\n\t\t */\n\t\talias?: string;\n\t\t/**\n\t\t * What to do when a field is an instance of `SQL.Aliased` and it's not a selection field (from a subquery)\n\t\t *\n\t\t * `sql` - return the underlying SQL expression\n\t\t *\n\t\t * `alias` - return the field alias\n\t\t */\n\t\tsqlAliasedBehavior: 'sql' | 'alias';\n\t\t/**\n\t\t * What to do when a field is an instance of `SQL` and it doesn't have an alias declared\n\t\t *\n\t\t * `sql` - return the underlying SQL expression\n\t\t *\n\t\t * `error` - return a DrizzleTypeError on type level and throw an error on runtime\n\t\t */\n\t\tsqlBehavior: 'sql' | 'error';\n\n\t\t/**\n\t\t * Whether to replace the original name of the column with the alias\n\t\t * Should be set to `true` for views creation\n\t\t * @default false\n\t\t */\n\t\treplaceOriginalName?: boolean;\n\t};\n\n\tconstructor(config: SelectionProxyHandler<T>['config']) {\n\t\tthis.config = { ...config };\n\t}\n\n\tget(subquery: T, prop: string | symbol): any {\n\t\tif (prop === '_') {\n\t\t\treturn {\n\t\t\t\t...subquery['_' as keyof typeof subquery],\n\t\t\t\tselectedFields: new Proxy(\n\t\t\t\t\t(subquery as Subquery)._.selectedFields,\n\t\t\t\t\tthis as ProxyHandler<Record<string, unknown>>,\n\t\t\t\t),\n\t\t\t};\n\t\t}\n\n\t\tif (prop === ViewBaseConfig) {\n\t\t\treturn {\n\t\t\t\t...subquery[ViewBaseConfig as keyof typeof subquery],\n\t\t\t\tselectedFields: new Proxy(\n\t\t\t\t\t(subquery as View)[ViewBaseConfig].selectedFields,\n\t\t\t\t\tthis as ProxyHandler<Record<string, unknown>>,\n\t\t\t\t),\n\t\t\t};\n\t\t}\n\n\t\tif (typeof prop === 'symbol') {\n\t\t\treturn subquery[prop as keyof typeof subquery];\n\t\t}\n\n\t\tconst columns = is(subquery, Subquery)\n\t\t\t? subquery._.selectedFields\n\t\t\t: is(subquery, View)\n\t\t\t? subquery[ViewBaseConfig].selectedFields\n\t\t\t: subquery;\n\t\tconst value: unknown = columns[prop as keyof typeof columns];\n\n\t\tif (is(value, SQL.Aliased)) {\n\t\t\t// Never return the underlying SQL expression for a field previously selected in a subquery\n\t\t\tif (this.config.sqlAliasedBehavior === 'sql' && !value.isSelectionField) {\n\t\t\t\treturn value.sql;\n\t\t\t}\n\n\t\t\tconst newValue = value.clone();\n\t\t\tnewValue.isSelectionField = true;\n\t\t\treturn newValue;\n\t\t}\n\n\t\tif (is(value, SQL)) {\n\t\t\tif (this.config.sqlBehavior === 'sql') {\n\t\t\t\treturn value;\n\t\t\t}\n\n\t\t\tthrow new Error(\n\t\t\t\t`You tried to reference \"${prop}\" field from a subquery, which is a raw SQL field, but it doesn't have an alias declared. Please add an alias to the field using \".as('alias')\" method.`,\n\t\t\t);\n\t\t}\n\n\t\tif (is(value, Column)) {\n\t\t\tif (this.config.alias) {\n\t\t\t\treturn new Proxy(\n\t\t\t\t\tvalue,\n\t\t\t\t\tnew ColumnAliasProxyHandler(\n\t\t\t\t\t\tnew Proxy(\n\t\t\t\t\t\t\tvalue.table,\n\t\t\t\t\t\t\tnew TableAliasProxyHandler(this.config.alias, this.config.replaceOriginalName ?? false),\n\t\t\t\t\t\t),\n\t\t\t\t\t),\n\t\t\t\t);\n\t\t\t}\n\t\t\treturn value;\n\t\t}\n\n\t\tif (typeof value !== 'object' || value === null) {\n\t\t\treturn value;\n\t\t}\n\n\t\treturn new Proxy(value, new SelectionProxyHandler(this.config));\n\t}\n}\n","import { entityKind } from '~/entity.ts';\n\nexport abstract class QueryPromise<T> implements Promise<T> {\n\tstatic readonly [entityKind]: string = 'QueryPromise';\n\n\t[Symbol.toStringTag] = 'QueryPromise';\n\n\tcatch<TResult = never>(\n\t\tonRejected?: ((reason: any) => TResult | PromiseLike<TResult>) | null | undefined,\n\t): Promise<T | TResult> {\n\t\treturn this.then(undefined, onRejected);\n\t}\n\n\tfinally(onFinally?: (() => void) | null | undefined): Promise<T> {\n\t\treturn this.then(\n\t\t\t(value) => {\n\t\t\t\tonFinally?.();\n\t\t\t\treturn value;\n\t\t\t},\n\t\t\t(reason) => {\n\t\t\t\tonFinally?.();\n\t\t\t\tthrow reason;\n\t\t\t},\n\t\t);\n\t}\n\n\tthen<TResult1 = T, TResult2 = never>(\n\t\tonFulfilled?: ((value: T) => TResult1 | PromiseLike<TResult1>) | undefined | null,\n\t\tonRejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | undefined | null,\n\t): Promise<TResult1 | TResult2> {\n\t\treturn this.execute().then(onFulfilled, onRejected);\n\t}\n\n\tabstract execute(): Promise<T>;\n}\n","import { entityKind } from '~/entity.ts';\nimport { TableName } from '~/table.utils.ts';\nimport type { AnySQLiteColumn, SQLiteColumn } from './columns/index.ts';\nimport type { SQLiteTable } from './table.ts';\n\nexport type UpdateDeleteAction = 'cascade' | 'restrict' | 'no action' | 'set null' | 'set default';\n\nexport type Reference = () => {\n\treadonly name?: string;\n\treadonly columns: SQLiteColumn[];\n\treadonly foreignTable: SQLiteTable;\n\treadonly foreignColumns: SQLiteColumn[];\n};\n\nexport class ForeignKeyBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteForeignKeyBuilder';\n\n\tdeclare _: {\n\t\tbrand: 'SQLiteForeignKeyBuilder';\n\t\tforeignTableName: 'TForeignTableName';\n\t};\n\n\t/** @internal */\n\treference: Reference;\n\n\t/** @internal */\n\t_onUpdate: UpdateDeleteAction | undefined;\n\n\t/** @internal */\n\t_onDelete: UpdateDeleteAction | undefined;\n\n\tconstructor(\n\t\tconfig: () => {\n\t\t\tname?: string;\n\t\t\tcolumns: SQLiteColumn[];\n\t\t\tforeignColumns: SQLiteColumn[];\n\t\t},\n\t\tactions?: {\n\t\t\tonUpdate?: UpdateDeleteAction;\n\t\t\tonDelete?: UpdateDeleteAction;\n\t\t} | undefined,\n\t) {\n\t\tthis.reference = () => {\n\t\t\tconst { name, columns, foreignColumns } = config();\n\t\t\treturn { name, columns, foreignTable: foreignColumns[0]!.table as SQLiteTable, foreignColumns };\n\t\t};\n\t\tif (actions) {\n\t\t\tthis._onUpdate = actions.onUpdate;\n\t\t\tthis._onDelete = actions.onDelete;\n\t\t}\n\t}\n\n\tonUpdate(action: UpdateDeleteAction): this {\n\t\tthis._onUpdate = action;\n\t\treturn this;\n\t}\n\n\tonDelete(action: UpdateDeleteAction): this {\n\t\tthis._onDelete = action;\n\t\treturn this;\n\t}\n\n\t/** @internal */\n\tbuild(table: SQLiteTable): ForeignKey {\n\t\treturn new ForeignKey(table, this);\n\t}\n}\n\nexport class ForeignKey {\n\tstatic readonly [entityKind]: string = 'SQLiteForeignKey';\n\n\treadonly reference: Reference;\n\treadonly onUpdate: UpdateDeleteAction | undefined;\n\treadonly onDelete: UpdateDeleteAction | undefined;\n\n\tconstructor(readonly table: SQLiteTable, builder: ForeignKeyBuilder) {\n\t\tthis.reference = builder.reference;\n\t\tthis.onUpdate = builder._onUpdate;\n\t\tthis.onDelete = builder._onDelete;\n\t}\n\n\tgetName(): string {\n\t\tconst { name, columns, foreignColumns } = this.reference();\n\t\tconst columnNames = columns.map((column) => column.name);\n\t\tconst foreignColumnNames = foreignColumns.map((column) => column.name);\n\t\tconst chunks = [\n\t\t\tthis.table[TableName],\n\t\t\t...columnNames,\n\t\t\tforeignColumns[0]!.table[TableName],\n\t\t\t...foreignColumnNames,\n\t\t];\n\t\treturn name ?? `${chunks.join('_')}_fk`;\n\t}\n}\n\ntype ColumnsWithTable<\n\tTTableName extends string,\n\tTColumns extends SQLiteColumn[],\n> = { [Key in keyof TColumns]: AnySQLiteColumn<{ tableName: TTableName }> };\n\n/**\n * @deprecated please use `foreignKey({ columns: [], foreignColumns: [] })` syntax without callback\n * @param config\n * @returns\n */\nexport function foreignKey<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends [AnySQLiteColumn<{ tableName: TTableName }>, ...AnySQLiteColumn<{ tableName: TTableName }>[]],\n>(\n\tconfig: () => {\n\t\tname?: string;\n\t\tcolumns: TColumns;\n\t\tforeignColumns: ColumnsWithTable<TForeignTableName, TColumns>;\n\t},\n): ForeignKeyBuilder;\nexport function foreignKey<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends [AnySQLiteColumn<{ tableName: TTableName }>, ...AnySQLiteColumn<{ tableName: TTableName }>[]],\n>(\n\tconfig: {\n\t\tname?: string;\n\t\tcolumns: TColumns;\n\t\tforeignColumns: ColumnsWithTable<TForeignTableName, TColumns>;\n\t},\n): ForeignKeyBuilder;\nexport function foreignKey(\n\tconfig: any,\n): ForeignKeyBuilder {\n\tfunction mappedConfig() {\n\t\tif (typeof config === 'function') {\n\t\t\tconst { name, columns, foreignColumns } = config();\n\t\t\treturn {\n\t\t\t\tname,\n\t\t\t\tcolumns,\n\t\t\t\tforeignColumns,\n\t\t\t};\n\t\t}\n\t\treturn config;\n\t}\n\n\treturn new ForeignKeyBuilder(mappedConfig);\n}\n","import { entityKind } from '~/entity.ts';\nimport { TableName } from '~/table.utils.ts';\nimport type { SQLiteColumn } from './columns/common.ts';\nimport type { SQLiteTable } from './table.ts';\n\nexport function uniqueKeyName(table: SQLiteTable, columns: string[]) {\n\treturn `${table[TableName]}_${columns.join('_')}_unique`;\n}\n\nexport function unique(name?: string): UniqueOnConstraintBuilder {\n\treturn new UniqueOnConstraintBuilder(name);\n}\n\nexport class UniqueConstraintBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteUniqueConstraintBuilder';\n\n\t/** @internal */\n\tcolumns: SQLiteColumn[];\n\n\tconstructor(\n\t\tcolumns: SQLiteColumn[],\n\t\tprivate name?: string,\n\t) {\n\t\tthis.columns = columns;\n\t}\n\n\t/** @internal */\n\tbuild(table: SQLiteTable): UniqueConstraint {\n\t\treturn new UniqueConstraint(table, this.columns, this.name);\n\t}\n}\n\nexport class UniqueOnConstraintBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteUniqueOnConstraintBuilder';\n\n\t/** @internal */\n\tname?: string;\n\n\tconstructor(\n\t\tname?: string,\n\t) {\n\t\tthis.name = name;\n\t}\n\n\ton(...columns: [SQLiteColumn, ...SQLiteColumn[]]) {\n\t\treturn new UniqueConstraintBuilder(columns, this.name);\n\t}\n}\n\nexport class UniqueConstraint {\n\tstatic readonly [entityKind]: string = 'SQLiteUniqueConstraint';\n\n\treadonly columns: SQLiteColumn[];\n\treadonly name?: string;\n\n\tconstructor(readonly table: SQLiteTable, columns: SQLiteColumn[], name?: string) {\n\t\tthis.columns = columns;\n\t\tthis.name = name ?? uniqueKeyName(this.table, this.columns.map((column) => column.name));\n\t}\n\n\tgetName() {\n\t\treturn this.name;\n\t}\n}\n","import type {\n\tColumnBuilderBase,\n\tColumnBuilderBaseConfig,\n\tColumnBuilderExtraConfig,\n\tColumnBuilderRuntimeConfig,\n\tColumnDataType,\n\tHasGenerated,\n\tMakeColumnConfig,\n} from '~/column-builder.ts';\nimport { ColumnBuilder } from '~/column-builder.ts';\nimport { Column } from '~/column.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SQL } from '~/sql/sql.ts';\nimport type { ForeignKey, UpdateDeleteAction } from '~/sqlite-core/foreign-keys.ts';\nimport { ForeignKeyBuilder } from '~/sqlite-core/foreign-keys.ts';\nimport type { AnySQLiteTable, SQLiteTable } from '~/sqlite-core/table.ts';\nimport type { Update } from '~/utils.ts';\nimport { uniqueKeyName } from '../unique-constraint.ts';\n\nexport interface ReferenceConfig {\n\tref: () => SQLiteColumn;\n\tactions: {\n\t\tonUpdate?: UpdateDeleteAction;\n\t\tonDelete?: UpdateDeleteAction;\n\t};\n}\n\nexport interface SQLiteColumnBuilderBase<\n\tT extends ColumnBuilderBaseConfig<ColumnDataType, string> = ColumnBuilderBaseConfig<ColumnDataType, string>,\n\tTTypeConfig extends object = object,\n> extends ColumnBuilderBase<T, TTypeConfig & { dialect: 'sqlite' }> {}\n\nexport interface SQLiteGeneratedColumnConfig {\n\tmode?: 'virtual' | 'stored';\n}\n\nexport abstract class SQLiteColumnBuilder<\n\tT extends ColumnBuilderBaseConfig<ColumnDataType, string> = ColumnBuilderBaseConfig<ColumnDataType, string>,\n\tTRuntimeConfig extends object = object,\n\tTTypeConfig extends object = object,\n\tTExtraConfig extends ColumnBuilderExtraConfig = object,\n> extends ColumnBuilder<T, TRuntimeConfig, TTypeConfig & { dialect: 'sqlite' }, TExtraConfig>\n\timplements SQLiteColumnBuilderBase<T, TTypeConfig>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteColumnBuilder';\n\n\tprivate foreignKeyConfigs: ReferenceConfig[] = [];\n\n\treferences(\n\t\tref: ReferenceConfig['ref'],\n\t\tactions: ReferenceConfig['actions'] = {},\n\t): this {\n\t\tthis.foreignKeyConfigs.push({ ref, actions });\n\t\treturn this;\n\t}\n\n\tunique(\n\t\tname?: string,\n\t): this {\n\t\tthis.config.isUnique = true;\n\t\tthis.config.uniqueName = name;\n\t\treturn this;\n\t}\n\n\tgeneratedAlwaysAs(as: SQL | T['data'] | (() => SQL), config?: SQLiteGeneratedColumnConfig): HasGenerated<this, {\n\t\ttype: 'always';\n\t}> {\n\t\tthis.config.generated = {\n\t\t\tas,\n\t\t\ttype: 'always',\n\t\t\tmode: config?.mode ?? 'virtual',\n\t\t};\n\t\treturn this as any;\n\t}\n\n\t/** @internal */\n\tbuildForeignKeys(column: SQLiteColumn, table: SQLiteTable): ForeignKey[] {\n\t\treturn this.foreignKeyConfigs.map(({ ref, actions }) => {\n\t\t\treturn ((ref, actions) => {\n\t\t\t\tconst builder = new ForeignKeyBuilder(() => {\n\t\t\t\t\tconst foreignColumn = ref();\n\t\t\t\t\treturn { columns: [column], foreignColumns: [foreignColumn] };\n\t\t\t\t});\n\t\t\t\tif (actions.onUpdate) {\n\t\t\t\t\tbuilder.onUpdate(actions.onUpdate);\n\t\t\t\t}\n\t\t\t\tif (actions.onDelete) {\n\t\t\t\t\tbuilder.onDelete(actions.onDelete);\n\t\t\t\t}\n\t\t\t\treturn builder.build(table);\n\t\t\t})(ref, actions);\n\t\t});\n\t}\n\n\t/** @internal */\n\tabstract build<TTableName extends string>(\n\t\ttable: AnySQLiteTable<{ name: TTableName }>,\n\t): SQLiteColumn<MakeColumnConfig<T, TTableName>>;\n}\n\n// To understand how to use `SQLiteColumn` and `AnySQLiteColumn`, see `Column` and `AnyColumn` documentation.\nexport abstract class SQLiteColumn<\n\tT extends ColumnBaseConfig<ColumnDataType, string> = ColumnBaseConfig<ColumnDataType, string>,\n\tTRuntimeConfig extends object = {},\n\tTTypeConfig extends object = {},\n> extends Column<T, TRuntimeConfig, TTypeConfig & { dialect: 'sqlite' }> {\n\tstatic override readonly [entityKind]: string = 'SQLiteColumn';\n\n\tconstructor(\n\t\toverride readonly table: SQLiteTable,\n\t\tconfig: ColumnBuilderRuntimeConfig<T['data'], TRuntimeConfig>,\n\t) {\n\t\tif (!config.uniqueName) {\n\t\t\tconfig.uniqueName = uniqueKeyName(table, [config.name]);\n\t\t}\n\t\tsuper(table, config);\n\t}\n}\n\nexport type AnySQLiteColumn<TPartial extends Partial<ColumnBaseConfig<ColumnDataType, string>> = {}> = SQLiteColumn<\n\tRequired<Update<ColumnBaseConfig<ColumnDataType, string>, TPartial>>\n>;\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnySQLiteTable } from '~/sqlite-core/table.ts';\nimport { type Equal, getColumnNameAndConfig, textDecoder } from '~/utils.ts';\nimport { SQLiteColumn, SQLiteColumnBuilder } from './common.ts';\n\ntype BlobMode = 'buffer' | 'json' | 'bigint';\n\nexport type SQLiteBigIntBuilderInitial<TName extends string> = SQLiteBigIntBuilder<{\n\tname: TName;\n\tdataType: 'bigint';\n\tcolumnType: 'SQLiteBigInt';\n\tdata: bigint;\n\tdriverParam: Buffer;\n\tenumValues: undefined;\n}>;\n\nexport class SQLiteBigIntBuilder<T extends ColumnBuilderBaseConfig<'bigint', 'SQLiteBigInt'>>\n\textends SQLiteColumnBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteBigIntBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'bigint', 'SQLiteBigInt');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnySQLiteTable<{ name: TTableName }>,\n\t): SQLiteBigInt<MakeColumnConfig<T, TTableName>> {\n\t\treturn new SQLiteBigInt<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any>);\n\t}\n}\n\nexport class SQLiteBigInt<T extends ColumnBaseConfig<'bigint', 'SQLiteBigInt'>> extends SQLiteColumn<T> {\n\tstatic override readonly [entityKind]: string = 'SQLiteBigInt';\n\n\tgetSQLType(): string {\n\t\treturn 'blob';\n\t}\n\n\toverride mapFromDriverValue(value: Buffer | Uint8Array | ArrayBuffer): bigint {\n\t\tif (typeof Buffer !== 'undefined' && Buffer.from) {\n\t\t\tconst buf = Buffer.isBuffer(value)\n\t\t\t\t? value\n\t\t\t\t// eslint-disable-next-line no-instanceof/no-instanceof\n\t\t\t\t: value instanceof ArrayBuffer\n\t\t\t\t? Buffer.from(value)\n\t\t\t\t: value.buffer\n\t\t\t\t? Buffer.from(value.buffer, value.byteOffset, value.byteLength)\n\t\t\t\t: Buffer.from(value);\n\t\t\treturn BigInt(buf.toString('utf8'));\n\t\t}\n\n\t\treturn BigInt(textDecoder!.decode(value));\n\t}\n\n\toverride mapToDriverValue(value: bigint): Buffer {\n\t\treturn Buffer.from(value.toString());\n\t}\n}\n\nexport type SQLiteBlobJsonBuilderInitial<TName extends string> = SQLiteBlobJsonBuilder<{\n\tname: TName;\n\tdataType: 'json';\n\tcolumnType: 'SQLiteBlobJson';\n\tdata: unknown;\n\tdriverParam: Buffer;\n\tenumValues: undefined;\n}>;\n\nexport class SQLiteBlobJsonBuilder<T extends ColumnBuilderBaseConfig<'json', 'SQLiteBlobJson'>>\n\textends SQLiteColumnBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteBlobJsonBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'json', 'SQLiteBlobJson');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnySQLiteTable<{ name: TTableName }>,\n\t): SQLiteBlobJson<MakeColumnConfig<T, TTableName>> {\n\t\treturn new SQLiteBlobJson<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any>,\n\t\t);\n\t}\n}\n\nexport class SQLiteBlobJson<T extends ColumnBaseConfig<'json', 'SQLiteBlobJson'>> extends SQLiteColumn<T> {\n\tstatic override readonly [entityKind]: string = 'SQLiteBlobJson';\n\n\tgetSQLType(): string {\n\t\treturn 'blob';\n\t}\n\n\toverride mapFromDriverValue(value: Buffer | Uint8Array | ArrayBuffer): T['data'] {\n\t\tif (typeof Buffer !== 'undefined' && Buffer.from) {\n\t\t\tconst buf = Buffer.isBuffer(value)\n\t\t\t\t? value\n\t\t\t\t// eslint-disable-next-line no-instanceof/no-instanceof\n\t\t\t\t: value instanceof ArrayBuffer\n\t\t\t\t? Buffer.from(value)\n\t\t\t\t: value.buffer\n\t\t\t\t? Buffer.from(value.buffer, value.byteOffset, value.byteLength)\n\t\t\t\t: Buffer.from(value);\n\t\t\treturn JSON.parse(buf.toString('utf8'));\n\t\t}\n\n\t\treturn JSON.parse(textDecoder!.decode(value));\n\t}\n\n\toverride mapToDriverValue(value: T['data']): Buffer {\n\t\treturn Buffer.from(JSON.stringify(value));\n\t}\n}\n\nexport type SQLiteBlobBufferBuilderInitial<TName extends string> = SQLiteBlobBufferBuilder<{\n\tname: TName;\n\tdataType: 'buffer';\n\tcolumnType: 'SQLiteBlobBuffer';\n\tdata: Buffer;\n\tdriverParam: Buffer;\n\tenumValues: undefined;\n}>;\n\nexport class SQLiteBlobBufferBuilder<T extends ColumnBuilderBaseConfig<'buffer', 'SQLiteBlobBuffer'>>\n\textends SQLiteColumnBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteBlobBufferBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'buffer', 'SQLiteBlobBuffer');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnySQLiteTable<{ name: TTableName }>,\n\t): SQLiteBlobBuffer<MakeColumnConfig<T, TTableName>> {\n\t\treturn new SQLiteBlobBuffer<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any>);\n\t}\n}\n\nexport class SQLiteBlobBuffer<T extends ColumnBaseConfig<'buffer', 'SQLiteBlobBuffer'>> extends SQLiteColumn<T> {\n\tstatic override readonly [entityKind]: string = 'SQLiteBlobBuffer';\n\n\toverride mapFromDriverValue(value: Buffer | Uint8Array | ArrayBuffer): T['data'] {\n\t\tif (Buffer.isBuffer(value)) {\n\t\t\treturn value;\n\t\t}\n\n\t\treturn Buffer.from(value as Uint8Array);\n\t}\n\n\tgetSQLType(): string {\n\t\treturn 'blob';\n\t}\n}\n\nexport interface BlobConfig<TMode extends BlobMode = BlobMode> {\n\tmode: TMode;\n}\n\n/**\n * It's recommended to use `text('...', { mode: 'json' })` instead of `blob` in JSON mode, because it supports JSON functions:\n * >All JSON functions currently throw an error if any of their arguments are BLOBs because BLOBs are reserved for a future enhancement in which BLOBs will store the binary encoding for JSON.\n *\n * https://www.sqlite.org/json1.html\n */\nexport function blob(): SQLiteBlobJsonBuilderInitial<''>;\nexport function blob<TMode extends BlobMode = BlobMode>(\n\tconfig?: BlobConfig<TMode>,\n): Equal<TMode, 'bigint'> extends true ? SQLiteBigIntBuilderInitial<''>\n\t: Equal<TMode, 'buffer'> extends true ? SQLiteBlobBufferBuilderInitial<''>\n\t: SQLiteBlobJsonBuilderInitial<''>;\nexport function blob<TName extends string, TMode extends BlobMode = BlobMode>(\n\tname: TName,\n\tconfig?: BlobConfig<TMode>,\n): Equal<TMode, 'bigint'> extends true ? SQLiteBigIntBuilderInitial<TName>\n\t: Equal<TMode, 'buffer'> extends true ? SQLiteBlobBufferBuilderInitial<TName>\n\t: SQLiteBlobJsonBuilderInitial<TName>;\nexport function blob(a?: string | BlobConfig, b?: BlobConfig) {\n\tconst { name, config } = getColumnNameAndConfig<BlobConfig | undefined>(a, b);\n\tif (config?.mode === 'json') {\n\t\treturn new SQLiteBlobJsonBuilder(name);\n\t}\n\tif (config?.mode === 'bigint') {\n\t\treturn new SQLiteBigIntBuilder(name);\n\t}\n\treturn new SQLiteBlobBufferBuilder(name);\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { SQL } from '~/sql/sql.ts';\nimport type { AnySQLiteTable } from '~/sqlite-core/table.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { SQLiteColumn, SQLiteColumnBuilder } from './common.ts';\n\nexport type ConvertCustomConfig<TName extends string, T extends Partial<CustomTypeValues>> =\n\t& {\n\t\tname: TName;\n\t\tdataType: 'custom';\n\t\tcolumnType: 'SQLiteCustomColumn';\n\t\tdata: T['data'];\n\t\tdriverParam: T['driverData'];\n\t\tenumValues: undefined;\n\t}\n\t& (T['notNull'] extends true ? { notNull: true } : {})\n\t& (T['default'] extends true ? { hasDefault: true } : {});\n\nexport interface SQLiteCustomColumnInnerConfig {\n\tcustomTypeValues: CustomTypeValues;\n}\n\nexport class SQLiteCustomColumnBuilder<T extends ColumnBuilderBaseConfig<'custom', 'SQLiteCustomColumn'>>\n\textends SQLiteColumnBuilder<\n\t\tT,\n\t\t{\n\t\t\tfieldConfig: CustomTypeValues['config'];\n\t\t\tcustomTypeParams: CustomTypeParams<any>;\n\t\t},\n\t\t{\n\t\t\tsqliteColumnBuilderBrand: 'SQLiteCustomColumnBuilderBrand';\n\t\t}\n\t>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteCustomColumnBuilder';\n\n\tconstructor(\n\t\tname: T['name'],\n\t\tfieldConfig: CustomTypeValues['config'],\n\t\tcustomTypeParams: CustomTypeParams<any>,\n\t) {\n\t\tsuper(name, 'custom', 'SQLiteCustomColumn');\n\t\tthis.config.fieldConfig = fieldConfig;\n\t\tthis.config.customTypeParams = customTypeParams;\n\t}\n\n\t/** @internal */\n\tbuild<TTableName extends string>(\n\t\ttable: AnySQLiteTable<{ name: TTableName }>,\n\t): SQLiteCustomColumn<MakeColumnConfig<T, TTableName>> {\n\t\treturn new SQLiteCustomColumn<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class SQLiteCustomColumn<T extends ColumnBaseConfig<'custom', 'SQLiteCustomColumn'>> extends SQLiteColumn<T> {\n\tstatic override readonly [entityKind]: string = 'SQLiteCustomColumn';\n\n\tprivate sqlName: string;\n\tprivate mapTo?: (value: T['data']) => T['driverParam'];\n\tprivate mapFrom?: (value: T['driverParam']) => T['data'];\n\n\tconstructor(\n\t\ttable: AnySQLiteTable<{ name: T['tableName'] }>,\n\t\tconfig: SQLiteCustomColumnBuilder<T>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.sqlName = config.customTypeParams.dataType(config.fieldConfig);\n\t\tthis.mapTo = config.customTypeParams.toDriver;\n\t\tthis.mapFrom = config.customTypeParams.fromDriver;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.sqlName;\n\t}\n\n\toverride mapFromDriverValue(value: T['driverParam']): T['data'] {\n\t\treturn typeof this.mapFrom === 'function' ? this.mapFrom(value) : value as T['data'];\n\t}\n\n\toverride mapToDriverValue(value: T['data']): T['driverParam'] {\n\t\treturn typeof this.mapTo === 'function' ? this.mapTo(value) : value as T['data'];\n\t}\n}\n\nexport type CustomTypeValues = {\n\t/**\n\t * Required type for custom column, that will infer proper type model\n\t *\n\t * Examples:\n\t *\n\t * If you want your column to be `string` type after selecting/or on inserting - use `data: string`. Like `text`, `varchar`\n\t *\n\t * If you want your column to be `number` type after selecting/or on inserting - use `data: number`. Like `integer`\n\t */\n\tdata: unknown;\n\n\t/**\n\t * Type helper, that represents what type database driver is accepting for specific database data type\n\t */\n\tdriverData?: unknown;\n\n\t/**\n\t * What config type should be used for {@link CustomTypeParams} `dataType` generation\n\t */\n\tconfig?: Record<string, any>;\n\n\t/**\n\t * Whether the config argument should be required or not\n\t * @default false\n\t */\n\tconfigRequired?: boolean;\n\n\t/**\n\t * If your custom data type should be notNull by default you can use `notNull: true`\n\t *\n\t * @example\n\t * const customSerial = customType<{ data: number, notNull: true, default: true }>({\n\t * \t dataType() {\n\t * \t return 'serial';\n\t * },\n\t * });\n\t */\n\tnotNull?: boolean;\n\n\t/**\n\t * If your custom data type has default you can use `default: true`\n\t *\n\t * @example\n\t * const customSerial = customType<{ data: number, notNull: true, default: true }>({\n\t * \t dataType() {\n\t * \t return 'serial';\n\t * },\n\t * });\n\t */\n\tdefault?: boolean;\n};\n\nexport interface CustomTypeParams<T extends CustomTypeValues> {\n\t/**\n\t * Database data type string representation, that is used for migrations\n\t * @example\n\t * ```\n\t * `jsonb`, `text`\n\t * ```\n\t *\n\t * If database data type needs additional params you can use them from `config` param\n\t * @example\n\t * ```\n\t * `varchar(256)`, `numeric(2,3)`\n\t * ```\n\t *\n\t * To make `config` be of specific type please use config generic in {@link CustomTypeValues}\n\t *\n\t * @example\n\t * Usage example\n\t * ```\n\t * dataType() {\n\t * return 'boolean';\n\t * },\n\t * ```\n\t * Or\n\t * ```\n\t * dataType(config) {\n\t * \t return typeof config.length !== 'undefined' ? `varchar(${config.length})` : `varchar`;\n\t * \t }\n\t * ```\n\t */\n\tdataType: (config: T['config'] | (Equal<T['configRequired'], true> extends true ? never : undefined)) => string;\n\n\t/**\n\t * Optional mapping function, between user input and driver\n\t * @example\n\t * For example, when using jsonb we need to map JS/TS object to string before writing to database\n\t * ```\n\t * toDriver(value: TData): string {\n\t * \t return JSON.stringify(value);\n\t * }\n\t * ```\n\t */\n\ttoDriver?: (value: T['data']) => T['driverData'] | SQL;\n\n\t/**\n\t * Optional mapping function, that is responsible for data mapping from database to JS/TS code\n\t * @example\n\t * For example, when using timestamp we need to map string Date representation to JS Date\n\t * ```\n\t * fromDriver(value: string): Date {\n\t * \treturn new Date(value);\n\t * },\n\t * ```\n\t */\n\tfromDriver?: (value: T['driverData']) => T['data'];\n}\n\n/**\n * Custom sqlite database data type generator\n */\nexport function customType<T extends CustomTypeValues = CustomTypeValues>(\n\tcustomTypeParams: CustomTypeParams<T>,\n): Equal<T['configRequired'], true> extends true ? {\n\t\t<TConfig extends Record<string, any> & T['config']>(\n\t\t\tfieldConfig: TConfig,\n\t\t): SQLiteCustomColumnBuilder<ConvertCustomConfig<'', T>>;\n\t\t<TName extends string>(\n\t\t\tdbName: TName,\n\t\t\tfieldConfig: T['config'],\n\t\t): SQLiteCustomColumnBuilder<ConvertCustomConfig<TName, T>>;\n\t}\n\t: {\n\t\t(): SQLiteCustomColumnBuilder<ConvertCustomConfig<'', T>>;\n\t\t<TConfig extends Record<string, any> & T['config']>(\n\t\t\tfieldConfig?: TConfig,\n\t\t): SQLiteCustomColumnBuilder<ConvertCustomConfig<'', T>>;\n\t\t<TName extends string>(\n\t\t\tdbName: TName,\n\t\t\tfieldConfig?: T['config'],\n\t\t): SQLiteCustomColumnBuilder<ConvertCustomConfig<TName, T>>;\n\t}\n{\n\treturn <TName extends string>(\n\t\ta?: TName | T['config'],\n\t\tb?: T['config'],\n\t): SQLiteCustomColumnBuilder<ConvertCustomConfig<TName, T>> => {\n\t\tconst { name, config } = getColumnNameAndConfig<T['config']>(a, b);\n\t\treturn new SQLiteCustomColumnBuilder(\n\t\t\tname as ConvertCustomConfig<TName, T>['name'],\n\t\t\tconfig,\n\t\t\tcustomTypeParams,\n\t\t);\n\t};\n}\n","import type {\n\tColumnBuilderBaseConfig,\n\tColumnBuilderRuntimeConfig,\n\tColumnDataType,\n\tHasDefault,\n\tIsPrimaryKey,\n\tMakeColumnConfig,\n\tNotNull,\n} from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport { sql } from '~/sql/sql.ts';\nimport type { OnConflict } from '~/sqlite-core/utils.ts';\nimport { type Equal, getColumnNameAndConfig, type Or } from '~/utils.ts';\nimport type { AnySQLiteTable } from '../table.ts';\nimport { SQLiteColumn, SQLiteColumnBuilder } from './common.ts';\n\nexport interface PrimaryKeyConfig {\n\tautoIncrement?: boolean;\n\tonConflict?: OnConflict;\n}\n\nexport abstract class SQLiteBaseIntegerBuilder<\n\tT extends ColumnBuilderBaseConfig<ColumnDataType, string>,\n\tTRuntimeConfig extends object = object,\n> extends SQLiteColumnBuilder<\n\tT,\n\tTRuntimeConfig & { autoIncrement: boolean },\n\t{},\n\t{ primaryKeyHasDefault: true }\n> {\n\tstatic override readonly [entityKind]: string = 'SQLiteBaseIntegerBuilder';\n\n\tconstructor(name: T['name'], dataType: T['dataType'], columnType: T['columnType']) {\n\t\tsuper(name, dataType, columnType);\n\t\tthis.config.autoIncrement = false;\n\t}\n\n\toverride primaryKey(config?: PrimaryKeyConfig): IsPrimaryKey<HasDefault<NotNull<this>>> {\n\t\tif (config?.autoIncrement) {\n\t\t\tthis.config.autoIncrement = true;\n\t\t}\n\t\tthis.config.hasDefault = true;\n\t\treturn super.primaryKey() as IsPrimaryKey<HasDefault<NotNull<this>>>;\n\t}\n\n\t/** @internal */\n\tabstract override build<TTableName extends string>(\n\t\ttable: AnySQLiteTable<{ name: TTableName }>,\n\t): SQLiteBaseInteger<MakeColumnConfig<T, TTableName>>;\n}\n\nexport abstract class SQLiteBaseInteger<\n\tT extends ColumnBaseConfig<ColumnDataType, string>,\n\tTRuntimeConfig extends object = object,\n> extends SQLiteColumn<T, TRuntimeConfig & { autoIncrement: boolean }> {\n\tstatic override readonly [entityKind]: string = 'SQLiteBaseInteger';\n\n\treadonly autoIncrement: boolean = this.config.autoIncrement;\n\n\tgetSQLType(): string {\n\t\treturn 'integer';\n\t}\n}\n\nexport type SQLiteIntegerBuilderInitial<TName extends string> = SQLiteIntegerBuilder<{\n\tname: TName;\n\tdataType: 'number';\n\tcolumnType: 'SQLiteInteger';\n\tdata: number;\n\tdriverParam: number;\n\tenumValues: undefined;\n}>;\n\nexport class SQLiteIntegerBuilder<T extends ColumnBuilderBaseConfig<'number', 'SQLiteInteger'>>\n\textends SQLiteBaseIntegerBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteIntegerBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'number', 'SQLiteInteger');\n\t}\n\n\tbuild<TTableName extends string>(\n\t\ttable: AnySQLiteTable<{ name: TTableName }>,\n\t): SQLiteInteger<MakeColumnConfig<T, TTableName>> {\n\t\treturn new SQLiteInteger<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class SQLiteInteger<T extends ColumnBaseConfig<'number', 'SQLiteInteger'>> extends SQLiteBaseInteger<T> {\n\tstatic override readonly [entityKind]: string = 'SQLiteInteger';\n}\n\nexport type SQLiteTimestampBuilderInitial<TName extends string> = SQLiteTimestampBuilder<{\n\tname: TName;\n\tdataType: 'date';\n\tcolumnType: 'SQLiteTimestamp';\n\tdata: Date;\n\tdriverParam: number;\n\tenumValues: undefined;\n}>;\n\nexport class SQLiteTimestampBuilder<T extends ColumnBuilderBaseConfig<'date', 'SQLiteTimestamp'>>\n\textends SQLiteBaseIntegerBuilder<T, { mode: 'timestamp' | 'timestamp_ms' }>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteTimestampBuilder';\n\n\tconstructor(name: T['name'], mode: 'timestamp' | 'timestamp_ms') {\n\t\tsuper(name, 'date', 'SQLiteTimestamp');\n\t\tthis.config.mode = mode;\n\t}\n\n\t/**\n\t * @deprecated Use `default()` with your own expression instead.\n\t *\n\t * Adds `DEFAULT (cast((julianday('now') - 2440587.5)*86400000 as integer))` to the column, which is the current epoch timestamp in milliseconds.\n\t */\n\tdefaultNow(): HasDefault<this> {\n\t\treturn this.default(sql`(cast((julianday('now') - 2440587.5)*86400000 as integer))`) as any;\n\t}\n\n\tbuild<TTableName extends string>(\n\t\ttable: AnySQLiteTable<{ name: TTableName }>,\n\t): SQLiteTimestamp<MakeColumnConfig<T, TTableName>> {\n\t\treturn new SQLiteTimestamp<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class SQLiteTimestamp<T extends ColumnBaseConfig<'date', 'SQLiteTimestamp'>>\n\textends SQLiteBaseInteger<T, { mode: 'timestamp' | 'timestamp_ms' }>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteTimestamp';\n\n\treadonly mode: 'timestamp' | 'timestamp_ms' = this.config.mode;\n\n\toverride mapFromDriverValue(value: number): Date {\n\t\tif (this.config.mode === 'timestamp') {\n\t\t\treturn new Date(value * 1000);\n\t\t}\n\t\treturn new Date(value);\n\t}\n\n\toverride mapToDriverValue(value: Date): number {\n\t\tconst unix = value.getTime();\n\t\tif (this.config.mode === 'timestamp') {\n\t\t\treturn Math.floor(unix / 1000);\n\t\t}\n\t\treturn unix;\n\t}\n}\n\nexport type SQLiteBooleanBuilderInitial<TName extends string> = SQLiteBooleanBuilder<{\n\tname: TName;\n\tdataType: 'boolean';\n\tcolumnType: 'SQLiteBoolean';\n\tdata: boolean;\n\tdriverParam: number;\n\tenumValues: undefined;\n}>;\n\nexport class SQLiteBooleanBuilder<T extends ColumnBuilderBaseConfig<'boolean', 'SQLiteBoolean'>>\n\textends SQLiteBaseIntegerBuilder<T, { mode: 'boolean' }>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteBooleanBuilder';\n\n\tconstructor(name: T['name'], mode: 'boolean') {\n\t\tsuper(name, 'boolean', 'SQLiteBoolean');\n\t\tthis.config.mode = mode;\n\t}\n\n\tbuild<TTableName extends string>(\n\t\ttable: AnySQLiteTable<{ name: TTableName }>,\n\t): SQLiteBoolean<MakeColumnConfig<T, TTableName>> {\n\t\treturn new SQLiteBoolean<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class SQLiteBoolean<T extends ColumnBaseConfig<'boolean', 'SQLiteBoolean'>>\n\textends SQLiteBaseInteger<T, { mode: 'boolean' }>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteBoolean';\n\n\treadonly mode: 'boolean' = this.config.mode;\n\n\toverride mapFromDriverValue(value: number): boolean {\n\t\treturn Number(value) === 1;\n\t}\n\n\toverride mapToDriverValue(value: boolean): number {\n\t\treturn value ? 1 : 0;\n\t}\n}\n\nexport interface IntegerConfig<\n\tTMode extends 'number' | 'timestamp' | 'timestamp_ms' | 'boolean' =\n\t\t| 'number'\n\t\t| 'timestamp'\n\t\t| 'timestamp_ms'\n\t\t| 'boolean',\n> {\n\tmode: TMode;\n}\n\nexport function integer(): SQLiteIntegerBuilderInitial<''>;\nexport function integer<TMode extends IntegerConfig['mode']>(\n\tconfig?: IntegerConfig<TMode>,\n): Or<Equal<TMode, 'timestamp'>, Equal<TMode, 'timestamp_ms'>> extends true ? SQLiteTimestampBuilderInitial<''>\n\t: Equal<TMode, 'boolean'> extends true ? SQLiteBooleanBuilderInitial<''>\n\t: SQLiteIntegerBuilderInitial<''>;\nexport function integer<TName extends string, TMode extends IntegerConfig['mode']>(\n\tname: TName,\n\tconfig?: IntegerConfig<TMode>,\n): Or<Equal<TMode, 'timestamp'>, Equal<TMode, 'timestamp_ms'>> extends true ? SQLiteTimestampBuilderInitial<TName>\n\t: Equal<TMode, 'boolean'> extends true ? SQLiteBooleanBuilderInitial<TName>\n\t: SQLiteIntegerBuilderInitial<TName>;\nexport function integer(a?: string | IntegerConfig, b?: IntegerConfig) {\n\tconst { name, config } = getColumnNameAndConfig<IntegerConfig | undefined>(a, b);\n\tif (config?.mode === 'timestamp' || config?.mode === 'timestamp_ms') {\n\t\treturn new SQLiteTimestampBuilder(name, config.mode);\n\t}\n\tif (config?.mode === 'boolean') {\n\t\treturn new SQLiteBooleanBuilder(name, config.mode);\n\t}\n\treturn new SQLiteIntegerBuilder(name);\n}\n\nexport const int = integer;\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnySQLiteTable } from '~/sqlite-core/table.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { SQLiteColumn, SQLiteColumnBuilder } from './common.ts';\n\nexport type SQLiteNumericBuilderInitial<TName extends string> = SQLiteNumericBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'SQLiteNumeric';\n\tdata: string;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class SQLiteNumericBuilder<T extends ColumnBuilderBaseConfig<'string', 'SQLiteNumeric'>>\n\textends SQLiteColumnBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteNumericBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'string', 'SQLiteNumeric');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnySQLiteTable<{ name: TTableName }>,\n\t): SQLiteNumeric<MakeColumnConfig<T, TTableName>> {\n\t\treturn new SQLiteNumeric<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class SQLiteNumeric<T extends ColumnBaseConfig<'string', 'SQLiteNumeric'>> extends SQLiteColumn<T> {\n\tstatic override readonly [entityKind]: string = 'SQLiteNumeric';\n\n\toverride mapFromDriverValue(value: unknown): string {\n\t\tif (typeof value === 'string') return value;\n\n\t\treturn String(value);\n\t}\n\n\tgetSQLType(): string {\n\t\treturn 'numeric';\n\t}\n}\n\nexport type SQLiteNumericNumberBuilderInitial<TName extends string> = SQLiteNumericNumberBuilder<{\n\tname: TName;\n\tdataType: 'number';\n\tcolumnType: 'SQLiteNumericNumber';\n\tdata: number;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class SQLiteNumericNumberBuilder<T extends ColumnBuilderBaseConfig<'number', 'SQLiteNumericNumber'>>\n\textends SQLiteColumnBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteNumericNumberBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'number', 'SQLiteNumericNumber');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnySQLiteTable<{ name: TTableName }>,\n\t): SQLiteNumericNumber<MakeColumnConfig<T, TTableName>> {\n\t\treturn new SQLiteNumericNumber<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class SQLiteNumericNumber<T extends ColumnBaseConfig<'number', 'SQLiteNumericNumber'>> extends SQLiteColumn<T> {\n\tstatic override readonly [entityKind]: string = 'SQLiteNumericNumber';\n\n\toverride mapFromDriverValue(value: unknown): number {\n\t\tif (typeof value === 'number') return value;\n\n\t\treturn Number(value);\n\t}\n\n\toverride mapToDriverValue = String;\n\n\tgetSQLType(): string {\n\t\treturn 'numeric';\n\t}\n}\n\nexport type SQLiteNumericBigIntBuilderInitial<TName extends string> = SQLiteNumericBigIntBuilder<{\n\tname: TName;\n\tdataType: 'bigint';\n\tcolumnType: 'SQLiteNumericBigInt';\n\tdata: bigint;\n\tdriverParam: string;\n\tenumValues: undefined;\n}>;\n\nexport class SQLiteNumericBigIntBuilder<T extends ColumnBuilderBaseConfig<'bigint', 'SQLiteNumericBigInt'>>\n\textends SQLiteColumnBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteNumericBigIntBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'bigint', 'SQLiteNumericBigInt');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnySQLiteTable<{ name: TTableName }>,\n\t): SQLiteNumericBigInt<MakeColumnConfig<T, TTableName>> {\n\t\treturn new SQLiteNumericBigInt<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class SQLiteNumericBigInt<T extends ColumnBaseConfig<'bigint', 'SQLiteNumericBigInt'>> extends SQLiteColumn<T> {\n\tstatic override readonly [entityKind]: string = 'SQLiteNumericBigInt';\n\n\toverride mapFromDriverValue = BigInt;\n\n\toverride mapToDriverValue = String;\n\n\tgetSQLType(): string {\n\t\treturn 'numeric';\n\t}\n}\n\nexport type SQLiteNumericConfig<T extends 'string' | 'number' | 'bigint' = 'string' | 'number' | 'bigint'> = {\n\tmode: T;\n};\n\nexport function numeric<TMode extends SQLiteNumericConfig['mode']>(\n\tconfig?: SQLiteNumericConfig<TMode>,\n): Equal<TMode, 'number'> extends true ? SQLiteNumericNumberBuilderInitial<''>\n\t: Equal<TMode, 'bigint'> extends true ? SQLiteNumericBigIntBuilderInitial<''>\n\t: SQLiteNumericBuilderInitial<''>;\nexport function numeric<TName extends string, TMode extends SQLiteNumericConfig['mode']>(\n\tname: TName,\n\tconfig?: SQLiteNumericConfig<TMode>,\n): Equal<TMode, 'number'> extends true ? SQLiteNumericNumberBuilderInitial<TName>\n\t: Equal<TMode, 'bigint'> extends true ? SQLiteNumericBigIntBuilderInitial<TName>\n\t: SQLiteNumericBuilderInitial<TName>;\nexport function numeric(a?: string | SQLiteNumericConfig, b?: SQLiteNumericConfig) {\n\tconst { name, config } = getColumnNameAndConfig<SQLiteNumericConfig>(a, b);\n\tconst mode = config?.mode;\n\treturn mode === 'number'\n\t\t? new SQLiteNumericNumberBuilder(name)\n\t\t: mode === 'bigint'\n\t\t? new SQLiteNumericBigIntBuilder(name)\n\t\t: new SQLiteNumericBuilder(name);\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnySQLiteTable } from '../table.ts';\nimport { SQLiteColumn, SQLiteColumnBuilder } from './common.ts';\n\nexport type SQLiteRealBuilderInitial<TName extends string> = SQLiteRealBuilder<{\n\tname: TName;\n\tdataType: 'number';\n\tcolumnType: 'SQLiteReal';\n\tdata: number;\n\tdriverParam: number;\n\tenumValues: undefined;\n}>;\n\nexport class SQLiteRealBuilder<T extends ColumnBuilderBaseConfig<'number', 'SQLiteReal'>>\n\textends SQLiteColumnBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteRealBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'number', 'SQLiteReal');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnySQLiteTable<{ name: TTableName }>,\n\t): SQLiteReal<MakeColumnConfig<T, TTableName>> {\n\t\treturn new SQLiteReal<MakeColumnConfig<T, TTableName>>(table, this.config as ColumnBuilderRuntimeConfig<any, any>);\n\t}\n}\n\nexport class SQLiteReal<T extends ColumnBaseConfig<'number', 'SQLiteReal'>> extends SQLiteColumn<T> {\n\tstatic override readonly [entityKind]: string = 'SQLiteReal';\n\n\tgetSQLType(): string {\n\t\treturn 'real';\n\t}\n}\n\nexport function real(): SQLiteRealBuilderInitial<''>;\nexport function real<TName extends string>(name: TName): SQLiteRealBuilderInitial<TName>;\nexport function real(name?: string) {\n\treturn new SQLiteRealBuilder(name ?? '');\n}\n","import type { ColumnBuilderBaseConfig, ColumnBuilderRuntimeConfig, MakeColumnConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { AnySQLiteTable } from '~/sqlite-core/table.ts';\nimport { type Equal, getColumnNameAndConfig, type Writable } from '~/utils.ts';\nimport { SQLiteColumn, SQLiteColumnBuilder } from './common.ts';\n\nexport type SQLiteTextBuilderInitial<\n\tTName extends string,\n\tTEnum extends [string, ...string[]],\n\tTLength extends number | undefined,\n> = SQLiteTextBuilder<{\n\tname: TName;\n\tdataType: 'string';\n\tcolumnType: 'SQLiteText';\n\tdata: TEnum[number];\n\tdriverParam: string;\n\tenumValues: TEnum;\n\tlength: TLength;\n}>;\n\nexport class SQLiteTextBuilder<\n\tT extends ColumnBuilderBaseConfig<'string', 'SQLiteText'> & { length?: number | undefined },\n> extends SQLiteColumnBuilder<\n\tT,\n\t{ length: T['length']; enumValues: T['enumValues'] },\n\t{ length: T['length'] }\n> {\n\tstatic override readonly [entityKind]: string = 'SQLiteTextBuilder';\n\n\tconstructor(name: T['name'], config: SQLiteTextConfig<'text', T['enumValues'], T['length']>) {\n\t\tsuper(name, 'string', 'SQLiteText');\n\t\tthis.config.enumValues = config.enum;\n\t\tthis.config.length = config.length;\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnySQLiteTable<{ name: TTableName }>,\n\t): SQLiteText<MakeColumnConfig<T, TTableName> & { length: T['length'] }> {\n\t\treturn new SQLiteText<MakeColumnConfig<T, TTableName> & { length: T['length'] }>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class SQLiteText<T extends ColumnBaseConfig<'string', 'SQLiteText'> & { length?: number | undefined }>\n\textends SQLiteColumn<T, { length: T['length']; enumValues: T['enumValues'] }>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteText';\n\n\toverride readonly enumValues = this.config.enumValues;\n\n\treadonly length: T['length'] = this.config.length;\n\n\tconstructor(\n\t\ttable: AnySQLiteTable<{ name: T['tableName'] }>,\n\t\tconfig: SQLiteTextBuilder<T>['config'],\n\t) {\n\t\tsuper(table, config);\n\t}\n\n\tgetSQLType(): string {\n\t\treturn `text${this.config.length ? `(${this.config.length})` : ''}`;\n\t}\n}\n\nexport type SQLiteTextJsonBuilderInitial<TName extends string> = SQLiteTextJsonBuilder<{\n\tname: TName;\n\tdataType: 'json';\n\tcolumnType: 'SQLiteTextJson';\n\tdata: unknown;\n\tdriverParam: string;\n\tenumValues: undefined;\n\tgenerated: undefined;\n}>;\n\nexport class SQLiteTextJsonBuilder<T extends ColumnBuilderBaseConfig<'json', 'SQLiteTextJson'>>\n\textends SQLiteColumnBuilder<T>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteTextJsonBuilder';\n\n\tconstructor(name: T['name']) {\n\t\tsuper(name, 'json', 'SQLiteTextJson');\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnySQLiteTable<{ name: TTableName }>,\n\t): SQLiteTextJson<MakeColumnConfig<T, TTableName>> {\n\t\treturn new SQLiteTextJson<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t);\n\t}\n}\n\nexport class SQLiteTextJson<T extends ColumnBaseConfig<'json', 'SQLiteTextJson'>>\n\textends SQLiteColumn<T, { length: number | undefined; enumValues: T['enumValues'] }>\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteTextJson';\n\n\tgetSQLType(): string {\n\t\treturn 'text';\n\t}\n\n\toverride mapFromDriverValue(value: string): T['data'] {\n\t\treturn JSON.parse(value);\n\t}\n\n\toverride mapToDriverValue(value: T['data']): string {\n\t\treturn JSON.stringify(value);\n\t}\n}\n\nexport type SQLiteTextConfig<\n\tTMode extends 'text' | 'json' = 'text' | 'json',\n\tTEnum extends readonly string[] | string[] | undefined = readonly string[] | string[] | undefined,\n\tTLength extends number | undefined = number | undefined,\n> = TMode extends 'text' ? {\n\t\tmode?: TMode;\n\t\tlength?: TLength;\n\t\tenum?: TEnum;\n\t}\n\t: {\n\t\tmode?: TMode;\n\t};\n\nexport function text(): SQLiteTextBuilderInitial<'', [string, ...string[]], undefined>;\nexport function text<\n\tU extends string,\n\tT extends Readonly<[U, ...U[]]>,\n\tL extends number | undefined,\n\tTMode extends 'text' | 'json' = 'text' | 'json',\n>(\n\tconfig?: SQLiteTextConfig<TMode, T | Writable<T>, L>,\n): Equal<TMode, 'json'> extends true ? SQLiteTextJsonBuilderInitial<''>\n\t: SQLiteTextBuilderInitial<'', Writable<T>, L>;\nexport function text<\n\tTName extends string,\n\tU extends string,\n\tT extends Readonly<[U, ...U[]]>,\n\tL extends number | undefined,\n\tTMode extends 'text' | 'json' = 'text' | 'json',\n>(\n\tname: TName,\n\tconfig?: SQLiteTextConfig<TMode, T | Writable<T>, L>,\n): Equal<TMode, 'json'> extends true ? SQLiteTextJsonBuilderInitial<TName>\n\t: SQLiteTextBuilderInitial<TName, Writable<T>, L>;\nexport function text(a?: string | SQLiteTextConfig, b: SQLiteTextConfig = {}): any {\n\tconst { name, config } = getColumnNameAndConfig<SQLiteTextConfig>(a, b);\n\tif (config.mode === 'json') {\n\t\treturn new SQLiteTextJsonBuilder(name);\n\t}\n\treturn new SQLiteTextBuilder(name, config as any);\n}\n","import { blob } from './blob.ts';\nimport { customType } from './custom.ts';\nimport { integer } from './integer.ts';\nimport { numeric } from './numeric.ts';\nimport { real } from './real.ts';\nimport { text } from './text.ts';\n\nexport function getSQLiteColumnBuilders() {\n\treturn {\n\t\tblob,\n\t\tcustomType,\n\t\tinteger,\n\t\tnumeric,\n\t\treal,\n\t\ttext,\n\t};\n}\n\nexport type SQLiteColumnBuilders = ReturnType<typeof getSQLiteColumnBuilders>;\n","import type { BuildColumns, BuildExtraConfigColumns } from '~/column-builder.ts';\nimport { entityKind } from '~/entity.ts';\nimport { Table, type TableConfig as TableConfigBase, type UpdateTableConfig } from '~/table.ts';\nimport type { CheckBuilder } from './checks.ts';\nimport { getSQLiteColumnBuilders, type SQLiteColumnBuilders } from './columns/all.ts';\nimport type { SQLiteColumn, SQLiteColumnBuilder, SQLiteColumnBuilderBase } from './columns/common.ts';\nimport type { ForeignKey, ForeignKeyBuilder } from './foreign-keys.ts';\nimport type { IndexBuilder } from './indexes.ts';\nimport type { PrimaryKeyBuilder } from './primary-keys.ts';\nimport type { UniqueConstraintBuilder } from './unique-constraint.ts';\n\nexport type SQLiteTableExtraConfigValue =\n\t| IndexBuilder\n\t| CheckBuilder\n\t| ForeignKeyBuilder\n\t| PrimaryKeyBuilder\n\t| UniqueConstraintBuilder;\n\nexport type SQLiteTableExtraConfig = Record<\n\tstring,\n\tSQLiteTableExtraConfigValue\n>;\n\nexport type TableConfig = TableConfigBase<SQLiteColumn<any>>;\n\n/** @internal */\nexport const InlineForeignKeys = Symbol.for('drizzle:SQLiteInlineForeignKeys');\n\nexport class SQLiteTable<T extends TableConfig = TableConfig> extends Table<T> {\n\tstatic override readonly [entityKind]: string = 'SQLiteTable';\n\n\t/** @internal */\n\tstatic override readonly Symbol = Object.assign({}, Table.Symbol, {\n\t\tInlineForeignKeys: InlineForeignKeys as typeof InlineForeignKeys,\n\t});\n\n\t/** @internal */\n\toverride [Table.Symbol.Columns]!: NonNullable<T['columns']>;\n\n\t/** @internal */\n\t[InlineForeignKeys]: ForeignKey[] = [];\n\n\t/** @internal */\n\toverride [Table.Symbol.ExtraConfigBuilder]:\n\t\t| ((self: Record<string, SQLiteColumn>) => SQLiteTableExtraConfig)\n\t\t| undefined = undefined;\n}\n\nexport type AnySQLiteTable<TPartial extends Partial<TableConfig> = {}> = SQLiteTable<\n\tUpdateTableConfig<TableConfig, TPartial>\n>;\n\nexport type SQLiteTableWithColumns<T extends TableConfig> =\n\t& SQLiteTable<T>\n\t& {\n\t\t[Key in keyof T['columns']]: T['columns'][Key];\n\t};\n\nexport interface SQLiteTableFn<TSchema extends string | undefined = undefined> {\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, SQLiteColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig?: (\n\t\t\tself: BuildColumns<TTableName, TColumnsMap, 'sqlite'>,\n\t\t) => SQLiteTableExtraConfigValue[],\n\t): SQLiteTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\t\tdialect: 'sqlite';\n\t}>;\n\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, SQLiteColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: (columnTypes: SQLiteColumnBuilders) => TColumnsMap,\n\t\textraConfig?: (self: BuildColumns<TTableName, TColumnsMap, 'sqlite'>) => SQLiteTableExtraConfigValue[],\n\t): SQLiteTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\t\tdialect: 'sqlite';\n\t}>;\n\t/**\n\t * @deprecated The third parameter of sqliteTable is changing and will only accept an array instead of an object\n\t *\n\t * @example\n\t * Deprecated version:\n\t * ```ts\n\t * export const users = sqliteTable(\"users\", {\n\t * \tid: int(),\n\t * }, (t) => ({\n\t * \tidx: index('custom_name').on(t.id)\n\t * }));\n\t * ```\n\t *\n\t * New API:\n\t * ```ts\n\t * export const users = sqliteTable(\"users\", {\n\t * \tid: int(),\n\t * }, (t) => [\n\t * \tindex('custom_name').on(t.id)\n\t * ]);\n\t * ```\n\t */\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, SQLiteColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: TColumnsMap,\n\t\textraConfig?: (self: BuildColumns<TTableName, TColumnsMap, 'sqlite'>) => SQLiteTableExtraConfig,\n\t): SQLiteTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\t\tdialect: 'sqlite';\n\t}>;\n\n\t/**\n\t * @deprecated The third parameter of sqliteTable is changing and will only accept an array instead of an object\n\t *\n\t * @example\n\t * Deprecated version:\n\t * ```ts\n\t * export const users = sqliteTable(\"users\", {\n\t * \tid: int(),\n\t * }, (t) => ({\n\t * \tidx: index('custom_name').on(t.id)\n\t * }));\n\t * ```\n\t *\n\t * New API:\n\t * ```ts\n\t * export const users = sqliteTable(\"users\", {\n\t * \tid: int(),\n\t * }, (t) => [\n\t * \tindex('custom_name').on(t.id)\n\t * ]);\n\t * ```\n\t */\n\t<\n\t\tTTableName extends string,\n\t\tTColumnsMap extends Record<string, SQLiteColumnBuilderBase>,\n\t>(\n\t\tname: TTableName,\n\t\tcolumns: (columnTypes: SQLiteColumnBuilders) => TColumnsMap,\n\t\textraConfig?: (self: BuildColumns<TTableName, TColumnsMap, 'sqlite'>) => SQLiteTableExtraConfig,\n\t): SQLiteTableWithColumns<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\t\tdialect: 'sqlite';\n\t}>;\n}\n\nfunction sqliteTableBase<\n\tTTableName extends string,\n\tTColumnsMap extends Record<string, SQLiteColumnBuilderBase>,\n\tTSchema extends string | undefined,\n>(\n\tname: TTableName,\n\tcolumns: TColumnsMap | ((columnTypes: SQLiteColumnBuilders) => TColumnsMap),\n\textraConfig:\n\t\t| ((\n\t\t\tself: BuildColumns<TTableName, TColumnsMap, 'sqlite'>,\n\t\t) => SQLiteTableExtraConfig | SQLiteTableExtraConfigValue[])\n\t\t| undefined,\n\tschema?: TSchema,\n\tbaseName = name,\n): SQLiteTableWithColumns<{\n\tname: TTableName;\n\tschema: TSchema;\n\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\tdialect: 'sqlite';\n}> {\n\tconst rawTable = new SQLiteTable<{\n\t\tname: TTableName;\n\t\tschema: TSchema;\n\t\tcolumns: BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\t\tdialect: 'sqlite';\n\t}>(name, schema, baseName);\n\n\tconst parsedColumns: TColumnsMap = typeof columns === 'function' ? columns(getSQLiteColumnBuilders()) : columns;\n\n\tconst builtColumns = Object.fromEntries(\n\t\tObject.entries(parsedColumns).map(([name, colBuilderBase]) => {\n\t\t\tconst colBuilder = colBuilderBase as SQLiteColumnBuilder;\n\t\t\tcolBuilder.setName(name);\n\t\t\tconst column = colBuilder.build(rawTable);\n\t\t\trawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n\t\t\treturn [name, column];\n\t\t}),\n\t) as unknown as BuildColumns<TTableName, TColumnsMap, 'sqlite'>;\n\n\tconst table = Object.assign(rawTable, builtColumns);\n\n\ttable[Table.Symbol.Columns] = builtColumns;\n\ttable[Table.Symbol.ExtraConfigColumns] = builtColumns as unknown as BuildExtraConfigColumns<\n\t\tTTableName,\n\t\tTColumnsMap,\n\t\t'sqlite'\n\t>;\n\n\tif (extraConfig) {\n\t\ttable[SQLiteTable.Symbol.ExtraConfigBuilder] = extraConfig as (\n\t\t\tself: Record<string, SQLiteColumn>,\n\t\t) => SQLiteTableExtraConfig;\n\t}\n\n\treturn table;\n}\n\nexport const sqliteTable: SQLiteTableFn = (name, columns, extraConfig) => {\n\treturn sqliteTableBase(name, columns, extraConfig);\n};\n\nexport function sqliteTableCreator(customizeTableName: (name: string) => string): SQLiteTableFn {\n\treturn (name, columns, extraConfig) => {\n\t\treturn sqliteTableBase(customizeTableName(name) as typeof name, columns, extraConfig, undefined, name);\n\t};\n}\n","import { entityKind } from '~/entity.ts';\nimport type { SQL } from '~/sql/sql.ts';\nimport type { SQLiteTable } from './table.ts';\n\nexport class CheckBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteCheckBuilder';\n\n\tprotected brand!: 'SQLiteConstraintBuilder';\n\n\tconstructor(public name: string, public value: SQL) {}\n\n\tbuild(table: SQLiteTable): Check {\n\t\treturn new Check(table, this);\n\t}\n}\n\nexport class Check {\n\tstatic readonly [entityKind]: string = 'SQLiteCheck';\n\n\tdeclare _: {\n\t\tbrand: 'SQLiteCheck';\n\t};\n\n\treadonly name: string;\n\treadonly value: SQL;\n\n\tconstructor(public table: SQLiteTable, builder: CheckBuilder) {\n\t\tthis.name = builder.name;\n\t\tthis.value = builder.value;\n\t}\n}\n\nexport function check(name: string, value: SQL): CheckBuilder {\n\treturn new CheckBuilder(name, value);\n}\n","import { entityKind } from '~/entity.ts';\nimport type { SQL } from '~/sql/sql.ts';\nimport type { SQLiteColumn } from './columns/index.ts';\nimport type { SQLiteTable } from './table.ts';\n\nexport interface IndexConfig {\n\tname: string;\n\tcolumns: IndexColumn[];\n\tunique: boolean;\n\twhere: SQL | undefined;\n}\n\nexport type IndexColumn = SQLiteColumn | SQL;\n\nexport class IndexBuilderOn {\n\tstatic readonly [entityKind]: string = 'SQLiteIndexBuilderOn';\n\n\tconstructor(private name: string, private unique: boolean) {}\n\n\ton(...columns: [IndexColumn, ...IndexColumn[]]): IndexBuilder {\n\t\treturn new IndexBuilder(this.name, columns, this.unique);\n\t}\n}\n\nexport class IndexBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteIndexBuilder';\n\n\tdeclare _: {\n\t\tbrand: 'SQLiteIndexBuilder';\n\t};\n\n\t/** @internal */\n\tconfig: IndexConfig;\n\n\tconstructor(name: string, columns: IndexColumn[], unique: boolean) {\n\t\tthis.config = {\n\t\t\tname,\n\t\t\tcolumns,\n\t\t\tunique,\n\t\t\twhere: undefined,\n\t\t};\n\t}\n\n\t/**\n\t * Condition for partial index.\n\t */\n\twhere(condition: SQL): this {\n\t\tthis.config.where = condition;\n\t\treturn this;\n\t}\n\n\t/** @internal */\n\tbuild(table: SQLiteTable): Index {\n\t\treturn new Index(this.config, table);\n\t}\n}\n\nexport class Index {\n\tstatic readonly [entityKind]: string = 'SQLiteIndex';\n\n\tdeclare _: {\n\t\tbrand: 'SQLiteIndex';\n\t};\n\n\treadonly config: IndexConfig & { table: SQLiteTable };\n\n\tconstructor(config: IndexConfig, table: SQLiteTable) {\n\t\tthis.config = { ...config, table };\n\t}\n}\n\nexport function index(name: string): IndexBuilderOn {\n\treturn new IndexBuilderOn(name, false);\n}\n\nexport function uniqueIndex(name: string): IndexBuilderOn {\n\treturn new IndexBuilderOn(name, true);\n}\n","import { entityKind } from '~/entity.ts';\nimport type { AnySQLiteColumn, SQLiteColumn } from './columns/index.ts';\nimport { SQLiteTable } from './table.ts';\n\nexport function primaryKey<\n\tTTableName extends string,\n\tTColumn extends AnySQLiteColumn<{ tableName: TTableName }>,\n\tTColumns extends AnySQLiteColumn<{ tableName: TTableName }>[],\n>(config: { name?: string; columns: [TColumn, ...TColumns] }): PrimaryKeyBuilder;\n/**\n * @deprecated: Please use primaryKey({ columns: [] }) instead of this function\n * @param columns\n */\nexport function primaryKey<\n\tTTableName extends string,\n\tTColumns extends AnySQLiteColumn<{ tableName: TTableName }>[],\n>(...columns: TColumns): PrimaryKeyBuilder;\nexport function primaryKey(...config: any) {\n\tif (config[0].columns) {\n\t\treturn new PrimaryKeyBuilder(config[0].columns, config[0].name);\n\t}\n\treturn new PrimaryKeyBuilder(config);\n}\nexport class PrimaryKeyBuilder {\n\tstatic readonly [entityKind]: string = 'SQLitePrimaryKeyBuilder';\n\n\tdeclare _: {\n\t\tbrand: 'SQLitePrimaryKeyBuilder';\n\t};\n\n\t/** @internal */\n\tcolumns: SQLiteColumn[];\n\n\t/** @internal */\n\tname?: string;\n\n\tconstructor(\n\t\tcolumns: SQLiteColumn[],\n\t\tname?: string,\n\t) {\n\t\tthis.columns = columns;\n\t\tthis.name = name;\n\t}\n\n\t/** @internal */\n\tbuild(table: SQLiteTable): PrimaryKey {\n\t\treturn new PrimaryKey(table, this.columns, this.name);\n\t}\n}\n\nexport class PrimaryKey {\n\tstatic readonly [entityKind]: string = 'SQLitePrimaryKey';\n\n\treadonly columns: SQLiteColumn[];\n\treadonly name?: string;\n\n\tconstructor(readonly table: SQLiteTable, columns: SQLiteColumn[], name?: string) {\n\t\tthis.columns = columns;\n\t\tthis.name = name;\n\t}\n\n\tgetName(): string {\n\t\treturn this.name\n\t\t\t?? `${this.table[SQLiteTable.Symbol.Name]}_${this.columns.map((column) => column.name).join('_')}_pk`;\n\t}\n}\n","import { is } from '~/entity.ts';\nimport { SQL } from '~/sql/sql.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { Table } from '~/table.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport type { Check } from './checks.ts';\nimport { CheckBuilder } from './checks.ts';\nimport type { ForeignKey } from './foreign-keys.ts';\nimport { ForeignKeyBuilder } from './foreign-keys.ts';\nimport type { Index } from './indexes.ts';\nimport { IndexBuilder } from './indexes.ts';\nimport type { PrimaryKey } from './primary-keys.ts';\nimport { PrimaryKeyBuilder } from './primary-keys.ts';\nimport { SQLiteTable } from './table.ts';\nimport { type UniqueConstraint, UniqueConstraintBuilder } from './unique-constraint.ts';\nimport type { SQLiteViewBase } from './view-base.ts';\nimport type { SQLiteView } from './view.ts';\n\nexport function getTableConfig<TTable extends SQLiteTable>(table: TTable) {\n\tconst columns = Object.values(table[SQLiteTable.Symbol.Columns]);\n\tconst indexes: Index[] = [];\n\tconst checks: Check[] = [];\n\tconst primaryKeys: PrimaryKey[] = [];\n\tconst uniqueConstraints: UniqueConstraint[] = [];\n\tconst foreignKeys: ForeignKey[] = Object.values(table[SQLiteTable.Symbol.InlineForeignKeys]);\n\tconst name = table[Table.Symbol.Name];\n\n\tconst extraConfigBuilder = table[SQLiteTable.Symbol.ExtraConfigBuilder];\n\n\tif (extraConfigBuilder !== undefined) {\n\t\tconst extraConfig = extraConfigBuilder(table[SQLiteTable.Symbol.Columns]);\n\t\tconst extraValues = Array.isArray(extraConfig) ? extraConfig.flat(1) as any[] : Object.values(extraConfig);\n\t\tfor (const builder of Object.values(extraValues)) {\n\t\t\tif (is(builder, IndexBuilder)) {\n\t\t\t\tindexes.push(builder.build(table));\n\t\t\t} else if (is(builder, CheckBuilder)) {\n\t\t\t\tchecks.push(builder.build(table));\n\t\t\t} else if (is(builder, UniqueConstraintBuilder)) {\n\t\t\t\tuniqueConstraints.push(builder.build(table));\n\t\t\t} else if (is(builder, PrimaryKeyBuilder)) {\n\t\t\t\tprimaryKeys.push(builder.build(table));\n\t\t\t} else if (is(builder, ForeignKeyBuilder)) {\n\t\t\t\tforeignKeys.push(builder.build(table));\n\t\t\t}\n\t\t}\n\t}\n\n\treturn {\n\t\tcolumns,\n\t\tindexes,\n\t\tforeignKeys,\n\t\tchecks,\n\t\tprimaryKeys,\n\t\tuniqueConstraints,\n\t\tname,\n\t};\n}\n\nexport function extractUsedTable(table: SQLiteTable | Subquery | SQLiteViewBase | SQL): string[] {\n\tif (is(table, SQLiteTable)) {\n\t\treturn [`${table[Table.Symbol.BaseName]}`];\n\t}\n\tif (is(table, Subquery)) {\n\t\treturn table._.usedTables ?? [];\n\t}\n\tif (is(table, SQL)) {\n\t\treturn table.usedTables ?? [];\n\t}\n\treturn [];\n}\n\nexport type OnConflict = 'rollback' | 'abort' | 'fail' | 'ignore' | 'replace';\n\nexport function getViewConfig<\n\tTName extends string = string,\n\tTExisting extends boolean = boolean,\n>(view: SQLiteView<TName, TExisting>) {\n\treturn {\n\t\t...view[ViewBaseConfig],\n\t\t// ...view[SQLiteViewConfig],\n\t};\n}\n","import { entityKind } from '~/entity.ts';\nimport type { SelectResultFields } from '~/query-builders/select.types.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport type { Placeholder, Query, SQL, SQLWrapper } from '~/sql/sql.ts';\nimport type { SQLiteDialect } from '~/sqlite-core/dialect.ts';\nimport type { SQLitePreparedQuery, SQLiteSession } from '~/sqlite-core/session.ts';\nimport { SQLiteTable } from '~/sqlite-core/table.ts';\nimport type { Subquery } from '~/subquery.ts';\nimport { Table } from '~/table.ts';\nimport { type DrizzleTypeError, orderSelectedFields, type ValueOrArray } from '~/utils.ts';\nimport type { SQLiteColumn } from '../columns/common.ts';\nimport { extractUsedTable } from '../utils.ts';\nimport type { SelectedFieldsFlat, SelectedFieldsOrdered } from './select.types.ts';\n\nexport type SQLiteDeleteWithout<\n\tT extends AnySQLiteDeleteBase,\n\tTDynamic extends boolean,\n\tK extends keyof T & string,\n> = TDynamic extends true ? T\n\t: Omit<\n\t\tSQLiteDeleteBase<\n\t\t\tT['_']['table'],\n\t\t\tT['_']['resultType'],\n\t\t\tT['_']['runResult'],\n\t\t\tT['_']['returning'],\n\t\t\tTDynamic,\n\t\t\tT['_']['excludedMethods'] | K\n\t\t>,\n\t\tT['_']['excludedMethods'] | K\n\t>;\n\nexport type SQLiteDelete<\n\tTTable extends SQLiteTable = SQLiteTable,\n\tTResultType extends 'sync' | 'async' = 'sync' | 'async',\n\tTRunResult = unknown,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\n> = SQLiteDeleteBase<TTable, TResultType, TRunResult, TReturning, true, never>;\n\nexport interface SQLiteDeleteConfig {\n\twhere?: SQL | undefined;\n\tlimit?: number | Placeholder;\n\torderBy?: (SQLiteColumn | SQL | SQL.Aliased)[];\n\ttable: SQLiteTable;\n\treturning?: SelectedFieldsOrdered;\n\twithList?: Subquery[];\n}\n\nexport type SQLiteDeleteReturningAll<\n\tT extends AnySQLiteDeleteBase,\n\tTDynamic extends boolean,\n> = SQLiteDeleteWithout<\n\tSQLiteDeleteBase<\n\t\tT['_']['table'],\n\t\tT['_']['resultType'],\n\t\tT['_']['runResult'],\n\t\tT['_']['table']['$inferSelect'],\n\t\tT['_']['dynamic'],\n\t\tT['_']['excludedMethods']\n\t>,\n\tTDynamic,\n\t'returning'\n>;\n\nexport type SQLiteDeleteReturning<\n\tT extends AnySQLiteDeleteBase,\n\tTDynamic extends boolean,\n\tTSelectedFields extends SelectedFieldsFlat,\n> = SQLiteDeleteWithout<\n\tSQLiteDeleteBase<\n\t\tT['_']['table'],\n\t\tT['_']['resultType'],\n\t\tT['_']['runResult'],\n\t\tSelectResultFields<TSelectedFields>,\n\t\tT['_']['dynamic'],\n\t\tT['_']['excludedMethods']\n\t>,\n\tTDynamic,\n\t'returning'\n>;\n\nexport type SQLiteDeleteExecute<T extends AnySQLiteDeleteBase> = T['_']['returning'] extends undefined\n\t? T['_']['runResult']\n\t: T['_']['returning'][];\n\nexport type SQLiteDeletePrepare<T extends AnySQLiteDeleteBase> = SQLitePreparedQuery<{\n\ttype: T['_']['resultType'];\n\trun: T['_']['runResult'];\n\tall: T['_']['returning'] extends undefined ? DrizzleTypeError<'.all() cannot be used without .returning()'>\n\t\t: T['_']['returning'][];\n\tget: T['_']['returning'] extends undefined ? DrizzleTypeError<'.get() cannot be used without .returning()'>\n\t\t: T['_']['returning'] | undefined;\n\tvalues: T['_']['returning'] extends undefined ? DrizzleTypeError<'.values() cannot be used without .returning()'>\n\t\t: any[][];\n\texecute: SQLiteDeleteExecute<T>;\n}>;\n\nexport type SQLiteDeleteDynamic<T extends AnySQLiteDeleteBase> = SQLiteDelete<\n\tT['_']['table'],\n\tT['_']['resultType'],\n\tT['_']['runResult'],\n\tT['_']['returning']\n>;\n\nexport type AnySQLiteDeleteBase = SQLiteDeleteBase<any, any, any, any, any, any>;\n\nexport interface SQLiteDeleteBase<\n\tTTable extends SQLiteTable,\n\tTResultType extends 'sync' | 'async',\n\tTRunResult,\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 ? TRunResult : TReturning[]>,\n\tRunnableQuery<TReturning extends undefined ? TRunResult : TReturning[], 'sqlite'>,\n\tSQLWrapper\n{\n\treadonly _: {\n\t\tdialect: 'sqlite';\n\t\treadonly table: TTable;\n\t\treadonly resultType: TResultType;\n\t\treadonly runResult: TRunResult;\n\t\treadonly returning: TReturning;\n\t\treadonly dynamic: TDynamic;\n\t\treadonly excludedMethods: TExcludedMethods;\n\t\treadonly result: TReturning extends undefined ? TRunResult : TReturning[];\n\t};\n}\n\nexport class SQLiteDeleteBase<\n\tTTable extends SQLiteTable,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTResultType extends 'sync' | 'async',\n\tTRunResult,\n\tTReturning extends Record<string, unknown> | undefined = undefined,\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 ? TRunResult : TReturning[]>\n\timplements RunnableQuery<TReturning extends undefined ? TRunResult : TReturning[], 'sqlite'>, SQLWrapper\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteDelete';\n\n\t/** @internal */\n\tconfig: SQLiteDeleteConfig;\n\n\tconstructor(\n\t\tprivate table: TTable,\n\t\tprivate session: SQLiteSession<any, any, any, any>,\n\t\tprivate dialect: SQLiteDialect,\n\t\twithList?: Subquery[],\n\t) {\n\t\tsuper();\n\t\tthis.config = { table, withList };\n\t}\n\n\t/**\n\t * Adds a `where` clause to the query.\n\t *\n\t * Calling this method will delete only those rows that fulfill a specified condition.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/delete}\n\t *\n\t * @param where the `where` clause.\n\t *\n\t * @example\n\t * You can use conditional operators and `sql function` to filter the rows to be deleted.\n\t *\n\t * ```ts\n\t * // Delete all cars with green color\n\t * db.delete(cars).where(eq(cars.color, 'green'));\n\t * // or\n\t * db.delete(cars).where(sql`${cars.color} = 'green'`)\n\t * ```\n\t *\n\t * You can logically combine conditional operators with `and()` and `or()` operators:\n\t *\n\t * ```ts\n\t * // Delete all BMW cars with a green color\n\t * db.delete(cars).where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n\t *\n\t * // Delete all cars with the green or blue color\n\t * db.delete(cars).where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n\t * ```\n\t */\n\twhere(where: SQL | undefined): SQLiteDeleteWithout<this, TDynamic, 'where'> {\n\t\tthis.config.where = where;\n\t\treturn this as any;\n\t}\n\n\torderBy(\n\t\tbuilder: (deleteTable: TTable) => ValueOrArray<SQLiteColumn | SQL | SQL.Aliased>,\n\t): SQLiteDeleteWithout<this, TDynamic, 'orderBy'>;\n\torderBy(...columns: (SQLiteColumn | SQL | SQL.Aliased)[]): SQLiteDeleteWithout<this, TDynamic, 'orderBy'>;\n\torderBy(\n\t\t...columns:\n\t\t\t| [(deleteTable: TTable) => ValueOrArray<SQLiteColumn | SQL | SQL.Aliased>]\n\t\t\t| (SQLiteColumn | SQL | SQL.Aliased)[]\n\t): SQLiteDeleteWithout<this, TDynamic, 'orderBy'> {\n\t\tif (typeof columns[0] === 'function') {\n\t\t\tconst orderBy = columns[0](\n\t\t\t\tnew Proxy(\n\t\t\t\t\tthis.config.table[Table.Symbol.Columns],\n\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'alias', sqlBehavior: 'sql' }),\n\t\t\t\t) as any,\n\t\t\t);\n\n\t\t\tconst orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];\n\t\t\tthis.config.orderBy = orderByArray;\n\t\t} else {\n\t\t\tconst orderByArray = columns as (SQLiteColumn | SQL | SQL.Aliased)[];\n\t\t\tthis.config.orderBy = orderByArray;\n\t\t}\n\t\treturn this as any;\n\t}\n\n\tlimit(limit: number | Placeholder): SQLiteDeleteWithout<this, TDynamic, 'limit'> {\n\t\tthis.config.limit = limit;\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `returning` clause to the query.\n\t *\n\t * Calling this method will return the specified fields of the deleted rows. If no fields are specified, all fields will be returned.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/delete#delete-with-return}\n\t *\n\t * @example\n\t * ```ts\n\t * // Delete all cars with the green color and return all fields\n\t * const deletedCars: Car[] = await db.delete(cars)\n\t * .where(eq(cars.color, 'green'))\n\t * .returning();\n\t *\n\t * // Delete all cars with the green color and return only their id and brand fields\n\t * const deletedCarsIdsAndBrands: { id: number, brand: string }[] = await db.delete(cars)\n\t * .where(eq(cars.color, 'green'))\n\t * .returning({ id: cars.id, brand: cars.brand });\n\t * ```\n\t */\n\treturning(): SQLiteDeleteReturningAll<this, TDynamic>;\n\treturning<TSelectedFields extends SelectedFieldsFlat>(\n\t\tfields: TSelectedFields,\n\t): SQLiteDeleteReturning<this, TDynamic, TSelectedFields>;\n\treturning(\n\t\tfields: SelectedFieldsFlat = this.table[SQLiteTable.Symbol.Columns],\n\t): SQLiteDeleteReturning<this, TDynamic, any> {\n\t\tthis.config.returning = orderSelectedFields<SQLiteColumn>(fields);\n\t\treturn this as any;\n\t}\n\n\t/** @internal */\n\tgetSQL(): SQL {\n\t\treturn this.dialect.buildDeleteQuery(this.config);\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\t/** @internal */\n\t_prepare(isOneTimeQuery = true): SQLiteDeletePrepare<this> {\n\t\treturn this.session[isOneTimeQuery ? 'prepareOneTimeQuery' : 'prepareQuery'](\n\t\t\tthis.dialect.sqlToQuery(this.getSQL()),\n\t\t\tthis.config.returning,\n\t\t\tthis.config.returning ? 'all' : 'run',\n\t\t\ttrue,\n\t\t\tundefined,\n\t\t\t{\n\t\t\t\ttype: 'delete',\n\t\t\t\ttables: extractUsedTable(this.config.table),\n\t\t\t},\n\t\t) as SQLiteDeletePrepare<this>;\n\t}\n\n\tprepare(): SQLiteDeletePrepare<this> {\n\t\treturn this._prepare(false);\n\t}\n\n\trun: ReturnType<this['prepare']>['run'] = (placeholderValues) => {\n\t\treturn this._prepare().run(placeholderValues);\n\t};\n\n\tall: ReturnType<this['prepare']>['all'] = (placeholderValues) => {\n\t\treturn this._prepare().all(placeholderValues);\n\t};\n\n\tget: ReturnType<this['prepare']>['get'] = (placeholderValues) => {\n\t\treturn this._prepare().get(placeholderValues);\n\t};\n\n\tvalues: ReturnType<this['prepare']>['values'] = (placeholderValues) => {\n\t\treturn this._prepare().values(placeholderValues);\n\t};\n\n\toverride async execute(placeholderValues?: Record<string, unknown>): Promise<SQLiteDeleteExecute<this>> {\n\t\treturn this._prepare().execute(placeholderValues) as SQLiteDeleteExecute<this>;\n\t}\n\n\t$dynamic(): SQLiteDeleteDynamic<this> {\n\t\treturn this as any;\n\t}\n}\n","import type { Column } from '~/column.ts';\nimport { entityKind } from './entity.ts';\nimport { Table } from './table.ts';\nimport type { Casing } from './utils.ts';\n\nexport function toSnakeCase(input: string) {\n\tconst words = input\n\t\t.replace(/['\\u2019]/g, '')\n\t\t.match(/[\\da-z]+|[A-Z]+(?![a-z])|[A-Z][\\da-z]+/g) ?? [];\n\n\treturn words.map((word) => word.toLowerCase()).join('_');\n}\n\nexport function toCamelCase(input: string) {\n\tconst words = input\n\t\t.replace(/['\\u2019]/g, '')\n\t\t.match(/[\\da-z]+|[A-Z]+(?![a-z])|[A-Z][\\da-z]+/g) ?? [];\n\n\treturn words.reduce((acc, word, i) => {\n\t\tconst formattedWord = i === 0 ? word.toLowerCase() : `${word[0]!.toUpperCase()}${word.slice(1)}`;\n\t\treturn acc + formattedWord;\n\t}, '');\n}\n\nfunction noopCase(input: string) {\n\treturn input;\n}\n\nexport class CasingCache {\n\tstatic readonly [entityKind]: string = 'CasingCache';\n\n\t/** @internal */\n\tcache: Record<string, string> = {};\n\tprivate cachedTables: Record<string, true> = {};\n\tprivate convert: (input: string) => string;\n\n\tconstructor(casing?: Casing) {\n\t\tthis.convert = casing === 'snake_case'\n\t\t\t? toSnakeCase\n\t\t\t: casing === 'camelCase'\n\t\t\t? toCamelCase\n\t\t\t: noopCase;\n\t}\n\n\tgetColumnCasing(column: Column): string {\n\t\tif (!column.keyAsName) return column.name;\n\n\t\tconst schema = column.table[Table.Symbol.Schema] ?? 'public';\n\t\tconst tableName = column.table[Table.Symbol.OriginalName];\n\t\tconst key = `${schema}.${tableName}.${column.name}`;\n\n\t\tif (!this.cache[key]) {\n\t\t\tthis.cacheTable(column.table);\n\t\t}\n\t\treturn this.cache[key]!;\n\t}\n\n\tprivate cacheTable(table: Table) {\n\t\tconst schema = table[Table.Symbol.Schema] ?? 'public';\n\t\tconst tableName = table[Table.Symbol.OriginalName];\n\t\tconst tableKey = `${schema}.${tableName}`;\n\n\t\tif (!this.cachedTables[tableKey]) {\n\t\t\tfor (const column of Object.values(table[Table.Symbol.Columns])) {\n\t\t\t\tconst columnKey = `${tableKey}.${column.name}`;\n\t\t\t\tthis.cache[columnKey] = this.convert(column.name);\n\t\t\t}\n\t\t\tthis.cachedTables[tableKey] = true;\n\t\t}\n\t}\n\n\tclearCache() {\n\t\tthis.cache = {};\n\t\tthis.cachedTables = {};\n\t}\n}\n","import { entityKind } from '~/entity.ts';\n\nexport class DrizzleError extends Error {\n\tstatic readonly [entityKind]: string = 'DrizzleError';\n\n\tconstructor({ message, cause }: { message?: string; cause?: unknown }) {\n\t\tsuper(message);\n\t\tthis.name = 'DrizzleError';\n\t\tthis.cause = cause;\n\t}\n}\n\nexport class DrizzleQueryError extends Error {\n\tconstructor(\n\t\tpublic query: string,\n\t\tpublic params: any[],\n\t\tpublic override cause?: Error,\n\t) {\n\t\tsuper(`Failed query: ${query}\\nparams: ${params}`);\n\t\tError.captureStackTrace(this, DrizzleQueryError);\n\n\t\t// ES2022+: preserves original error on `.cause`\n\t\tif (cause) (this as any).cause = cause;\n\t}\n}\n\nexport class TransactionRollbackError extends DrizzleError {\n\tstatic override readonly [entityKind]: string = 'TransactionRollbackError';\n\n\tconstructor() {\n\t\tsuper({ message: 'Rollback' });\n\t}\n}\n","import { type AnyColumn, Column } from '~/column.ts';\nimport { is } from '~/entity.ts';\nimport { type SQL, sql, type SQLWrapper } from '../sql.ts';\n\n/**\n * Returns the number of values in `expression`.\n *\n * ## Examples\n *\n * ```ts\n * // Number employees with null values\n * db.select({ value: count() }).from(employees)\n * // Number of employees where `name` is not null\n * db.select({ value: count(employees.name) }).from(employees)\n * ```\n *\n * @see countDistinct to get the number of non-duplicate values in `expression`\n */\nexport function count(expression?: SQLWrapper): SQL<number> {\n\treturn sql`count(${expression || sql.raw('*')})`.mapWith(Number);\n}\n\n/**\n * Returns the number of non-duplicate values in `expression`.\n *\n * ## Examples\n *\n * ```ts\n * // Number of employees where `name` is distinct\n * db.select({ value: countDistinct(employees.name) }).from(employees)\n * ```\n *\n * @see count to get the number of values in `expression`, including duplicates\n */\nexport function countDistinct(expression: SQLWrapper): SQL<number> {\n\treturn sql`count(distinct ${expression})`.mapWith(Number);\n}\n\n/**\n * Returns the average (arithmetic mean) of all non-null values in `expression`.\n *\n * ## Examples\n *\n * ```ts\n * // Average salary of an employee\n * db.select({ value: avg(employees.salary) }).from(employees)\n * ```\n *\n * @see avgDistinct to get the average of all non-null and non-duplicate values in `expression`\n */\nexport function avg(expression: SQLWrapper): SQL<string | null> {\n\treturn sql`avg(${expression})`.mapWith(String);\n}\n\n/**\n * Returns the average (arithmetic mean) of all non-null and non-duplicate values in `expression`.\n *\n * ## Examples\n *\n * ```ts\n * // Average salary of an employee where `salary` is distinct\n * db.select({ value: avgDistinct(employees.salary) }).from(employees)\n * ```\n *\n * @see avg to get the average of all non-null values in `expression`, including duplicates\n */\nexport function avgDistinct(expression: SQLWrapper): SQL<string | null> {\n\treturn sql`avg(distinct ${expression})`.mapWith(String);\n}\n\n/**\n * Returns the sum of all non-null values in `expression`.\n *\n * ## Examples\n *\n * ```ts\n * // Sum of every employee's salary\n * db.select({ value: sum(employees.salary) }).from(employees)\n * ```\n *\n * @see sumDistinct to get the sum of all non-null and non-duplicate values in `expression`\n */\nexport function sum(expression: SQLWrapper): SQL<string | null> {\n\treturn sql`sum(${expression})`.mapWith(String);\n}\n\n/**\n * Returns the sum of all non-null and non-duplicate values in `expression`.\n *\n * ## Examples\n *\n * ```ts\n * // Sum of every employee's salary where `salary` is distinct (no duplicates)\n * db.select({ value: sumDistinct(employees.salary) }).from(employees)\n * ```\n *\n * @see sum to get the sum of all non-null values in `expression`, including duplicates\n */\nexport function sumDistinct(expression: SQLWrapper): SQL<string | null> {\n\treturn sql`sum(distinct ${expression})`.mapWith(String);\n}\n\n/**\n * Returns the maximum value in `expression`.\n *\n * ## Examples\n *\n * ```ts\n * // The employee with the highest salary\n * db.select({ value: max(employees.salary) }).from(employees)\n * ```\n */\nexport function max<T extends SQLWrapper>(expression: T): SQL<(T extends AnyColumn ? T['_']['data'] : string) | null> {\n\treturn sql`max(${expression})`.mapWith(is(expression, Column) ? expression : String) as any;\n}\n\n/**\n * Returns the minimum value in `expression`.\n *\n * ## Examples\n *\n * ```ts\n * // The employee with the lowest salary\n * db.select({ value: min(employees.salary) }).from(employees)\n * ```\n */\nexport function min<T extends SQLWrapper>(expression: T): SQL<(T extends AnyColumn ? T['_']['data'] : string) | null> {\n\treturn sql`min(${expression})`.mapWith(is(expression, Column) ? expression : String) as any;\n}\n","import type { AnyColumn } from '~/column.ts';\nimport type { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport { type SQL, sql, type SQLWrapper } from '../sql.ts';\n\nfunction toSql(value: number[] | string[]): string {\n\treturn JSON.stringify(value);\n}\n\n/**\n * Used in sorting and in querying, if used in sorting,\n * this specifies that the given column or expression should be sorted in an order\n * that minimizes the L2 distance to the given value.\n * If used in querying, this specifies that it should return the L2 distance\n * between the given column or expression and the given value.\n *\n * ## Examples\n *\n * ```ts\n * // Sort cars by embedding similarity\n * // to the given embedding\n * db.select().from(cars)\n * .orderBy(l2Distance(cars.embedding, embedding));\n * ```\n *\n * ```ts\n * // Select distance of cars and embedding\n * // to the given embedding\n * db.select({distance: l2Distance(cars.embedding, embedding)}).from(cars)\n * ```\n */\nexport function l2Distance(\n\tcolumn: SQLWrapper | AnyColumn,\n\tvalue: number[] | string[] | TypedQueryBuilder<any> | string,\n): SQL {\n\tif (Array.isArray(value)) {\n\t\treturn sql`${column} <-> ${toSql(value)}`;\n\t}\n\treturn sql`${column} <-> ${value}`;\n}\n\n/**\n * L1 distance is one of the possible distance measures between two probability distribution vectors and it is\n * calculated as the sum of the absolute differences.\n * The smaller the distance between the observed probability vectors, the higher the accuracy of the synthetic data\n *\n * ## Examples\n *\n * ```ts\n * // Sort cars by embedding similarity\n * // to the given embedding\n * db.select().from(cars)\n * .orderBy(l1Distance(cars.embedding, embedding));\n * ```\n *\n * ```ts\n * // Select distance of cars and embedding\n * // to the given embedding\n * db.select({distance: l1Distance(cars.embedding, embedding)}).from(cars)\n * ```\n */\nexport function l1Distance(\n\tcolumn: SQLWrapper | AnyColumn,\n\tvalue: number[] | string[] | TypedQueryBuilder<any> | string,\n): SQL {\n\tif (Array.isArray(value)) {\n\t\treturn sql`${column} <+> ${toSql(value)}`;\n\t}\n\treturn sql`${column} <+> ${value}`;\n}\n\n/**\n * Used in sorting and in querying, if used in sorting,\n * this specifies that the given column or expression should be sorted in an order\n * that minimizes the inner product distance to the given value.\n * If used in querying, this specifies that it should return the inner product distance\n * between the given column or expression and the given value.\n *\n * ## Examples\n *\n * ```ts\n * // Sort cars by embedding similarity\n * // to the given embedding\n * db.select().from(cars)\n * .orderBy(innerProduct(cars.embedding, embedding));\n * ```\n *\n * ```ts\n * // Select distance of cars and embedding\n * // to the given embedding\n * db.select({ distance: innerProduct(cars.embedding, embedding) }).from(cars)\n * ```\n */\nexport function innerProduct(\n\tcolumn: SQLWrapper | AnyColumn,\n\tvalue: number[] | string[] | TypedQueryBuilder<any> | string,\n): SQL {\n\tif (Array.isArray(value)) {\n\t\treturn sql`${column} <#> ${toSql(value)}`;\n\t}\n\treturn sql`${column} <#> ${value}`;\n}\n\n/**\n * Used in sorting and in querying, if used in sorting,\n * this specifies that the given column or expression should be sorted in an order\n * that minimizes the cosine distance to the given value.\n * If used in querying, this specifies that it should return the cosine distance\n * between the given column or expression and the given value.\n *\n * ## Examples\n *\n * ```ts\n * // Sort cars by embedding similarity\n * // to the given embedding\n * db.select().from(cars)\n * .orderBy(cosineDistance(cars.embedding, embedding));\n * ```\n *\n * ```ts\n * // Select distance of cars and embedding\n * // to the given embedding\n * db.select({distance: cosineDistance(cars.embedding, embedding)}).from(cars)\n * ```\n */\nexport function cosineDistance(\n\tcolumn: SQLWrapper | AnyColumn,\n\tvalue: number[] | string[] | TypedQueryBuilder<any> | string,\n): SQL {\n\tif (Array.isArray(value)) {\n\t\treturn sql`${column} <=> ${toSql(value)}`;\n\t}\n\treturn sql`${column} <=> ${value}`;\n}\n\n/**\n * Hamming distance between two strings or vectors of equal length is the number of positions at which the\n * corresponding symbols are different. In other words, it measures the minimum number of\n * substitutions required to change one string into the other, or equivalently,\n * the minimum number of errors that could have transformed one string into the other\n *\n * ## Examples\n *\n * ```ts\n * // Sort cars by embedding similarity\n * // to the given embedding\n * db.select().from(cars)\n * .orderBy(hammingDistance(cars.embedding, embedding));\n * ```\n */\nexport function hammingDistance(\n\tcolumn: SQLWrapper | AnyColumn,\n\tvalue: number[] | string[] | TypedQueryBuilder<any> | string,\n): SQL {\n\tif (Array.isArray(value)) {\n\t\treturn sql`${column} <~> ${toSql(value)}`;\n\t}\n\treturn sql`${column} <~> ${value}`;\n}\n\n/**\n * ## Examples\n *\n * ```ts\n * // Sort cars by embedding similarity\n * // to the given embedding\n * db.select().from(cars)\n * .orderBy(jaccardDistance(cars.embedding, embedding));\n * ```\n */\nexport function jaccardDistance(\n\tcolumn: SQLWrapper | AnyColumn,\n\tvalue: number[] | string[] | TypedQueryBuilder<any> | string,\n): SQL {\n\tif (Array.isArray(value)) {\n\t\treturn sql`${column} <%> ${toSql(value)}`;\n\t}\n\treturn sql`${column} <%> ${value}`;\n}\n","export * from './aggregate.ts';\nexport * from './vector.ts';\n","export * from './expressions/index.ts';\nexport * from './functions/index.ts';\nexport * from './sql.ts';\n","export * from './blob.ts';\nexport * from './common.ts';\nexport * from './custom.ts';\nexport * from './integer.ts';\nexport * from './numeric.ts';\nexport * from './real.ts';\nexport * from './text.ts';\n","import { entityKind } from '~/entity.ts';\nimport type { ColumnsSelection } from '~/sql/sql.ts';\nimport { View } from '~/sql/sql.ts';\n\nexport abstract class SQLiteViewBase<\n\tTName extends string = string,\n\tTExisting extends boolean = boolean,\n\tTSelection extends ColumnsSelection = ColumnsSelection,\n> extends View<TName, TExisting, TSelection> {\n\tstatic override readonly [entityKind]: string = 'SQLiteViewBase';\n\n\tdeclare _: View<TName, TExisting, TSelection>['_'] & {\n\t\tviewBrand: 'SQLiteView';\n\t};\n}\n","import { aliasedTable, aliasedTableColumn, mapColumnsInAliasedSQLToAlias, mapColumnsInSQLToAlias } from '~/alias.ts';\nimport { CasingCache } from '~/casing.ts';\nimport type { AnyColumn } from '~/column.ts';\nimport { Column } from '~/column.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { DrizzleError } from '~/errors.ts';\nimport type { MigrationConfig, MigrationMeta } from '~/migrator.ts';\nimport {\n\ttype BuildRelationalQueryResult,\n\ttype DBQueryConfig,\n\tgetOperators,\n\tgetOrderByOperators,\n\tMany,\n\tnormalizeRelation,\n\tOne,\n\ttype Relation,\n\ttype TableRelationalConfig,\n\ttype TablesRelationalConfig,\n} from '~/relations.ts';\nimport type { Name, Placeholder } from '~/sql/index.ts';\nimport { and, eq } from '~/sql/index.ts';\nimport { Param, type QueryWithTypings, SQL, sql, type SQLChunk } from '~/sql/sql.ts';\nimport { SQLiteColumn } from '~/sqlite-core/columns/index.ts';\nimport type {\n\tAnySQLiteSelectQueryBuilder,\n\tSQLiteDeleteConfig,\n\tSQLiteInsertConfig,\n\tSQLiteUpdateConfig,\n} from '~/sqlite-core/query-builders/index.ts';\nimport { SQLiteTable } from '~/sqlite-core/table.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { getTableName, getTableUniqueName, Table } from '~/table.ts';\nimport { type Casing, orderSelectedFields, type UpdateSet } from '~/utils.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport type {\n\tSelectedFieldsOrdered,\n\tSQLiteSelectConfig,\n\tSQLiteSelectJoinConfig,\n} from './query-builders/select.types.ts';\nimport type { SQLiteSession } from './session.ts';\nimport { SQLiteViewBase } from './view-base.ts';\n\nexport interface SQLiteDialectConfig {\n\tcasing?: Casing;\n}\n\nexport abstract class SQLiteDialect {\n\tstatic readonly [entityKind]: string = 'SQLiteDialect';\n\n\t/** @internal */\n\treadonly casing: CasingCache;\n\n\tconstructor(config?: SQLiteDialectConfig) {\n\t\tthis.casing = new CasingCache(config?.casing);\n\t}\n\n\tescapeName(name: string): string {\n\t\treturn `\"${name.replace(/\"/g, '\"\"')}\"`;\n\t}\n\n\tescapeParam(_num: number): string {\n\t\treturn '?';\n\t}\n\n\tescapeString(str: string): string {\n\t\treturn `'${str.replace(/'/g, \"''\")}'`;\n\t}\n\n\tprivate buildWithCTE(queries: Subquery[] | undefined): SQL | undefined {\n\t\tif (!queries?.length) return undefined;\n\n\t\tconst withSqlChunks = [sql`with `];\n\t\tfor (const [i, w] of queries.entries()) {\n\t\t\twithSqlChunks.push(sql`${sql.identifier(w._.alias)} as (${w._.sql})`);\n\t\t\tif (i < queries.length - 1) {\n\t\t\t\twithSqlChunks.push(sql`, `);\n\t\t\t}\n\t\t}\n\t\twithSqlChunks.push(sql` `);\n\t\treturn sql.join(withSqlChunks);\n\t}\n\n\tbuildDeleteQuery({\n\t\ttable,\n\t\twhere,\n\t\treturning,\n\t\twithList,\n\t\tlimit,\n\t\torderBy,\n\t}: SQLiteDeleteConfig): SQL {\n\t\tconst withSql = this.buildWithCTE(withList);\n\n\t\tconst returningSql = returning\n\t\t\t? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}`\n\t\t\t: undefined;\n\n\t\tconst whereSql = where ? sql` where ${where}` : undefined;\n\n\t\tconst orderBySql = this.buildOrderBy(orderBy);\n\n\t\tconst limitSql = this.buildLimit(limit);\n\n\t\treturn sql`${withSql}delete from ${table}${whereSql}${returningSql}${orderBySql}${limitSql}`;\n\t}\n\n\tbuildUpdateSet(table: SQLiteTable, set: UpdateSet): SQL {\n\t\tconst tableColumns = table[Table.Symbol.Columns];\n\n\t\tconst columnNames = Object.keys(tableColumns).filter(\n\t\t\t(colName) =>\n\t\t\t\tset[colName] !== undefined\n\t\t\t\t|| tableColumns[colName]?.onUpdateFn !== undefined,\n\t\t);\n\n\t\tconst setSize = columnNames.length;\n\t\treturn sql.join(\n\t\t\tcolumnNames.flatMap((colName, i) => {\n\t\t\t\tconst col = tableColumns[colName]!;\n\n\t\t\t\tconst onUpdateFnResult = col.onUpdateFn?.();\n\t\t\t\tconst value = set[colName]\n\t\t\t\t\t?? (is(onUpdateFnResult, SQL)\n\t\t\t\t\t\t? onUpdateFnResult\n\t\t\t\t\t\t: sql.param(onUpdateFnResult, col));\n\t\t\t\tconst res = sql`${sql.identifier(this.casing.getColumnCasing(col))} = ${value}`;\n\n\t\t\t\tif (i < setSize - 1) {\n\t\t\t\t\treturn [res, sql.raw(', ')];\n\t\t\t\t}\n\t\t\t\treturn [res];\n\t\t\t}),\n\t\t);\n\t}\n\n\tbuildUpdateQuery({\n\t\ttable,\n\t\tset,\n\t\twhere,\n\t\treturning,\n\t\twithList,\n\t\tjoins,\n\t\tfrom,\n\t\tlimit,\n\t\torderBy,\n\t}: SQLiteUpdateConfig): SQL {\n\t\tconst withSql = this.buildWithCTE(withList);\n\n\t\tconst setSql = this.buildUpdateSet(table, set);\n\n\t\tconst fromSql = from && sql.join([sql.raw(' from '), this.buildFromTable(from)]);\n\n\t\tconst joinsSql = this.buildJoins(joins);\n\n\t\tconst returningSql = returning\n\t\t\t? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}`\n\t\t\t: undefined;\n\n\t\tconst whereSql = where ? sql` where ${where}` : undefined;\n\n\t\tconst orderBySql = this.buildOrderBy(orderBy);\n\n\t\tconst limitSql = this.buildLimit(limit);\n\n\t\treturn sql`${withSql}update ${table} set ${setSql}${fromSql}${joinsSql}${whereSql}${returningSql}${orderBySql}${limitSql}`;\n\t}\n\n\t/**\n\t * Builds selection SQL with provided fields/expressions\n\t *\n\t * Examples:\n\t *\n\t * `select <selection> from`\n\t *\n\t * `insert ... returning <selection>`\n\t *\n\t * If `isSingleTable` is true, then columns won't be prefixed with table name\n\t */\n\tprivate buildSelection(\n\t\tfields: SelectedFieldsOrdered,\n\t\t{ isSingleTable = false }: { isSingleTable?: boolean } = {},\n\t): SQL {\n\t\tconst columnsLen = fields.length;\n\n\t\tconst chunks = fields.flatMap(({ field }, i) => {\n\t\t\tconst chunk: SQLChunk[] = [];\n\n\t\t\tif (is(field, SQL.Aliased) && field.isSelectionField) {\n\t\t\t\tchunk.push(sql.identifier(field.fieldAlias));\n\t\t\t} else if (is(field, SQL.Aliased) || is(field, SQL)) {\n\t\t\t\tconst query = is(field, SQL.Aliased) ? field.sql : field;\n\n\t\t\t\tif (isSingleTable) {\n\t\t\t\t\tchunk.push(\n\t\t\t\t\t\tnew SQL(\n\t\t\t\t\t\t\tquery.queryChunks.map((c) => {\n\t\t\t\t\t\t\t\tif (is(c, Column)) {\n\t\t\t\t\t\t\t\t\treturn sql.identifier(this.casing.getColumnCasing(c));\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\treturn c;\n\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t),\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\tchunk.push(query);\n\t\t\t\t}\n\n\t\t\t\tif (is(field, SQL.Aliased)) {\n\t\t\t\t\tchunk.push(sql` as ${sql.identifier(field.fieldAlias)}`);\n\t\t\t\t}\n\t\t\t} else if (is(field, Column)) {\n\t\t\t\tconst tableName = field.table[Table.Symbol.Name];\n\t\t\t\tif (field.columnType === 'SQLiteNumericBigInt') {\n\t\t\t\t\tif (isSingleTable) {\n\t\t\t\t\t\tchunk.push(\n\t\t\t\t\t\t\tsql`cast(${sql.identifier(this.casing.getColumnCasing(field))} as text)`,\n\t\t\t\t\t\t);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tchunk.push(\n\t\t\t\t\t\t\tsql`cast(${sql.identifier(tableName)}.${sql.identifier(this.casing.getColumnCasing(field))} as text)`,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tif (isSingleTable) {\n\t\t\t\t\t\tchunk.push(sql.identifier(this.casing.getColumnCasing(field)));\n\t\t\t\t\t} else {\n\t\t\t\t\t\tchunk.push(\n\t\t\t\t\t\t\tsql`${sql.identifier(tableName)}.${sql.identifier(this.casing.getColumnCasing(field))}`,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else if (is(field, Subquery)) {\n\t\t\t\tconst entries = Object.entries(field._.selectedFields) as [\n\t\t\t\t\tstring,\n\t\t\t\t\tSQL.Aliased | Column | SQL,\n\t\t\t\t][];\n\n\t\t\t\tif (entries.length === 1) {\n\t\t\t\t\tconst entry = entries[0]![1];\n\n\t\t\t\t\tconst fieldDecoder = is(entry, SQL)\n\t\t\t\t\t\t? entry.decoder\n\t\t\t\t\t\t: is(entry, Column)\n\t\t\t\t\t\t? { mapFromDriverValue: (v: any) => entry.mapFromDriverValue(v) }\n\t\t\t\t\t\t: entry.sql.decoder;\n\t\t\t\t\tif (fieldDecoder) field._.sql.decoder = fieldDecoder;\n\t\t\t\t}\n\t\t\t\tchunk.push(field);\n\t\t\t}\n\n\t\t\tif (i < columnsLen - 1) {\n\t\t\t\tchunk.push(sql`, `);\n\t\t\t}\n\n\t\t\treturn chunk;\n\t\t});\n\n\t\treturn sql.join(chunks);\n\t}\n\n\tprivate buildJoins(\n\t\tjoins: SQLiteSelectJoinConfig[] | undefined,\n\t): SQL | undefined {\n\t\tif (!joins || joins.length === 0) {\n\t\t\treturn undefined;\n\t\t}\n\n\t\tconst joinsArray: SQL[] = [];\n\n\t\tif (joins) {\n\t\t\tfor (const [index, joinMeta] of joins.entries()) {\n\t\t\t\tif (index === 0) {\n\t\t\t\t\tjoinsArray.push(sql` `);\n\t\t\t\t}\n\t\t\t\tconst table = joinMeta.table;\n\t\t\t\tconst onSql = joinMeta.on ? sql` on ${joinMeta.on}` : undefined;\n\n\t\t\t\tif (is(table, SQLiteTable)) {\n\t\t\t\t\tconst tableName = table[SQLiteTable.Symbol.Name];\n\t\t\t\t\tconst tableSchema = table[SQLiteTable.Symbol.Schema];\n\t\t\t\t\tconst origTableName = table[SQLiteTable.Symbol.OriginalName];\n\t\t\t\t\tconst alias = tableName === origTableName ? undefined : joinMeta.alias;\n\t\t\t\t\tjoinsArray.push(\n\t\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join ${tableSchema ? sql`${sql.identifier(tableSchema)}.` : undefined}${\n\t\t\t\t\t\t\tsql.identifier(\n\t\t\t\t\t\t\t\torigTableName,\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t}${alias && sql` ${sql.identifier(alias)}`}${onSql}`,\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\tjoinsArray.push(\n\t\t\t\t\t\tsql`${sql.raw(joinMeta.joinType)} join ${table}${onSql}`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\tif (index < joins.length - 1) {\n\t\t\t\t\tjoinsArray.push(sql` `);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn sql.join(joinsArray);\n\t}\n\n\tprivate buildLimit(limit: number | Placeholder | undefined): SQL | undefined {\n\t\treturn typeof limit === 'object'\n\t\t\t\t|| (typeof limit === 'number' && limit >= 0)\n\t\t\t? sql` limit ${limit}`\n\t\t\t: undefined;\n\t}\n\n\tprivate buildOrderBy(\n\t\torderBy: (SQLiteColumn | SQL | SQL.Aliased)[] | undefined,\n\t): SQL | undefined {\n\t\tconst orderByList: (SQLiteColumn | SQL | SQL.Aliased)[] = [];\n\n\t\tif (orderBy) {\n\t\t\tfor (const [index, orderByValue] of orderBy.entries()) {\n\t\t\t\torderByList.push(orderByValue);\n\n\t\t\t\tif (index < orderBy.length - 1) {\n\t\t\t\t\torderByList.push(sql`, `);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn orderByList.length > 0\n\t\t\t? sql` order by ${sql.join(orderByList)}`\n\t\t\t: undefined;\n\t}\n\n\tprivate buildFromTable(\n\t\ttable: SQL | Subquery | SQLiteViewBase | SQLiteTable | undefined,\n\t): SQL | Subquery | SQLiteViewBase | SQLiteTable | undefined {\n\t\tif (is(table, Table) && table[Table.Symbol.IsAlias]) {\n\t\t\treturn sql`${sql`${sql.identifier(table[Table.Symbol.Schema] ?? '')}.`.if(table[Table.Symbol.Schema])}${\n\t\t\t\tsql.identifier(\n\t\t\t\t\ttable[Table.Symbol.OriginalName],\n\t\t\t\t)\n\t\t\t} ${sql.identifier(table[Table.Symbol.Name])}`;\n\t\t}\n\n\t\treturn table;\n\t}\n\n\tbuildSelectQuery({\n\t\twithList,\n\t\tfields,\n\t\tfieldsFlat,\n\t\twhere,\n\t\thaving,\n\t\ttable,\n\t\tjoins,\n\t\torderBy,\n\t\tgroupBy,\n\t\tlimit,\n\t\toffset,\n\t\tdistinct,\n\t\tsetOperators,\n\t}: SQLiteSelectConfig): SQL {\n\t\tconst fieldsList = fieldsFlat ?? orderSelectedFields<SQLiteColumn>(fields);\n\t\tfor (const f of fieldsList) {\n\t\t\tif (\n\t\t\t\tis(f.field, Column)\n\t\t\t\t&& getTableName(f.field.table)\n\t\t\t\t\t!== (is(table, Subquery)\n\t\t\t\t\t\t? table._.alias\n\t\t\t\t\t\t: is(table, SQLiteViewBase)\n\t\t\t\t\t\t? table[ViewBaseConfig].name\n\t\t\t\t\t\t: is(table, SQL)\n\t\t\t\t\t\t? undefined\n\t\t\t\t\t\t: getTableName(table))\n\t\t\t\t&& !((table) =>\n\t\t\t\t\tjoins?.some(\n\t\t\t\t\t\t({ alias }) =>\n\t\t\t\t\t\t\talias\n\t\t\t\t\t\t\t\t=== (table[Table.Symbol.IsAlias]\n\t\t\t\t\t\t\t\t\t? getTableName(table)\n\t\t\t\t\t\t\t\t\t: table[Table.Symbol.BaseName]),\n\t\t\t\t\t))(f.field.table)\n\t\t\t) {\n\t\t\t\tconst tableName = getTableName(f.field.table);\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`Your \"${\n\t\t\t\t\t\tf.path.join(\n\t\t\t\t\t\t\t'->',\n\t\t\t\t\t\t)\n\t\t\t\t\t}\" field references a column \"${tableName}\".\"${f.field.name}\", but the table \"${tableName}\" is not part of the query! Did you forget to join it?`,\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\n\t\tconst isSingleTable = !joins || joins.length === 0;\n\n\t\tconst withSql = this.buildWithCTE(withList);\n\n\t\tconst distinctSql = distinct ? sql` distinct` : undefined;\n\n\t\tconst selection = this.buildSelection(fieldsList, { isSingleTable });\n\n\t\tconst tableSql = this.buildFromTable(table);\n\n\t\tconst joinsSql = this.buildJoins(joins);\n\n\t\tconst whereSql = where ? sql` where ${where}` : undefined;\n\n\t\tconst havingSql = having ? sql` having ${having}` : undefined;\n\n\t\tconst groupByList: (SQL | AnyColumn | SQL.Aliased)[] = [];\n\t\tif (groupBy) {\n\t\t\tfor (const [index, groupByValue] of groupBy.entries()) {\n\t\t\t\tgroupByList.push(groupByValue);\n\n\t\t\t\tif (index < groupBy.length - 1) {\n\t\t\t\t\tgroupByList.push(sql`, `);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tconst groupBySql = groupByList.length > 0\n\t\t\t? sql` group by ${sql.join(groupByList)}`\n\t\t\t: undefined;\n\n\t\tconst orderBySql = this.buildOrderBy(orderBy);\n\n\t\tconst limitSql = this.buildLimit(limit);\n\n\t\tconst offsetSql = offset ? sql` offset ${offset}` : undefined;\n\n\t\tconst finalQuery =\n\t\t\tsql`${withSql}select${distinctSql} ${selection} from ${tableSql}${joinsSql}${whereSql}${groupBySql}${havingSql}${orderBySql}${limitSql}${offsetSql}`;\n\n\t\tif (setOperators.length > 0) {\n\t\t\treturn this.buildSetOperations(finalQuery, setOperators);\n\t\t}\n\n\t\treturn finalQuery;\n\t}\n\n\tbuildSetOperations(\n\t\tleftSelect: SQL,\n\t\tsetOperators: SQLiteSelectConfig['setOperators'],\n\t): SQL {\n\t\tconst [setOperator, ...rest] = setOperators;\n\n\t\tif (!setOperator) {\n\t\t\tthrow new Error('Cannot pass undefined values to any set operator');\n\t\t}\n\n\t\tif (rest.length === 0) {\n\t\t\treturn this.buildSetOperationQuery({ leftSelect, setOperator });\n\t\t}\n\n\t\t// Some recursive magic here\n\t\treturn this.buildSetOperations(\n\t\t\tthis.buildSetOperationQuery({ leftSelect, setOperator }),\n\t\t\trest,\n\t\t);\n\t}\n\n\tbuildSetOperationQuery({\n\t\tleftSelect,\n\t\tsetOperator: { type, isAll, rightSelect, limit, orderBy, offset },\n\t}: {\n\t\tleftSelect: SQL;\n\t\tsetOperator: SQLiteSelectConfig['setOperators'][number];\n\t}): SQL {\n\t\t// SQLite doesn't support parenthesis in set operations\n\t\tconst leftChunk = sql`${leftSelect.getSQL()} `;\n\t\tconst rightChunk = sql`${rightSelect.getSQL()}`;\n\n\t\tlet orderBySql;\n\t\tif (orderBy && orderBy.length > 0) {\n\t\t\tconst orderByValues: (SQL<unknown> | Name)[] = [];\n\n\t\t\t// The next bit is necessary because the sql operator replaces ${table.column} with `table`.`column`\n\t\t\t// which is invalid Sql syntax, Table from one of the SELECTs cannot be used in global ORDER clause\n\t\t\tfor (const singleOrderBy of orderBy) {\n\t\t\t\tif (is(singleOrderBy, SQLiteColumn)) {\n\t\t\t\t\torderByValues.push(sql.identifier(singleOrderBy.name));\n\t\t\t\t} else if (is(singleOrderBy, SQL)) {\n\t\t\t\t\tfor (let i = 0; i < singleOrderBy.queryChunks.length; i++) {\n\t\t\t\t\t\tconst chunk = singleOrderBy.queryChunks[i];\n\n\t\t\t\t\t\tif (is(chunk, SQLiteColumn)) {\n\t\t\t\t\t\t\tsingleOrderBy.queryChunks[i] = sql.identifier(\n\t\t\t\t\t\t\t\tthis.casing.getColumnCasing(chunk),\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\torderByValues.push(sql`${singleOrderBy}`);\n\t\t\t\t} else {\n\t\t\t\t\torderByValues.push(sql`${singleOrderBy}`);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\torderBySql = sql` order by ${sql.join(orderByValues, sql`, `)}`;\n\t\t}\n\n\t\tconst limitSql = typeof limit === 'object' || (typeof limit === 'number' && limit >= 0)\n\t\t\t? sql` limit ${limit}`\n\t\t\t: undefined;\n\n\t\tconst operatorChunk = sql.raw(`${type} ${isAll ? 'all ' : ''}`);\n\n\t\tconst offsetSql = offset ? sql` offset ${offset}` : undefined;\n\n\t\treturn sql`${leftChunk}${operatorChunk}${rightChunk}${orderBySql}${limitSql}${offsetSql}`;\n\t}\n\n\tbuildInsertQuery({\n\t\ttable,\n\t\tvalues: valuesOrSelect,\n\t\tonConflict,\n\t\treturning,\n\t\twithList,\n\t\tselect,\n\t}: SQLiteInsertConfig): SQL {\n\t\t// const isSingleValue = values.length === 1;\n\t\tconst valuesSqlList: ((SQLChunk | SQL)[] | SQL)[] = [];\n\t\tconst columns: Record<string, SQLiteColumn> = table[Table.Symbol.Columns];\n\n\t\tconst colEntries: [string, SQLiteColumn][] = Object.entries(columns).filter(\n\t\t\t([_, col]) => !col.shouldDisableInsert(),\n\t\t);\n\t\tconst insertOrder = colEntries.map(([, column]) => sql.identifier(this.casing.getColumnCasing(column)));\n\n\t\tif (select) {\n\t\t\tconst select = valuesOrSelect as AnySQLiteSelectQueryBuilder | SQL;\n\n\t\t\tif (is(select, SQL)) {\n\t\t\t\tvaluesSqlList.push(select);\n\t\t\t} else {\n\t\t\t\tvaluesSqlList.push(select.getSQL());\n\t\t\t}\n\t\t} else {\n\t\t\tconst values = valuesOrSelect as Record<string, Param | SQL>[];\n\t\t\tvaluesSqlList.push(sql.raw('values '));\n\n\t\t\tfor (const [valueIndex, value] of values.entries()) {\n\t\t\t\tconst valueList: (SQLChunk | SQL)[] = [];\n\t\t\t\tfor (const [fieldName, col] of colEntries) {\n\t\t\t\t\tconst colValue = value[fieldName];\n\t\t\t\t\tif (\n\t\t\t\t\t\tcolValue === undefined\n\t\t\t\t\t\t|| (is(colValue, Param) && colValue.value === undefined)\n\t\t\t\t\t) {\n\t\t\t\t\t\tlet defaultValue;\n\t\t\t\t\t\tif (col.default !== null && col.default !== undefined) {\n\t\t\t\t\t\t\tdefaultValue = is(col.default, SQL)\n\t\t\t\t\t\t\t\t? col.default\n\t\t\t\t\t\t\t\t: sql.param(col.default, col);\n\t\t\t\t\t\t\t// eslint-disable-next-line unicorn/no-negated-condition\n\t\t\t\t\t\t} else if (col.defaultFn !== undefined) {\n\t\t\t\t\t\t\tconst defaultFnResult = col.defaultFn();\n\t\t\t\t\t\t\tdefaultValue = is(defaultFnResult, SQL)\n\t\t\t\t\t\t\t\t? defaultFnResult\n\t\t\t\t\t\t\t\t: sql.param(defaultFnResult, col);\n\t\t\t\t\t\t\t// eslint-disable-next-line unicorn/no-negated-condition\n\t\t\t\t\t\t} else if (!col.default && col.onUpdateFn !== undefined) {\n\t\t\t\t\t\t\tconst onUpdateFnResult = col.onUpdateFn();\n\t\t\t\t\t\t\tdefaultValue = is(onUpdateFnResult, SQL)\n\t\t\t\t\t\t\t\t? onUpdateFnResult\n\t\t\t\t\t\t\t\t: sql.param(onUpdateFnResult, col);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tdefaultValue = sql`null`;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tvalueList.push(defaultValue);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvalueList.push(colValue);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tvaluesSqlList.push(valueList);\n\t\t\t\tif (valueIndex < values.length - 1) {\n\t\t\t\t\tvaluesSqlList.push(sql`, `);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tconst withSql = this.buildWithCTE(withList);\n\n\t\tconst valuesSql = sql.join(valuesSqlList);\n\n\t\tconst returningSql = returning\n\t\t\t? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}`\n\t\t\t: undefined;\n\n\t\tconst onConflictSql = onConflict?.length ? sql.join(onConflict) : undefined;\n\n\t\t// if (isSingleValue && valuesSqlList.length === 0){\n\t\t// \treturn sql`insert into ${table} default values ${onConflictSql}${returningSql}`;\n\t\t// }\n\n\t\treturn sql`${withSql}insert into ${table} ${insertOrder} ${valuesSql}${onConflictSql}${returningSql}`;\n\t}\n\n\tsqlToQuery(sql: SQL, invokeSource?: 'indexes' | undefined): QueryWithTypings {\n\t\treturn sql.toQuery({\n\t\t\tcasing: this.casing,\n\t\t\tescapeName: this.escapeName,\n\t\t\tescapeParam: this.escapeParam,\n\t\t\tescapeString: this.escapeString,\n\t\t\tinvokeSource,\n\t\t});\n\t}\n\n\tbuildRelationalQuery({\n\t\tfullSchema,\n\t\tschema,\n\t\ttableNamesMap,\n\t\ttable,\n\t\ttableConfig,\n\t\tqueryConfig: config,\n\t\ttableAlias,\n\t\tnestedQueryRelation,\n\t\tjoinOn,\n\t}: {\n\t\tfullSchema: Record<string, unknown>;\n\t\tschema: TablesRelationalConfig;\n\t\ttableNamesMap: Record<string, string>;\n\t\ttable: SQLiteTable;\n\t\ttableConfig: TableRelationalConfig;\n\t\tqueryConfig: true | DBQueryConfig<'many', true>;\n\t\ttableAlias: string;\n\t\tnestedQueryRelation?: Relation;\n\t\tjoinOn?: SQL;\n\t}): BuildRelationalQueryResult<SQLiteTable, SQLiteColumn> {\n\t\tlet selection: BuildRelationalQueryResult<\n\t\t\tSQLiteTable,\n\t\t\tSQLiteColumn\n\t\t>['selection'] = [];\n\t\tlet limit,\n\t\t\toffset,\n\t\t\torderBy: SQLiteSelectConfig['orderBy'] = [],\n\t\t\twhere;\n\t\tconst joins: SQLiteSelectJoinConfig[] = [];\n\n\t\tif (config === true) {\n\t\t\tconst selectionEntries = Object.entries(tableConfig.columns);\n\t\t\tselection = selectionEntries.map(([key, value]) => ({\n\t\t\t\tdbKey: value.name,\n\t\t\t\ttsKey: key,\n\t\t\t\tfield: aliasedTableColumn(value as SQLiteColumn, tableAlias),\n\t\t\t\trelationTableTsKey: undefined,\n\t\t\t\tisJson: false,\n\t\t\t\tselection: [],\n\t\t\t}));\n\t\t} else {\n\t\t\tconst aliasedColumns = Object.fromEntries(\n\t\t\t\tObject.entries(tableConfig.columns).map(([key, value]) => [\n\t\t\t\t\tkey,\n\t\t\t\t\taliasedTableColumn(value, tableAlias),\n\t\t\t\t]),\n\t\t\t);\n\n\t\t\tif (config.where) {\n\t\t\t\tconst whereSql = typeof config.where === 'function'\n\t\t\t\t\t? config.where(aliasedColumns, getOperators())\n\t\t\t\t\t: config.where;\n\t\t\t\twhere = whereSql && mapColumnsInSQLToAlias(whereSql, tableAlias);\n\t\t\t}\n\n\t\t\tconst fieldsSelection: {\n\t\t\t\ttsKey: string;\n\t\t\t\tvalue: SQLiteColumn | SQL.Aliased;\n\t\t\t}[] = [];\n\t\t\tlet selectedColumns: string[] = [];\n\n\t\t\t// Figure out which columns to select\n\t\t\tif (config.columns) {\n\t\t\t\tlet isIncludeMode = false;\n\n\t\t\t\tfor (const [field, value] of Object.entries(config.columns)) {\n\t\t\t\t\tif (value === undefined) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (field in tableConfig.columns) {\n\t\t\t\t\t\tif (!isIncludeMode && value === true) {\n\t\t\t\t\t\t\tisIncludeMode = true;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tselectedColumns.push(field);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (selectedColumns.length > 0) {\n\t\t\t\t\tselectedColumns = isIncludeMode\n\t\t\t\t\t\t? selectedColumns.filter((c) => config.columns?.[c] === true)\n\t\t\t\t\t\t: Object.keys(tableConfig.columns).filter(\n\t\t\t\t\t\t\t(key) => !selectedColumns.includes(key),\n\t\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Select all columns if selection is not specified\n\t\t\t\tselectedColumns = Object.keys(tableConfig.columns);\n\t\t\t}\n\n\t\t\tfor (const field of selectedColumns) {\n\t\t\t\tconst column = tableConfig.columns[field]! as SQLiteColumn;\n\t\t\t\tfieldsSelection.push({ tsKey: field, value: column });\n\t\t\t}\n\n\t\t\tlet selectedRelations: {\n\t\t\t\ttsKey: string;\n\t\t\t\tqueryConfig: true | DBQueryConfig<'many', false>;\n\t\t\t\trelation: Relation;\n\t\t\t}[] = [];\n\n\t\t\t// Figure out which relations to select\n\t\t\tif (config.with) {\n\t\t\t\tselectedRelations = Object.entries(config.with)\n\t\t\t\t\t.filter(\n\t\t\t\t\t\t(\n\t\t\t\t\t\t\tentry,\n\t\t\t\t\t\t): entry is [(typeof entry)[0], NonNullable<(typeof entry)[1]>] => !!entry[1],\n\t\t\t\t\t)\n\t\t\t\t\t.map(([tsKey, queryConfig]) => ({\n\t\t\t\t\t\ttsKey,\n\t\t\t\t\t\tqueryConfig,\n\t\t\t\t\t\trelation: tableConfig.relations[tsKey]!,\n\t\t\t\t\t}));\n\t\t\t}\n\n\t\t\tlet extras;\n\n\t\t\t// Figure out which extras to select\n\t\t\tif (config.extras) {\n\t\t\t\textras = typeof config.extras === 'function'\n\t\t\t\t\t? config.extras(aliasedColumns, { sql })\n\t\t\t\t\t: config.extras;\n\t\t\t\tfor (const [tsKey, value] of Object.entries(extras)) {\n\t\t\t\t\tfieldsSelection.push({\n\t\t\t\t\t\ttsKey,\n\t\t\t\t\t\tvalue: mapColumnsInAliasedSQLToAlias(value, tableAlias),\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Transform `fieldsSelection` into `selection`\n\t\t\t// `fieldsSelection` shouldn't be used after this point\n\t\t\tfor (const { tsKey, value } of fieldsSelection) {\n\t\t\t\tselection.push({\n\t\t\t\t\tdbKey: is(value, SQL.Aliased)\n\t\t\t\t\t\t? value.fieldAlias\n\t\t\t\t\t\t: tableConfig.columns[tsKey]!.name,\n\t\t\t\t\ttsKey,\n\t\t\t\t\tfield: is(value, Column)\n\t\t\t\t\t\t? aliasedTableColumn(value, tableAlias)\n\t\t\t\t\t\t: value,\n\t\t\t\t\trelationTableTsKey: undefined,\n\t\t\t\t\tisJson: false,\n\t\t\t\t\tselection: [],\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tlet orderByOrig = typeof config.orderBy === 'function'\n\t\t\t\t? config.orderBy(aliasedColumns, getOrderByOperators())\n\t\t\t\t: (config.orderBy ?? []);\n\t\t\tif (!Array.isArray(orderByOrig)) {\n\t\t\t\torderByOrig = [orderByOrig];\n\t\t\t}\n\t\t\torderBy = orderByOrig.map((orderByValue) => {\n\t\t\t\tif (is(orderByValue, Column)) {\n\t\t\t\t\treturn aliasedTableColumn(orderByValue, tableAlias) as SQLiteColumn;\n\t\t\t\t}\n\t\t\t\treturn mapColumnsInSQLToAlias(orderByValue, tableAlias);\n\t\t\t});\n\n\t\t\tlimit = config.limit;\n\t\t\toffset = config.offset;\n\n\t\t\t// Process all relations\n\t\t\tfor (\n\t\t\t\tconst {\n\t\t\t\t\ttsKey: selectedRelationTsKey,\n\t\t\t\t\tqueryConfig: selectedRelationConfigValue,\n\t\t\t\t\trelation,\n\t\t\t\t} of selectedRelations\n\t\t\t) {\n\t\t\t\tconst normalizedRelation = normalizeRelation(\n\t\t\t\t\tschema,\n\t\t\t\t\ttableNamesMap,\n\t\t\t\t\trelation,\n\t\t\t\t);\n\t\t\t\tconst relationTableName = getTableUniqueName(relation.referencedTable);\n\t\t\t\tconst relationTableTsName = tableNamesMap[relationTableName]!;\n\t\t\t\tconst relationTableAlias = `${tableAlias}_${selectedRelationTsKey}`;\n\t\t\t\t// const relationTable = schema[relationTableTsName]!;\n\t\t\t\tconst joinOn = and(\n\t\t\t\t\t...normalizedRelation.fields.map((field, i) =>\n\t\t\t\t\t\teq(\n\t\t\t\t\t\t\taliasedTableColumn(\n\t\t\t\t\t\t\t\tnormalizedRelation.references[i]!,\n\t\t\t\t\t\t\t\trelationTableAlias,\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\taliasedTableColumn(field, tableAlias),\n\t\t\t\t\t\t)\n\t\t\t\t\t),\n\t\t\t\t);\n\t\t\t\tconst builtRelation = this.buildRelationalQuery({\n\t\t\t\t\tfullSchema,\n\t\t\t\t\tschema,\n\t\t\t\t\ttableNamesMap,\n\t\t\t\t\ttable: fullSchema[relationTableTsName] as SQLiteTable,\n\t\t\t\t\ttableConfig: schema[relationTableTsName]!,\n\t\t\t\t\tqueryConfig: is(relation, One)\n\t\t\t\t\t\t? selectedRelationConfigValue === true\n\t\t\t\t\t\t\t? { limit: 1 }\n\t\t\t\t\t\t\t: { ...selectedRelationConfigValue, limit: 1 }\n\t\t\t\t\t\t: selectedRelationConfigValue,\n\t\t\t\t\ttableAlias: relationTableAlias,\n\t\t\t\t\tjoinOn,\n\t\t\t\t\tnestedQueryRelation: relation,\n\t\t\t\t});\n\t\t\t\tconst field = sql`(${builtRelation.sql})`.as(selectedRelationTsKey);\n\t\t\t\tselection.push({\n\t\t\t\t\tdbKey: selectedRelationTsKey,\n\t\t\t\t\ttsKey: selectedRelationTsKey,\n\t\t\t\t\tfield,\n\t\t\t\t\trelationTableTsKey: relationTableTsName,\n\t\t\t\t\tisJson: true,\n\t\t\t\t\tselection: builtRelation.selection,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tif (selection.length === 0) {\n\t\t\tthrow new DrizzleError({\n\t\t\t\tmessage:\n\t\t\t\t\t`No fields selected for table \"${tableConfig.tsName}\" (\"${tableAlias}\"). You need to have at least one item in \"columns\", \"with\" or \"extras\". If you need to select all columns, omit the \"columns\" key or set it to undefined.`,\n\t\t\t});\n\t\t}\n\n\t\tlet result;\n\n\t\twhere = and(joinOn, where);\n\n\t\tif (nestedQueryRelation) {\n\t\t\tlet field = sql`json_array(${\n\t\t\t\tsql.join(\n\t\t\t\t\tselection.map(({ field }) =>\n\t\t\t\t\t\tis(field, SQLiteColumn)\n\t\t\t\t\t\t\t? sql.identifier(this.casing.getColumnCasing(field))\n\t\t\t\t\t\t\t: is(field, SQL.Aliased)\n\t\t\t\t\t\t\t? field.sql\n\t\t\t\t\t\t\t: field\n\t\t\t\t\t),\n\t\t\t\t\tsql`, `,\n\t\t\t\t)\n\t\t\t})`;\n\t\t\tif (is(nestedQueryRelation, Many)) {\n\t\t\t\tfield = sql`coalesce(json_group_array(${field}), json_array())`;\n\t\t\t}\n\t\t\tconst nestedSelection = [\n\t\t\t\t{\n\t\t\t\t\tdbKey: 'data',\n\t\t\t\t\ttsKey: 'data',\n\t\t\t\t\tfield: field.as('data'),\n\t\t\t\t\tisJson: true,\n\t\t\t\t\trelationTableTsKey: tableConfig.tsName,\n\t\t\t\t\tselection,\n\t\t\t\t},\n\t\t\t];\n\n\t\t\tconst needsSubquery = limit !== undefined || offset !== undefined || orderBy.length > 0;\n\n\t\t\tif (needsSubquery) {\n\t\t\t\tresult = this.buildSelectQuery({\n\t\t\t\t\ttable: aliasedTable(table, tableAlias),\n\t\t\t\t\tfields: {},\n\t\t\t\t\tfieldsFlat: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tpath: [],\n\t\t\t\t\t\t\tfield: sql.raw('*'),\n\t\t\t\t\t\t},\n\t\t\t\t\t],\n\t\t\t\t\twhere,\n\t\t\t\t\tlimit,\n\t\t\t\t\toffset,\n\t\t\t\t\torderBy,\n\t\t\t\t\tsetOperators: [],\n\t\t\t\t});\n\n\t\t\t\twhere = undefined;\n\t\t\t\tlimit = undefined;\n\t\t\t\toffset = undefined;\n\t\t\t\torderBy = undefined;\n\t\t\t} else {\n\t\t\t\tresult = aliasedTable(table, tableAlias);\n\t\t\t}\n\n\t\t\tresult = this.buildSelectQuery({\n\t\t\t\ttable: is(result, SQLiteTable)\n\t\t\t\t\t? result\n\t\t\t\t\t: new Subquery(result, {}, tableAlias),\n\t\t\t\tfields: {},\n\t\t\t\tfieldsFlat: nestedSelection.map(({ field }) => ({\n\t\t\t\t\tpath: [],\n\t\t\t\t\tfield: is(field, Column)\n\t\t\t\t\t\t? aliasedTableColumn(field, tableAlias)\n\t\t\t\t\t\t: field,\n\t\t\t\t})),\n\t\t\t\tjoins,\n\t\t\t\twhere,\n\t\t\t\tlimit,\n\t\t\t\toffset,\n\t\t\t\torderBy,\n\t\t\t\tsetOperators: [],\n\t\t\t});\n\t\t} else {\n\t\t\tresult = this.buildSelectQuery({\n\t\t\t\ttable: aliasedTable(table, tableAlias),\n\t\t\t\tfields: {},\n\t\t\t\tfieldsFlat: selection.map(({ field }) => ({\n\t\t\t\t\tpath: [],\n\t\t\t\t\tfield: is(field, Column)\n\t\t\t\t\t\t? aliasedTableColumn(field, tableAlias)\n\t\t\t\t\t\t: field,\n\t\t\t\t})),\n\t\t\t\tjoins,\n\t\t\t\twhere,\n\t\t\t\tlimit,\n\t\t\t\toffset,\n\t\t\t\torderBy,\n\t\t\t\tsetOperators: [],\n\t\t\t});\n\t\t}\n\n\t\treturn {\n\t\t\ttableTsKey: tableConfig.tsName,\n\t\t\tsql: result,\n\t\t\tselection,\n\t\t};\n\t}\n}\n\nexport class SQLiteSyncDialect extends SQLiteDialect {\n\tstatic override readonly [entityKind]: string = 'SQLiteSyncDialect';\n\n\tmigrate(\n\t\tmigrations: MigrationMeta[],\n\t\tsession: SQLiteSession<\n\t\t\t'sync',\n\t\t\tunknown,\n\t\t\tRecord<string, unknown>,\n\t\t\tTablesRelationalConfig\n\t\t>,\n\t\tconfig?: string | MigrationConfig,\n\t): void {\n\t\tconst migrationsTable = config === undefined\n\t\t\t? '__drizzle_migrations'\n\t\t\t: typeof config === 'string'\n\t\t\t? '__drizzle_migrations'\n\t\t\t: (config.migrationsTable ?? '__drizzle_migrations');\n\n\t\tconst migrationTableCreate = sql`\n\t\t\tCREATE TABLE IF NOT EXISTS ${sql.identifier(migrationsTable)} (\n\t\t\t\tid SERIAL PRIMARY KEY,\n\t\t\t\thash text NOT NULL,\n\t\t\t\tcreated_at numeric\n\t\t\t)\n\t\t`;\n\t\tsession.run(migrationTableCreate);\n\n\t\tconst dbMigrations = session.values<[number, string, string]>(\n\t\t\tsql`SELECT id, hash, created_at FROM ${sql.identifier(migrationsTable)} ORDER BY created_at DESC LIMIT 1`,\n\t\t);\n\n\t\tconst lastDbMigration = dbMigrations[0] ?? undefined;\n\t\tsession.run(sql`BEGIN`);\n\n\t\ttry {\n\t\t\tfor (const migration of migrations) {\n\t\t\t\tif (\n\t\t\t\t\t!lastDbMigration\n\t\t\t\t\t|| Number(lastDbMigration[2])! < migration.folderMillis\n\t\t\t\t) {\n\t\t\t\t\tfor (const stmt of migration.sql) {\n\t\t\t\t\t\tsession.run(sql.raw(stmt));\n\t\t\t\t\t}\n\t\t\t\t\tsession.run(\n\t\t\t\t\t\tsql`INSERT INTO ${\n\t\t\t\t\t\t\tsql.identifier(\n\t\t\t\t\t\t\t\tmigrationsTable,\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t} (\"hash\", \"created_at\") VALUES(${migration.hash}, ${migration.folderMillis})`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tsession.run(sql`COMMIT`);\n\t\t} catch (e) {\n\t\t\tsession.run(sql`ROLLBACK`);\n\t\t\tthrow e;\n\t\t}\n\t}\n}\n\nexport class SQLiteAsyncDialect extends SQLiteDialect {\n\tstatic override readonly [entityKind]: string = 'SQLiteAsyncDialect';\n\n\tasync migrate(\n\t\tmigrations: MigrationMeta[],\n\t\tsession: SQLiteSession<'async', any, any, any>,\n\t\tconfig?: string | MigrationConfig,\n\t): Promise<void> {\n\t\tconst migrationsTable = config === undefined\n\t\t\t? '__drizzle_migrations'\n\t\t\t: typeof config === 'string'\n\t\t\t? '__drizzle_migrations'\n\t\t\t: (config.migrationsTable ?? '__drizzle_migrations');\n\n\t\tconst migrationTableCreate = sql`\n\t\t\tCREATE TABLE IF NOT EXISTS ${sql.identifier(migrationsTable)} (\n\t\t\t\tid SERIAL PRIMARY KEY,\n\t\t\t\thash text NOT NULL,\n\t\t\t\tcreated_at numeric\n\t\t\t)\n\t\t`;\n\t\tawait session.run(migrationTableCreate);\n\n\t\tconst dbMigrations = await session.values<[number, string, string]>(\n\t\t\tsql`SELECT id, hash, created_at FROM ${sql.identifier(migrationsTable)} ORDER BY created_at DESC LIMIT 1`,\n\t\t);\n\n\t\tconst lastDbMigration = dbMigrations[0] ?? undefined;\n\n\t\tawait session.transaction(async (tx) => {\n\t\t\tfor (const migration of migrations) {\n\t\t\t\tif (\n\t\t\t\t\t!lastDbMigration\n\t\t\t\t\t|| Number(lastDbMigration[2])! < migration.folderMillis\n\t\t\t\t) {\n\t\t\t\t\tfor (const stmt of migration.sql) {\n\t\t\t\t\t\tawait tx.run(sql.raw(stmt));\n\t\t\t\t\t}\n\t\t\t\t\tawait tx.run(\n\t\t\t\t\t\tsql`INSERT INTO ${\n\t\t\t\t\t\t\tsql.identifier(\n\t\t\t\t\t\t\t\tmigrationsTable,\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t} (\"hash\", \"created_at\") VALUES(${migration.hash}, ${migration.folderMillis})`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n}\n","import { entityKind } from '~/entity.ts';\nimport type { SQL, SQLWrapper } from '~/sql/index.ts';\n\nexport abstract class TypedQueryBuilder<TSelection, TResult = unknown, TConfig = unknown> implements SQLWrapper {\n\tstatic readonly [entityKind]: string = 'TypedQueryBuilder';\n\n\tdeclare _: {\n\t\tselectedFields: TSelection;\n\t\tresult: TResult;\n\t\tconfig?: TConfig;\n\t};\n\n\t/** @internal */\n\tgetSelectedFields(): TSelection {\n\t\treturn this._.selectedFields;\n\t}\n\n\tabstract getSQL(): SQL;\n}\n","import type { CacheConfig, WithCacheConfig } from '~/cache/core/types.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport type {\n\tBuildSubquerySelection,\n\tGetSelectTableName,\n\tGetSelectTableSelection,\n\tJoinNullability,\n\tJoinType,\n\tSelectMode,\n\tSelectResult,\n\tSetOperator,\n} from '~/query-builders/select.types.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport { SQL, View } from '~/sql/sql.ts';\nimport type { ColumnsSelection, Placeholder, Query, SQLWrapper } from '~/sql/sql.ts';\nimport type { SQLiteColumn } from '~/sqlite-core/columns/index.ts';\nimport type { SQLiteDialect } from '~/sqlite-core/dialect.ts';\nimport type { SQLiteSession } from '~/sqlite-core/session.ts';\nimport type { SubqueryWithSelection } from '~/sqlite-core/subquery.ts';\nimport type { SQLiteTable } from '~/sqlite-core/table.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { Table } from '~/table.ts';\nimport {\n\tapplyMixins,\n\tgetTableColumns,\n\tgetTableLikeName,\n\thaveSameKeys,\n\torderSelectedFields,\n\ttype ValueOrArray,\n} from '~/utils.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport { extractUsedTable } from '../utils.ts';\nimport { SQLiteViewBase } from '../view-base.ts';\nimport type {\n\tAnySQLiteSelect,\n\tCreateSQLiteSelectFromBuilderMode,\n\tGetSQLiteSetOperators,\n\tSelectedFields,\n\tSetOperatorRightSelect,\n\tSQLiteCreateSetOperatorFn,\n\tSQLiteSelectConfig,\n\tSQLiteSelectCrossJoinFn,\n\tSQLiteSelectDynamic,\n\tSQLiteSelectExecute,\n\tSQLiteSelectHKT,\n\tSQLiteSelectHKTBase,\n\tSQLiteSelectJoinFn,\n\tSQLiteSelectPrepare,\n\tSQLiteSelectWithout,\n\tSQLiteSetOperatorExcludedMethods,\n\tSQLiteSetOperatorWithResult,\n} from './select.types.ts';\n\nexport class SQLiteSelectBuilder<\n\tTSelection extends SelectedFields | undefined,\n\tTResultType extends 'sync' | 'async',\n\tTRunResult,\n\tTBuilderMode extends 'db' | 'qb' = 'db',\n> {\n\tstatic readonly [entityKind]: string = 'SQLiteSelectBuilder';\n\n\tprivate fields: TSelection;\n\tprivate session: SQLiteSession<any, any, any, any> | undefined;\n\tprivate dialect: SQLiteDialect;\n\tprivate withList: Subquery[] | undefined;\n\tprivate distinct: boolean | undefined;\n\n\tconstructor(\n\t\tconfig: {\n\t\t\tfields: TSelection;\n\t\t\tsession: SQLiteSession<any, any, any, any> | undefined;\n\t\t\tdialect: SQLiteDialect;\n\t\t\twithList?: Subquery[];\n\t\t\tdistinct?: boolean;\n\t\t},\n\t) {\n\t\tthis.fields = config.fields;\n\t\tthis.session = config.session;\n\t\tthis.dialect = config.dialect;\n\t\tthis.withList = config.withList;\n\t\tthis.distinct = config.distinct;\n\t}\n\n\tfrom<TFrom extends SQLiteTable | Subquery | SQLiteViewBase | SQL>(\n\t\tsource: TFrom,\n\t): CreateSQLiteSelectFromBuilderMode<\n\t\tTBuilderMode,\n\t\tGetSelectTableName<TFrom>,\n\t\tTResultType,\n\t\tTRunResult,\n\t\tTSelection extends undefined ? GetSelectTableSelection<TFrom> : TSelection,\n\t\tTSelection extends undefined ? 'single' : 'partial'\n\t> {\n\t\tconst isPartialSelect = !!this.fields;\n\n\t\tlet fields: SelectedFields;\n\t\tif (this.fields) {\n\t\t\tfields = this.fields;\n\t\t} else if (is(source, Subquery)) {\n\t\t\t// This is required to use the proxy handler to get the correct field values from the subquery\n\t\t\tfields = Object.fromEntries(\n\t\t\t\tObject.keys(source._.selectedFields).map((\n\t\t\t\t\tkey,\n\t\t\t\t) => [key, source[key as unknown as keyof typeof source] as unknown as SelectedFields[string]]),\n\t\t\t);\n\t\t} else if (is(source, SQLiteViewBase)) {\n\t\t\tfields = source[ViewBaseConfig].selectedFields as SelectedFields;\n\t\t} else if (is(source, SQL)) {\n\t\t\tfields = {};\n\t\t} else {\n\t\t\tfields = getTableColumns<SQLiteTable>(source);\n\t\t}\n\n\t\treturn new SQLiteSelectBase({\n\t\t\ttable: source,\n\t\t\tfields,\n\t\t\tisPartialSelect,\n\t\t\tsession: this.session,\n\t\t\tdialect: this.dialect,\n\t\t\twithList: this.withList,\n\t\t\tdistinct: this.distinct,\n\t\t}) as any;\n\t}\n}\n\nexport abstract class SQLiteSelectQueryBuilderBase<\n\tTHKT extends SQLiteSelectHKTBase,\n\tTTableName extends string | undefined,\n\tTResultType extends 'sync' | 'async',\n\tTRunResult,\n\tTSelection extends ColumnsSelection,\n\tTSelectMode extends SelectMode,\n\tTNullabilityMap extends Record<string, JoinNullability> = TTableName extends string ? Record<TTableName, 'not-null'>\n\t\t: {},\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n\tTResult extends any[] = SelectResult<TSelection, TSelectMode, TNullabilityMap>[],\n\tTSelectedFields extends ColumnsSelection = BuildSubquerySelection<TSelection, TNullabilityMap>,\n> extends TypedQueryBuilder<TSelectedFields, TResult> {\n\tstatic override readonly [entityKind]: string = 'SQLiteSelectQueryBuilder';\n\n\toverride readonly _: {\n\t\treadonly dialect: 'sqlite';\n\t\treadonly hkt: THKT;\n\t\treadonly tableName: TTableName;\n\t\treadonly resultType: TResultType;\n\t\treadonly runResult: TRunResult;\n\t\treadonly selection: TSelection;\n\t\treadonly selectMode: TSelectMode;\n\t\treadonly nullabilityMap: TNullabilityMap;\n\t\treadonly dynamic: TDynamic;\n\t\treadonly excludedMethods: TExcludedMethods;\n\t\treadonly result: TResult;\n\t\treadonly selectedFields: TSelectedFields;\n\t\treadonly config: SQLiteSelectConfig;\n\t};\n\n\t/** @internal */\n\tconfig: SQLiteSelectConfig;\n\tprotected joinsNotNullableMap: Record<string, boolean>;\n\tprivate tableName: string | undefined;\n\tprivate isPartialSelect: boolean;\n\tprotected session: SQLiteSession<any, any, any, any> | undefined;\n\tprotected dialect: SQLiteDialect;\n\tprotected cacheConfig?: WithCacheConfig = undefined;\n\tprotected usedTables: Set<string> = new Set();\n\n\tconstructor(\n\t\t{ table, fields, isPartialSelect, session, dialect, withList, distinct }: {\n\t\t\ttable: SQLiteSelectConfig['table'];\n\t\t\tfields: SQLiteSelectConfig['fields'];\n\t\t\tisPartialSelect: boolean;\n\t\t\tsession: SQLiteSession<any, any, any, any> | undefined;\n\t\t\tdialect: SQLiteDialect;\n\t\t\twithList: Subquery[] | undefined;\n\t\t\tdistinct: boolean | undefined;\n\t\t},\n\t) {\n\t\tsuper();\n\t\tthis.config = {\n\t\t\twithList,\n\t\t\ttable,\n\t\t\tfields: { ...fields },\n\t\t\tdistinct,\n\t\t\tsetOperators: [],\n\t\t};\n\t\tthis.isPartialSelect = isPartialSelect;\n\t\tthis.session = session;\n\t\tthis.dialect = dialect;\n\t\tthis._ = {\n\t\t\tselectedFields: fields as TSelectedFields,\n\t\t\tconfig: this.config,\n\t\t} as this['_'];\n\t\tthis.tableName = getTableLikeName(table);\n\t\tthis.joinsNotNullableMap = typeof this.tableName === 'string' ? { [this.tableName]: true } : {};\n\t\tfor (const item of extractUsedTable(table)) this.usedTables.add(item);\n\t}\n\n\t/** @internal */\n\tgetUsedTables() {\n\t\treturn [...this.usedTables];\n\t}\n\n\tprivate createJoin<TJoinType extends JoinType>(\n\t\tjoinType: TJoinType,\n\t): 'cross' extends TJoinType ? SQLiteSelectCrossJoinFn<this, TDynamic>\n\t\t: SQLiteSelectJoinFn<this, TDynamic, TJoinType>\n\t{\n\t\treturn (\n\t\t\ttable: SQLiteTable | Subquery | SQLiteViewBase | SQL,\n\t\t\ton?: ((aliases: TSelection) => SQL | undefined) | SQL | undefined,\n\t\t) => {\n\t\t\tconst baseTableName = this.tableName;\n\t\t\tconst tableName = getTableLikeName(table);\n\n\t\t\t// store all tables used in a query\n\t\t\tfor (const item of extractUsedTable(table)) this.usedTables.add(item);\n\n\t\t\tif (typeof tableName === 'string' && this.config.joins?.some((join) => join.alias === tableName)) {\n\t\t\t\tthrow new Error(`Alias \"${tableName}\" is already used in this query`);\n\t\t\t}\n\n\t\t\tif (!this.isPartialSelect) {\n\t\t\t\t// If this is the first join and this is not a partial select and we're not selecting from raw SQL, \"move\" the fields from the main table to the nested object\n\t\t\t\tif (Object.keys(this.joinsNotNullableMap).length === 1 && typeof baseTableName === 'string') {\n\t\t\t\t\tthis.config.fields = {\n\t\t\t\t\t\t[baseTableName]: this.config.fields,\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\tif (typeof tableName === 'string' && !is(table, SQL)) {\n\t\t\t\t\tconst selection = is(table, Subquery)\n\t\t\t\t\t\t? table._.selectedFields\n\t\t\t\t\t\t: is(table, View)\n\t\t\t\t\t\t? table[ViewBaseConfig].selectedFields\n\t\t\t\t\t\t: table[Table.Symbol.Columns];\n\t\t\t\t\tthis.config.fields[tableName] = selection;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (typeof on === 'function') {\n\t\t\t\ton = on(\n\t\t\t\t\tnew Proxy(\n\t\t\t\t\t\tthis.config.fields,\n\t\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t\t) as TSelection,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tif (!this.config.joins) {\n\t\t\t\tthis.config.joins = [];\n\t\t\t}\n\t\t\tthis.config.joins.push({ on, table, joinType, alias: tableName });\n\n\t\t\tif (typeof tableName === 'string') {\n\t\t\t\tswitch (joinType) {\n\t\t\t\t\tcase 'left': {\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = false;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'right': {\n\t\t\t\t\t\tthis.joinsNotNullableMap = Object.fromEntries(\n\t\t\t\t\t\t\tObject.entries(this.joinsNotNullableMap).map(([key]) => [key, false]),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'cross':\n\t\t\t\t\tcase 'inner': {\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase 'full': {\n\t\t\t\t\t\tthis.joinsNotNullableMap = Object.fromEntries(\n\t\t\t\t\t\t\tObject.entries(this.joinsNotNullableMap).map(([key]) => [key, false]),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.joinsNotNullableMap[tableName] = false;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn this as any;\n\t\t};\n\t}\n\n\t/**\n\t * Executes a `left join` operation by adding another table to the current query.\n\t *\n\t * 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\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#left-join}\n\t *\n\t * @param table the table to join.\n\t * @param on the `on` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all users and their pets\n\t * const usersWithPets: { user: User; pets: Pet | null; }[] = await db.select()\n\t * .from(users)\n\t * .leftJoin(pets, eq(users.id, pets.ownerId))\n\t *\n\t * // Select userId and petId\n\t * const usersIdsAndPetIds: { userId: number; petId: number | null; }[] = await db.select({\n\t * userId: users.id,\n\t * petId: pets.id,\n\t * })\n\t * .from(users)\n\t * .leftJoin(pets, eq(users.id, pets.ownerId))\n\t * ```\n\t */\n\tleftJoin = this.createJoin('left');\n\n\t/**\n\t * Executes a `right join` operation by adding another table to the current query.\n\t *\n\t * 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\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#right-join}\n\t *\n\t * @param table the table to join.\n\t * @param on the `on` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all users and their pets\n\t * const usersWithPets: { user: User | null; pets: Pet; }[] = await db.select()\n\t * .from(users)\n\t * .rightJoin(pets, eq(users.id, pets.ownerId))\n\t *\n\t * // Select userId and petId\n\t * const usersIdsAndPetIds: { userId: number | null; petId: number; }[] = await db.select({\n\t * userId: users.id,\n\t * petId: pets.id,\n\t * })\n\t * .from(users)\n\t * .rightJoin(pets, eq(users.id, pets.ownerId))\n\t * ```\n\t */\n\trightJoin = this.createJoin('right');\n\n\t/**\n\t * Executes an `inner join` operation, creating a new table by combining rows from two tables that have matching values.\n\t *\n\t * 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\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join}\n\t *\n\t * @param table the table to join.\n\t * @param on the `on` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all users and their pets\n\t * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()\n\t * .from(users)\n\t * .innerJoin(pets, eq(users.id, pets.ownerId))\n\t *\n\t * // Select userId and petId\n\t * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({\n\t * userId: users.id,\n\t * petId: pets.id,\n\t * })\n\t * .from(users)\n\t * .innerJoin(pets, eq(users.id, pets.ownerId))\n\t * ```\n\t */\n\tinnerJoin = this.createJoin('inner');\n\n\t/**\n\t * Executes a `full join` operation by combining rows from two tables into a new table.\n\t *\n\t * 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\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#full-join}\n\t *\n\t * @param table the table to join.\n\t * @param on the `on` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all users and their pets\n\t * const usersWithPets: { user: User | null; pets: Pet | null; }[] = await db.select()\n\t * .from(users)\n\t * .fullJoin(pets, eq(users.id, pets.ownerId))\n\t *\n\t * // Select userId and petId\n\t * const usersIdsAndPetIds: { userId: number | null; petId: number | null; }[] = await db.select({\n\t * userId: users.id,\n\t * petId: pets.id,\n\t * })\n\t * .from(users)\n\t * .fullJoin(pets, eq(users.id, pets.ownerId))\n\t * ```\n\t */\n\tfullJoin = this.createJoin('full');\n\n\t/**\n\t * Executes a `cross join` operation by combining rows from two tables into a new table.\n\t *\n\t * Calling this method retrieves all rows from both main and joined tables, merging all rows from each table.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/joins#cross-join}\n\t *\n\t * @param table the table to join.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all users, each user with every pet\n\t * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()\n\t * .from(users)\n\t * .crossJoin(pets)\n\t *\n\t * // Select userId and petId\n\t * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({\n\t * userId: users.id,\n\t * petId: pets.id,\n\t * })\n\t * .from(users)\n\t * .crossJoin(pets)\n\t * ```\n\t */\n\tcrossJoin = this.createJoin('cross');\n\n\tprivate createSetOperator(\n\t\ttype: SetOperator,\n\t\tisAll: boolean,\n\t): <TValue extends SQLiteSetOperatorWithResult<TResult>>(\n\t\trightSelection:\n\t\t\t| ((setOperators: GetSQLiteSetOperators) => SetOperatorRightSelect<TValue, TResult>)\n\t\t\t| SetOperatorRightSelect<TValue, TResult>,\n\t) => SQLiteSelectWithout<\n\t\tthis,\n\t\tTDynamic,\n\t\tSQLiteSetOperatorExcludedMethods,\n\t\ttrue\n\t> {\n\t\treturn (rightSelection) => {\n\t\t\tconst rightSelect = (typeof rightSelection === 'function'\n\t\t\t\t? rightSelection(getSQLiteSetOperators())\n\t\t\t\t: rightSelection) as TypedQueryBuilder<\n\t\t\t\t\tany,\n\t\t\t\t\tTResult\n\t\t\t\t>;\n\n\t\t\tif (!haveSameKeys(this.getSelectedFields(), rightSelect.getSelectedFields())) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t'Set operator error (union / intersect / except): selected fields are not the same or are in a different order',\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tthis.config.setOperators.push({ type, isAll, rightSelect });\n\t\t\treturn this as any;\n\t\t};\n\t}\n\n\t/**\n\t * Adds `union` set operator to the query.\n\t *\n\t * Calling this method will combine the result sets of the `select` statements and remove any duplicate rows that appear across them.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/set-operations#union}\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all unique names from customers and users tables\n\t * await db.select({ name: users.name })\n\t * .from(users)\n\t * .union(\n\t * db.select({ name: customers.name }).from(customers)\n\t * );\n\t * // or\n\t * import { union } from 'drizzle-orm/sqlite-core'\n\t *\n\t * await union(\n\t * db.select({ name: users.name }).from(users),\n\t * db.select({ name: customers.name }).from(customers)\n\t * );\n\t * ```\n\t */\n\tunion = this.createSetOperator('union', false);\n\n\t/**\n\t * Adds `union all` set operator to the query.\n\t *\n\t * Calling this method will combine the result-set of the `select` statements and keep all duplicate rows that appear across them.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/set-operations#union-all}\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all transaction ids from both online and in-store sales\n\t * await db.select({ transaction: onlineSales.transactionId })\n\t * .from(onlineSales)\n\t * .unionAll(\n\t * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n\t * );\n\t * // or\n\t * import { unionAll } from 'drizzle-orm/sqlite-core'\n\t *\n\t * await unionAll(\n\t * db.select({ transaction: onlineSales.transactionId }).from(onlineSales),\n\t * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n\t * );\n\t * ```\n\t */\n\tunionAll = this.createSetOperator('union', true);\n\n\t/**\n\t * Adds `intersect` set operator to the query.\n\t *\n\t * Calling this method will retain only the rows that are present in both result sets and eliminate duplicates.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect}\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select course names that are offered in both departments A and B\n\t * await db.select({ courseName: depA.courseName })\n\t * .from(depA)\n\t * .intersect(\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * // or\n\t * import { intersect } from 'drizzle-orm/sqlite-core'\n\t *\n\t * await intersect(\n\t * db.select({ courseName: depA.courseName }).from(depA),\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * ```\n\t */\n\tintersect = this.createSetOperator('intersect', false);\n\n\t/**\n\t * Adds `except` set operator to the query.\n\t *\n\t * 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\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/set-operations#except}\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all courses offered in department A but not in department B\n\t * await db.select({ courseName: depA.courseName })\n\t * .from(depA)\n\t * .except(\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * // or\n\t * import { except } from 'drizzle-orm/sqlite-core'\n\t *\n\t * await except(\n\t * db.select({ courseName: depA.courseName }).from(depA),\n\t * db.select({ courseName: depB.courseName }).from(depB)\n\t * );\n\t * ```\n\t */\n\texcept = this.createSetOperator('except', false);\n\n\t/** @internal */\n\taddSetOperators(setOperators: SQLiteSelectConfig['setOperators']): SQLiteSelectWithout<\n\t\tthis,\n\t\tTDynamic,\n\t\tSQLiteSetOperatorExcludedMethods,\n\t\ttrue\n\t> {\n\t\tthis.config.setOperators.push(...setOperators);\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `where` clause to the query.\n\t *\n\t * Calling this method will select only those rows that fulfill a specified condition.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#filtering}\n\t *\n\t * @param where the `where` clause.\n\t *\n\t * @example\n\t * You can use conditional operators and `sql function` to filter the rows to be selected.\n\t *\n\t * ```ts\n\t * // Select all cars with green color\n\t * await db.select().from(cars).where(eq(cars.color, 'green'));\n\t * // or\n\t * await db.select().from(cars).where(sql`${cars.color} = 'green'`)\n\t * ```\n\t *\n\t * You can logically combine conditional operators with `and()` and `or()` operators:\n\t *\n\t * ```ts\n\t * // Select all BMW cars with a green color\n\t * await db.select().from(cars).where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n\t *\n\t * // Select all cars with the green or blue color\n\t * await db.select().from(cars).where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n\t * ```\n\t */\n\twhere(\n\t\twhere: ((aliases: TSelection) => SQL | undefined) | SQL | undefined,\n\t): SQLiteSelectWithout<this, TDynamic, 'where'> {\n\t\tif (typeof where === 'function') {\n\t\t\twhere = where(\n\t\t\t\tnew Proxy(\n\t\t\t\t\tthis.config.fields,\n\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t) as TSelection,\n\t\t\t);\n\t\t}\n\t\tthis.config.where = where;\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `having` clause to the query.\n\t *\n\t * 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\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#aggregations}\n\t *\n\t * @param having the `having` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all brands with more than one car\n\t * await db.select({\n\t * \tbrand: cars.brand,\n\t * \tcount: sql<number>`cast(count(${cars.id}) as int)`,\n\t * })\n\t * .from(cars)\n\t * .groupBy(cars.brand)\n\t * .having(({ count }) => gt(count, 1));\n\t * ```\n\t */\n\thaving(\n\t\thaving: ((aliases: this['_']['selection']) => SQL | undefined) | SQL | undefined,\n\t): SQLiteSelectWithout<this, TDynamic, 'having'> {\n\t\tif (typeof having === 'function') {\n\t\t\thaving = having(\n\t\t\t\tnew Proxy(\n\t\t\t\t\tthis.config.fields,\n\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t) as TSelection,\n\t\t\t);\n\t\t}\n\t\tthis.config.having = having;\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `group by` clause to the query.\n\t *\n\t * Calling this method will group rows that have the same values into summary rows, often used for aggregation purposes.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#aggregations}\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Group and count people by their last names\n\t * await db.select({\n\t * lastName: people.lastName,\n\t * count: sql<number>`cast(count(*) as int)`\n\t * })\n\t * .from(people)\n\t * .groupBy(people.lastName);\n\t * ```\n\t */\n\tgroupBy(\n\t\tbuilder: (aliases: this['_']['selection']) => ValueOrArray<SQLiteColumn | SQL | SQL.Aliased>,\n\t): SQLiteSelectWithout<this, TDynamic, 'groupBy'>;\n\tgroupBy(...columns: (SQLiteColumn | SQL)[]): SQLiteSelectWithout<this, TDynamic, 'groupBy'>;\n\tgroupBy(\n\t\t...columns:\n\t\t\t| [(aliases: this['_']['selection']) => ValueOrArray<SQLiteColumn | SQL | SQL.Aliased>]\n\t\t\t| (SQLiteColumn | SQL | SQL.Aliased)[]\n\t): SQLiteSelectWithout<this, TDynamic, 'groupBy'> {\n\t\tif (typeof columns[0] === 'function') {\n\t\t\tconst groupBy = columns[0](\n\t\t\t\tnew Proxy(\n\t\t\t\t\tthis.config.fields,\n\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'alias', sqlBehavior: 'sql' }),\n\t\t\t\t) as TSelection,\n\t\t\t);\n\t\t\tthis.config.groupBy = Array.isArray(groupBy) ? groupBy : [groupBy];\n\t\t} else {\n\t\t\tthis.config.groupBy = columns as (SQLiteColumn | SQL | SQL.Aliased)[];\n\t\t}\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds an `order by` clause to the query.\n\t *\n\t * Calling this method will sort the result-set in ascending or descending order. By default, the sort order is ascending.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#order-by}\n\t *\n\t * @example\n\t *\n\t * ```\n\t * // Select cars ordered by year\n\t * await db.select().from(cars).orderBy(cars.year);\n\t * ```\n\t *\n\t * You can specify whether results are in ascending or descending order with the `asc()` and `desc()` operators.\n\t *\n\t * ```ts\n\t * // Select cars ordered by year in descending order\n\t * await db.select().from(cars).orderBy(desc(cars.year));\n\t *\n\t * // Select cars ordered by year and price\n\t * await db.select().from(cars).orderBy(asc(cars.year), desc(cars.price));\n\t * ```\n\t */\n\torderBy(\n\t\tbuilder: (aliases: this['_']['selection']) => ValueOrArray<SQLiteColumn | SQL | SQL.Aliased>,\n\t): SQLiteSelectWithout<this, TDynamic, 'orderBy'>;\n\torderBy(...columns: (SQLiteColumn | SQL)[]): SQLiteSelectWithout<this, TDynamic, 'orderBy'>;\n\torderBy(\n\t\t...columns:\n\t\t\t| [(aliases: this['_']['selection']) => ValueOrArray<SQLiteColumn | SQL | SQL.Aliased>]\n\t\t\t| (SQLiteColumn | SQL | SQL.Aliased)[]\n\t): SQLiteSelectWithout<this, TDynamic, 'orderBy'> {\n\t\tif (typeof columns[0] === 'function') {\n\t\t\tconst orderBy = columns[0](\n\t\t\t\tnew Proxy(\n\t\t\t\t\tthis.config.fields,\n\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'alias', sqlBehavior: 'sql' }),\n\t\t\t\t) as TSelection,\n\t\t\t);\n\n\t\t\tconst orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];\n\n\t\t\tif (this.config.setOperators.length > 0) {\n\t\t\t\tthis.config.setOperators.at(-1)!.orderBy = orderByArray;\n\t\t\t} else {\n\t\t\t\tthis.config.orderBy = orderByArray;\n\t\t\t}\n\t\t} else {\n\t\t\tconst orderByArray = columns as (SQLiteColumn | SQL | SQL.Aliased)[];\n\n\t\t\tif (this.config.setOperators.length > 0) {\n\t\t\t\tthis.config.setOperators.at(-1)!.orderBy = orderByArray;\n\t\t\t} else {\n\t\t\t\tthis.config.orderBy = orderByArray;\n\t\t\t}\n\t\t}\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `limit` clause to the query.\n\t *\n\t * Calling this method will set the maximum number of rows that will be returned by this query.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}\n\t *\n\t * @param limit the `limit` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Get the first 10 people from this query.\n\t * await db.select().from(people).limit(10);\n\t * ```\n\t */\n\tlimit(limit: number | Placeholder): SQLiteSelectWithout<this, TDynamic, 'limit'> {\n\t\tif (this.config.setOperators.length > 0) {\n\t\t\tthis.config.setOperators.at(-1)!.limit = limit;\n\t\t} else {\n\t\t\tthis.config.limit = limit;\n\t\t}\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds an `offset` clause to the query.\n\t *\n\t * Calling this method will skip a number of rows when returning results from this query.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}\n\t *\n\t * @param offset the `offset` clause.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Get the 10th-20th people from this query.\n\t * await db.select().from(people).offset(10).limit(10);\n\t * ```\n\t */\n\toffset(offset: number | Placeholder): SQLiteSelectWithout<this, TDynamic, 'offset'> {\n\t\tif (this.config.setOperators.length > 0) {\n\t\t\tthis.config.setOperators.at(-1)!.offset = offset;\n\t\t} else {\n\t\t\tthis.config.offset = offset;\n\t\t}\n\t\treturn this as any;\n\t}\n\n\t/** @internal */\n\tgetSQL(): SQL {\n\t\treturn this.dialect.buildSelectQuery(this.config);\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\tas<TAlias extends string>(\n\t\talias: TAlias,\n\t): SubqueryWithSelection<this['_']['selectedFields'], TAlias> {\n\t\tconst usedTables: string[] = [];\n\t\tusedTables.push(...extractUsedTable(this.config.table));\n\t\tif (this.config.joins) { for (const it of this.config.joins) usedTables.push(...extractUsedTable(it.table)); }\n\n\t\treturn new Proxy(\n\t\t\tnew Subquery(this.getSQL(), this.config.fields, alias, false, [...new Set(usedTables)]),\n\t\t\tnew SelectionProxyHandler({ alias, sqlAliasedBehavior: 'alias', sqlBehavior: 'error' }),\n\t\t) as SubqueryWithSelection<this['_']['selectedFields'], TAlias>;\n\t}\n\n\t/** @internal */\n\toverride getSelectedFields(): this['_']['selectedFields'] {\n\t\treturn new Proxy(\n\t\t\tthis.config.fields,\n\t\t\tnew SelectionProxyHandler({ alias: this.tableName, sqlAliasedBehavior: 'alias', sqlBehavior: 'error' }),\n\t\t) as this['_']['selectedFields'];\n\t}\n\n\t$dynamic(): SQLiteSelectDynamic<this> {\n\t\treturn this;\n\t}\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\nexport interface SQLiteSelectBase<\n\tTTableName extends string | undefined,\n\tTResultType extends 'sync' | 'async',\n\tTRunResult,\n\tTSelection extends ColumnsSelection,\n\tTSelectMode extends SelectMode = 'single',\n\tTNullabilityMap extends Record<string, JoinNullability> = TTableName extends string ? Record<TTableName, 'not-null'>\n\t\t: {},\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n\tTResult extends any[] = SelectResult<TSelection, TSelectMode, TNullabilityMap>[],\n\tTSelectedFields extends ColumnsSelection = BuildSubquerySelection<TSelection, TNullabilityMap>,\n> extends\n\tSQLiteSelectQueryBuilderBase<\n\t\tSQLiteSelectHKT,\n\t\tTTableName,\n\t\tTResultType,\n\t\tTRunResult,\n\t\tTSelection,\n\t\tTSelectMode,\n\t\tTNullabilityMap,\n\t\tTDynamic,\n\t\tTExcludedMethods,\n\t\tTResult,\n\t\tTSelectedFields\n\t>,\n\tQueryPromise<TResult>\n{}\n\nexport class SQLiteSelectBase<\n\tTTableName extends string | undefined,\n\tTResultType extends 'sync' | 'async',\n\tTRunResult,\n\tTSelection,\n\tTSelectMode extends SelectMode = 'single',\n\tTNullabilityMap extends Record<string, JoinNullability> = TTableName extends string ? Record<TTableName, 'not-null'>\n\t\t: {},\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n\tTResult = SelectResult<TSelection, TSelectMode, TNullabilityMap>[],\n\tTSelectedFields extends ColumnsSelection = BuildSubquerySelection<TSelection, TNullabilityMap>,\n> extends SQLiteSelectQueryBuilderBase<\n\tSQLiteSelectHKT,\n\tTTableName,\n\tTResultType,\n\tTRunResult,\n\tTSelection,\n\tTSelectMode,\n\tTNullabilityMap,\n\tTDynamic,\n\tTExcludedMethods,\n\tTResult,\n\tTSelectedFields\n> implements RunnableQuery<TResult, 'sqlite'>, SQLWrapper {\n\tstatic override readonly [entityKind]: string = 'SQLiteSelect';\n\n\t/** @internal */\n\t_prepare(isOneTimeQuery = true): SQLiteSelectPrepare<this> {\n\t\tif (!this.session) {\n\t\t\tthrow new Error('Cannot execute a query on a query builder. Please use a database instance instead.');\n\t\t}\n\t\tconst fieldsList = orderSelectedFields<SQLiteColumn>(this.config.fields);\n\t\tconst query = this.session[isOneTimeQuery ? 'prepareOneTimeQuery' : 'prepareQuery'](\n\t\t\tthis.dialect.sqlToQuery(this.getSQL()),\n\t\t\tfieldsList,\n\t\t\t'all',\n\t\t\ttrue,\n\t\t\tundefined,\n\t\t\t{\n\t\t\t\ttype: 'select',\n\t\t\t\ttables: [...this.usedTables],\n\t\t\t},\n\t\t\tthis.cacheConfig,\n\t\t);\n\t\tquery.joinsNotNullableMap = this.joinsNotNullableMap;\n\t\treturn query as ReturnType<this['prepare']>;\n\t}\n\n\t$withCache(config?: { config?: CacheConfig; tag?: string; autoInvalidate?: boolean } | false) {\n\t\tthis.cacheConfig = config === undefined\n\t\t\t? { config: {}, enable: true, autoInvalidate: true }\n\t\t\t: config === false\n\t\t\t? { enable: false }\n\t\t\t: { enable: true, autoInvalidate: true, ...config };\n\t\treturn this;\n\t}\n\n\tprepare(): SQLiteSelectPrepare<this> {\n\t\treturn this._prepare(false);\n\t}\n\n\trun: ReturnType<this['prepare']>['run'] = (placeholderValues) => {\n\t\treturn this._prepare().run(placeholderValues);\n\t};\n\n\tall: ReturnType<this['prepare']>['all'] = (placeholderValues) => {\n\t\treturn this._prepare().all(placeholderValues);\n\t};\n\n\tget: ReturnType<this['prepare']>['get'] = (placeholderValues) => {\n\t\treturn this._prepare().get(placeholderValues);\n\t};\n\n\tvalues: ReturnType<this['prepare']>['values'] = (placeholderValues) => {\n\t\treturn this._prepare().values(placeholderValues);\n\t};\n\n\tasync execute(): Promise<SQLiteSelectExecute<this>> {\n\t\treturn this.all() as SQLiteSelectExecute<this>;\n\t}\n}\n\napplyMixins(SQLiteSelectBase, [QueryPromise]);\n\nfunction createSetOperator(type: SetOperator, isAll: boolean): SQLiteCreateSetOperatorFn {\n\treturn (leftSelect, rightSelect, ...restSelects) => {\n\t\tconst setOperators = [rightSelect, ...restSelects].map((select) => ({\n\t\t\ttype,\n\t\t\tisAll,\n\t\t\trightSelect: select as AnySQLiteSelect,\n\t\t}));\n\n\t\tfor (const setOperator of setOperators) {\n\t\t\tif (!haveSameKeys((leftSelect as any).getSelectedFields(), setOperator.rightSelect.getSelectedFields())) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t'Set operator error (union / intersect / except): selected fields are not the same or are in a different order',\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\n\t\treturn (leftSelect as AnySQLiteSelect).addSetOperators(setOperators) as any;\n\t};\n}\n\nconst getSQLiteSetOperators = () => ({\n\tunion,\n\tunionAll,\n\tintersect,\n\texcept,\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 * 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 * // or\n * await db.select({ name: users.name })\n * .from(users)\n * .union(\n * db.select({ name: customers.name }).from(customers)\n * );\n * ```\n */\nexport const union = createSetOperator('union', false);\n\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 * 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 * // or\n * await db.select({ transaction: onlineSales.transactionId })\n * .from(onlineSales)\n * .unionAll(\n * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n * );\n * ```\n */\nexport const unionAll = createSetOperator('union', true);\n\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 * 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 * // or\n * await db.select({ courseName: depA.courseName })\n * .from(depA)\n * .intersect(\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * ```\n */\nexport const intersect = createSetOperator('intersect', false);\n\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 * 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 * // or\n * await db.select({ courseName: depA.courseName })\n * .from(depA)\n * .except(\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * ```\n */\nexport const except = createSetOperator('except', false);\n","import { entityKind, is } from '~/entity.ts';\nimport type { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport type { ColumnsSelection, SQL } from '~/sql/sql.ts';\nimport type { SQLiteDialectConfig } from '~/sqlite-core/dialect.ts';\nimport { SQLiteDialect, SQLiteSyncDialect } from '~/sqlite-core/dialect.ts';\nimport type { WithBuilder } from '~/sqlite-core/subquery.ts';\nimport { WithSubquery } from '~/subquery.ts';\nimport { SQLiteSelectBuilder } from './select.ts';\nimport type { SelectedFields } from './select.types.ts';\n\nexport class QueryBuilder {\n\tstatic readonly [entityKind]: string = 'SQLiteQueryBuilder';\n\n\tprivate dialect: SQLiteDialect | undefined;\n\tprivate dialectConfig: SQLiteDialectConfig | undefined;\n\n\tconstructor(dialect?: SQLiteDialect | SQLiteDialectConfig) {\n\t\tthis.dialect = is(dialect, SQLiteDialect) ? dialect : undefined;\n\t\tthis.dialectConfig = is(dialect, SQLiteDialect) ? undefined : dialect;\n\t}\n\n\t$with: WithBuilder = (alias: string, selection?: ColumnsSelection) => {\n\t\tconst queryBuilder = this;\n\t\tconst as = (\n\t\t\tqb:\n\t\t\t\t| TypedQueryBuilder<ColumnsSelection | undefined>\n\t\t\t\t| SQL\n\t\t\t\t| ((qb: QueryBuilder) => TypedQueryBuilder<ColumnsSelection | undefined> | SQL),\n\t\t) => {\n\t\t\tif (typeof qb === 'function') {\n\t\t\t\tqb = qb(queryBuilder);\n\t\t\t}\n\n\t\t\treturn new Proxy(\n\t\t\t\tnew WithSubquery(\n\t\t\t\t\tqb.getSQL(),\n\t\t\t\t\tselection ?? ('getSelectedFields' in qb ? qb.getSelectedFields() ?? {} : {}) as SelectedFields,\n\t\t\t\t\talias,\n\t\t\t\t\ttrue,\n\t\t\t\t),\n\t\t\t\tnew SelectionProxyHandler({ alias, sqlAliasedBehavior: 'alias', sqlBehavior: 'error' }),\n\t\t\t) as any;\n\t\t};\n\t\treturn { as };\n\t};\n\n\twith(...queries: WithSubquery[]) {\n\t\tconst self = this;\n\n\t\tfunction select(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\t\tfunction select<TSelection extends SelectedFields>(\n\t\t\tfields: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\t\tfunction select<TSelection extends SelectedFields>(\n\t\t\tfields?: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\t\treturn new SQLiteSelectBuilder({\n\t\t\t\tfields: fields ?? undefined,\n\t\t\t\tsession: undefined,\n\t\t\t\tdialect: self.getDialect(),\n\t\t\t\twithList: queries,\n\t\t\t});\n\t\t}\n\n\t\tfunction selectDistinct(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\t\tfunction selectDistinct<TSelection extends SelectedFields>(\n\t\t\tfields: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\t\tfunction selectDistinct<TSelection extends SelectedFields>(\n\t\t\tfields?: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\t\treturn new SQLiteSelectBuilder({\n\t\t\t\tfields: fields ?? undefined,\n\t\t\t\tsession: undefined,\n\t\t\t\tdialect: self.getDialect(),\n\t\t\t\twithList: queries,\n\t\t\t\tdistinct: true,\n\t\t\t});\n\t\t}\n\n\t\treturn { select, selectDistinct };\n\t}\n\n\tselect(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\tselect<TSelection extends SelectedFields>(\n\t\tfields: TSelection,\n\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\tselect<TSelection extends SelectedFields>(\n\t\tfields?: TSelection,\n\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\treturn new SQLiteSelectBuilder({ fields: fields ?? undefined, session: undefined, dialect: this.getDialect() });\n\t}\n\n\tselectDistinct(): SQLiteSelectBuilder<undefined, 'sync', void, 'qb'>;\n\tselectDistinct<TSelection extends SelectedFields>(\n\t\tfields: TSelection,\n\t): SQLiteSelectBuilder<TSelection, 'sync', void, 'qb'>;\n\tselectDistinct<TSelection extends SelectedFields>(\n\t\tfields?: TSelection,\n\t): SQLiteSelectBuilder<TSelection | undefined, 'sync', void, 'qb'> {\n\t\treturn new SQLiteSelectBuilder({\n\t\t\tfields: fields ?? undefined,\n\t\t\tsession: undefined,\n\t\t\tdialect: this.getDialect(),\n\t\t\tdistinct: true,\n\t\t});\n\t}\n\n\t// Lazy load dialect to avoid circular dependency\n\tprivate getDialect() {\n\t\tif (!this.dialect) {\n\t\t\tthis.dialect = new SQLiteSyncDialect(this.dialectConfig);\n\t\t}\n\n\t\treturn this.dialect;\n\t}\n}\n","import { entityKind, is } from '~/entity.ts';\nimport type { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport type { SelectResultFields } from '~/query-builders/select.types.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 { SQLiteDialect } from '~/sqlite-core/dialect.ts';\nimport type { IndexColumn } from '~/sqlite-core/indexes.ts';\nimport type { SQLitePreparedQuery, SQLiteSession } from '~/sqlite-core/session.ts';\nimport { SQLiteTable } from '~/sqlite-core/table.ts';\nimport type { Subquery } from '~/subquery.ts';\nimport { Columns, Table } from '~/table.ts';\nimport { type DrizzleTypeError, haveSameKeys, mapUpdateSet, orderSelectedFields, type Simplify } from '~/utils.ts';\nimport type { AnySQLiteColumn, SQLiteColumn } from '../columns/common.ts';\nimport { extractUsedTable } from '../utils.ts';\nimport { QueryBuilder } from './query-builder.ts';\nimport type { SelectedFieldsFlat, SelectedFieldsOrdered } from './select.types.ts';\nimport type { SQLiteUpdateSetSource } from './update.ts';\n\nexport interface SQLiteInsertConfig<TTable extends SQLiteTable = SQLiteTable> {\n\ttable: TTable;\n\tvalues: Record<string, Param | SQL>[] | SQLiteInsertSelectQueryBuilder<TTable> | SQL;\n\twithList?: Subquery[];\n\tonConflict?: SQL[];\n\treturning?: SelectedFieldsOrdered;\n\tselect?: boolean;\n}\n\nexport type SQLiteInsertValue<TTable extends SQLiteTable> = Simplify<\n\t{\n\t\t[Key in keyof TTable['$inferInsert']]: TTable['$inferInsert'][Key] | SQL | Placeholder;\n\t}\n>;\n\nexport type SQLiteInsertSelectQueryBuilder<TTable extends SQLiteTable> = TypedQueryBuilder<\n\t{ [K in keyof TTable['$inferInsert']]: AnySQLiteColumn | SQL | SQL.Aliased | TTable['$inferInsert'][K] }\n>;\n\nexport class SQLiteInsertBuilder<\n\tTTable extends SQLiteTable,\n\tTResultType extends 'sync' | 'async',\n\tTRunResult,\n> {\n\tstatic readonly [entityKind]: string = 'SQLiteInsertBuilder';\n\n\tconstructor(\n\t\tprotected table: TTable,\n\t\tprotected session: SQLiteSession<any, any, any, any>,\n\t\tprotected dialect: SQLiteDialect,\n\t\tprivate withList?: Subquery[],\n\t) {}\n\n\tvalues(value: SQLiteInsertValue<TTable>): SQLiteInsertBase<TTable, TResultType, TRunResult>;\n\tvalues(values: SQLiteInsertValue<TTable>[]): SQLiteInsertBase<TTable, TResultType, TRunResult>;\n\tvalues(\n\t\tvalues: SQLiteInsertValue<TTable> | SQLiteInsertValue<TTable>[],\n\t): SQLiteInsertBase<TTable, TResultType, TRunResult> {\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\t// if (mappedValues.length > 1 && mappedValues.some((t) => Object.keys(t).length === 0)) {\n\t\t// \tthrow new Error(\n\t\t// \t\t`One of the values you want to insert is empty. In SQLite you can insert only one empty object per statement. For this case Drizzle with use \"INSERT INTO ... DEFAULT VALUES\" syntax`,\n\t\t// \t);\n\t\t// }\n\n\t\treturn new SQLiteInsertBase(this.table, mappedValues, this.session, this.dialect, this.withList);\n\t}\n\n\tselect(\n\t\tselectQuery: (qb: QueryBuilder) => SQLiteInsertSelectQueryBuilder<TTable>,\n\t): SQLiteInsertBase<TTable, TResultType, TRunResult>;\n\tselect(selectQuery: (qb: QueryBuilder) => SQL): SQLiteInsertBase<TTable, TResultType, TRunResult>;\n\tselect(selectQuery: SQL): SQLiteInsertBase<TTable, TResultType, TRunResult>;\n\tselect(selectQuery: SQLiteInsertSelectQueryBuilder<TTable>): SQLiteInsertBase<TTable, TResultType, TRunResult>;\n\tselect(\n\t\tselectQuery:\n\t\t\t| SQL\n\t\t\t| SQLiteInsertSelectQueryBuilder<TTable>\n\t\t\t| ((qb: QueryBuilder) => SQLiteInsertSelectQueryBuilder<TTable> | SQL),\n\t): SQLiteInsertBase<TTable, TResultType, TRunResult> {\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 SQLiteInsertBase(this.table, select, this.session, this.dialect, this.withList, true);\n\t}\n}\n\nexport type SQLiteInsertWithout<T extends AnySQLiteInsert, TDynamic extends boolean, K extends keyof T & string> =\n\tTDynamic extends true ? T\n\t\t: Omit<\n\t\t\tSQLiteInsertBase<\n\t\t\t\tT['_']['table'],\n\t\t\t\tT['_']['resultType'],\n\t\t\t\tT['_']['runResult'],\n\t\t\t\tT['_']['returning'],\n\t\t\t\tTDynamic,\n\t\t\t\tT['_']['excludedMethods'] | K\n\t\t\t>,\n\t\t\tT['_']['excludedMethods'] | K\n\t\t>;\n\nexport type SQLiteInsertReturning<\n\tT extends AnySQLiteInsert,\n\tTDynamic extends boolean,\n\tTSelectedFields extends SelectedFieldsFlat,\n> = SQLiteInsertWithout<\n\tSQLiteInsertBase<\n\t\tT['_']['table'],\n\t\tT['_']['resultType'],\n\t\tT['_']['runResult'],\n\t\tSelectResultFields<TSelectedFields>,\n\t\tTDynamic,\n\t\tT['_']['excludedMethods']\n\t>,\n\tTDynamic,\n\t'returning'\n>;\n\nexport type SQLiteInsertReturningAll<\n\tT extends AnySQLiteInsert,\n\tTDynamic extends boolean,\n> = SQLiteInsertWithout<\n\tSQLiteInsertBase<\n\t\tT['_']['table'],\n\t\tT['_']['resultType'],\n\t\tT['_']['runResult'],\n\t\tT['_']['table']['$inferSelect'],\n\t\tTDynamic,\n\t\tT['_']['excludedMethods']\n\t>,\n\tTDynamic,\n\t'returning'\n>;\n\nexport type SQLiteInsertOnConflictDoUpdateConfig<T extends AnySQLiteInsert> = {\n\ttarget: IndexColumn | IndexColumn[];\n\t/** @deprecated - use either `targetWhere` or `setWhere` */\n\twhere?: SQL;\n\t// TODO: add tests for targetWhere and setWhere\n\ttargetWhere?: SQL;\n\tsetWhere?: SQL;\n\tset: SQLiteUpdateSetSource<T['_']['table']>;\n};\n\nexport type SQLiteInsertDynamic<T extends AnySQLiteInsert> = SQLiteInsert<\n\tT['_']['table'],\n\tT['_']['resultType'],\n\tT['_']['runResult'],\n\tT['_']['returning']\n>;\n\nexport type SQLiteInsertExecute<T extends AnySQLiteInsert> = T['_']['returning'] extends undefined ? T['_']['runResult']\n\t: T['_']['returning'][];\n\nexport type SQLiteInsertPrepare<T extends AnySQLiteInsert> = SQLitePreparedQuery<\n\t{\n\t\ttype: T['_']['resultType'];\n\t\trun: T['_']['runResult'];\n\t\tall: T['_']['returning'] extends undefined ? DrizzleTypeError<'.all() cannot be used without .returning()'>\n\t\t\t: T['_']['returning'][];\n\t\tget: T['_']['returning'] extends undefined ? DrizzleTypeError<'.get() cannot be used without .returning()'>\n\t\t\t: T['_']['returning'];\n\t\tvalues: T['_']['returning'] extends undefined ? DrizzleTypeError<'.values() cannot be used without .returning()'>\n\t\t\t: any[][];\n\t\texecute: SQLiteInsertExecute<T>;\n\t}\n>;\n\nexport type AnySQLiteInsert = SQLiteInsertBase<any, any, any, any, any, any>;\n\nexport type SQLiteInsert<\n\tTTable extends SQLiteTable = SQLiteTable,\n\tTResultType extends 'sync' | 'async' = 'sync' | 'async',\n\tTRunResult = unknown,\n\tTReturning = any,\n> = SQLiteInsertBase<TTable, TResultType, TRunResult, TReturning, true, never>;\n\nexport interface SQLiteInsertBase<\n\tTTable extends SQLiteTable,\n\tTResultType extends 'sync' | 'async',\n\tTRunResult,\n\tTReturning = undefined,\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n> extends\n\tSQLWrapper,\n\tQueryPromise<TReturning extends undefined ? TRunResult : TReturning[]>,\n\tRunnableQuery<TReturning extends undefined ? TRunResult : TReturning[], 'sqlite'>\n{\n\treadonly _: {\n\t\treadonly dialect: 'sqlite';\n\t\treadonly table: TTable;\n\t\treadonly resultType: TResultType;\n\t\treadonly runResult: TRunResult;\n\t\treadonly returning: TReturning;\n\t\treadonly dynamic: TDynamic;\n\t\treadonly excludedMethods: TExcludedMethods;\n\t\treadonly result: TReturning extends undefined ? TRunResult : TReturning[];\n\t};\n}\n\nexport class SQLiteInsertBase<\n\tTTable extends SQLiteTable,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTResultType extends 'sync' | 'async',\n\tTRunResult,\n\tTReturning = 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 ? TRunResult : TReturning[]>\n\timplements RunnableQuery<TReturning extends undefined ? TRunResult : TReturning[], 'sqlite'>, SQLWrapper\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteInsert';\n\n\t/** @internal */\n\tconfig: SQLiteInsertConfig<TTable>;\n\n\tconstructor(\n\t\ttable: TTable,\n\t\tvalues: SQLiteInsertConfig['values'],\n\t\tprivate session: SQLiteSession<any, any, any, any>,\n\t\tprivate dialect: SQLiteDialect,\n\t\twithList?: Subquery[],\n\t\tselect?: boolean,\n\t) {\n\t\tsuper();\n\t\tthis.config = { table, values: values as any, withList, select };\n\t}\n\n\t/**\n\t * Adds a `returning` clause to the query.\n\t *\n\t * Calling this method will return the specified fields of the inserted rows. If no fields are specified, all fields will be returned.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/insert#insert-returning}\n\t *\n\t * @example\n\t * ```ts\n\t * // Insert one row and return all fields\n\t * const insertedCar: Car[] = await db.insert(cars)\n\t * .values({ brand: 'BMW' })\n\t * .returning();\n\t *\n\t * // Insert one row and return only the id\n\t * const insertedCarId: { id: number }[] = await db.insert(cars)\n\t * .values({ brand: 'BMW' })\n\t * .returning({ id: cars.id });\n\t * ```\n\t */\n\treturning(): SQLiteInsertReturningAll<this, TDynamic>;\n\treturning<TSelectedFields extends SelectedFieldsFlat>(\n\t\tfields: TSelectedFields,\n\t): SQLiteInsertReturning<this, TDynamic, TSelectedFields>;\n\treturning(\n\t\tfields: SelectedFieldsFlat = this.config.table[SQLiteTable.Symbol.Columns],\n\t): SQLiteInsertWithout<AnySQLiteInsert, TDynamic, 'returning'> {\n\t\tthis.config.returning = orderSelectedFields<SQLiteColumn>(fields);\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds an `on conflict do nothing` clause to the query.\n\t *\n\t * Calling this method simply avoids inserting a row as its alternative action.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/insert#on-conflict-do-nothing}\n\t *\n\t * @param config The `target` and `where` clauses.\n\t *\n\t * @example\n\t * ```ts\n\t * // Insert one row and cancel the insert if there's a conflict\n\t * await db.insert(cars)\n\t * .values({ id: 1, brand: 'BMW' })\n\t * .onConflictDoNothing();\n\t *\n\t * // Explicitly specify conflict target\n\t * await db.insert(cars)\n\t * .values({ id: 1, brand: 'BMW' })\n\t * .onConflictDoNothing({ target: cars.id });\n\t * ```\n\t */\n\tonConflictDoNothing(config: { target?: IndexColumn | IndexColumn[]; where?: SQL } = {}): this {\n\t\tif (!this.config.onConflict) this.config.onConflict = [];\n\n\t\tif (config.target === undefined) {\n\t\t\tthis.config.onConflict.push(sql` on conflict do nothing`);\n\t\t} else {\n\t\t\tconst targetSql = Array.isArray(config.target) ? sql`${config.target}` : sql`${[config.target]}`;\n\t\t\tconst whereSql = config.where ? sql` where ${config.where}` : sql``;\n\t\t\tthis.config.onConflict.push(sql` on conflict ${targetSql} do nothing${whereSql}`);\n\t\t}\n\t\treturn this;\n\t}\n\n\t/**\n\t * Adds an `on conflict do update` clause to the query.\n\t *\n\t * Calling this method will update the existing row that conflicts with the row proposed for insertion as its alternative action.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/insert#upserts-and-conflicts}\n\t *\n\t * @param config The `target`, `set` and `where` clauses.\n\t *\n\t * @example\n\t * ```ts\n\t * // Update the row if there's a conflict\n\t * await db.insert(cars)\n\t * .values({ id: 1, brand: 'BMW' })\n\t * .onConflictDoUpdate({\n\t * target: cars.id,\n\t * set: { brand: 'Porsche' }\n\t * });\n\t *\n\t * // Upsert with 'where' clause\n\t * await db.insert(cars)\n\t * .values({ id: 1, brand: 'BMW' })\n\t * .onConflictDoUpdate({\n\t * target: cars.id,\n\t * set: { brand: 'newBMW' },\n\t * where: sql`${cars.createdAt} > '2023-01-01'::date`,\n\t * });\n\t * ```\n\t */\n\tonConflictDoUpdate(config: SQLiteInsertOnConflictDoUpdateConfig<this>): this {\n\t\tif (config.where && (config.targetWhere || config.setWhere)) {\n\t\t\tthrow new Error(\n\t\t\t\t'You cannot use both \"where\" and \"targetWhere\"/\"setWhere\" at the same time - \"where\" is deprecated, use \"targetWhere\" or \"setWhere\" instead.',\n\t\t\t);\n\t\t}\n\n\t\tif (!this.config.onConflict) this.config.onConflict = [];\n\n\t\tconst whereSql = config.where ? sql` where ${config.where}` : undefined;\n\t\tconst targetWhereSql = config.targetWhere ? sql` where ${config.targetWhere}` : undefined;\n\t\tconst setWhereSql = config.setWhere ? sql` where ${config.setWhere}` : undefined;\n\t\tconst targetSql = Array.isArray(config.target) ? sql`${config.target}` : sql`${[config.target]}`;\n\t\tconst setSql = this.dialect.buildUpdateSet(this.config.table, mapUpdateSet(this.config.table, config.set));\n\t\tthis.config.onConflict.push(\n\t\t\tsql` on conflict ${targetSql}${targetWhereSql} do update set ${setSql}${whereSql}${setWhereSql}`,\n\t\t);\n\t\treturn this;\n\t}\n\n\t/** @internal */\n\tgetSQL(): SQL {\n\t\treturn this.dialect.buildInsertQuery(this.config);\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\t/** @internal */\n\t_prepare(isOneTimeQuery = true): SQLiteInsertPrepare<this> {\n\t\treturn this.session[isOneTimeQuery ? 'prepareOneTimeQuery' : 'prepareQuery'](\n\t\t\tthis.dialect.sqlToQuery(this.getSQL()),\n\t\t\tthis.config.returning,\n\t\t\tthis.config.returning ? 'all' : 'run',\n\t\t\ttrue,\n\t\t\tundefined,\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) as SQLiteInsertPrepare<this>;\n\t}\n\n\tprepare(): SQLiteInsertPrepare<this> {\n\t\treturn this._prepare(false);\n\t}\n\n\trun: ReturnType<this['prepare']>['run'] = (placeholderValues) => {\n\t\treturn this._prepare().run(placeholderValues);\n\t};\n\n\tall: ReturnType<this['prepare']>['all'] = (placeholderValues) => {\n\t\treturn this._prepare().all(placeholderValues);\n\t};\n\n\tget: ReturnType<this['prepare']>['get'] = (placeholderValues) => {\n\t\treturn this._prepare().get(placeholderValues);\n\t};\n\n\tvalues: ReturnType<this['prepare']>['values'] = (placeholderValues) => {\n\t\treturn this._prepare().values(placeholderValues);\n\t};\n\n\toverride async execute(): Promise<SQLiteInsertExecute<this>> {\n\t\treturn (this.config.returning ? this.all() : this.run()) as SQLiteInsertExecute<this>;\n\t}\n\n\t$dynamic(): SQLiteInsertDynamic<this> {\n\t\treturn this as any;\n\t}\n}\n","import type { ColumnsSelection, Placeholder, SQL, View } from '~/sql/sql.ts';\nimport type { SQLiteColumn } from '~/sqlite-core/columns/index.ts';\nimport type { SQLiteTable, SQLiteTableWithColumns } from '~/sqlite-core/table.ts';\nimport type { Assume, ValidateShape } from '~/utils.ts';\n\nimport type {\n\tSelectedFields as SelectFieldsBase,\n\tSelectedFieldsFlat as SelectFieldsFlatBase,\n\tSelectedFieldsOrdered as SelectFieldsOrderedBase,\n} from '~/operations.ts';\nimport type { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport type {\n\tAppendToNullabilityMap,\n\tAppendToResult,\n\tBuildSubquerySelection,\n\tGetSelectTableName,\n\tJoinNullability,\n\tJoinType,\n\tMapColumnsToTableAlias,\n\tSelectMode,\n\tSelectResult,\n\tSetOperator,\n} from '~/query-builders/select.types.ts';\nimport type { Subquery } from '~/subquery.ts';\nimport type { Table, UpdateTableConfig } from '~/table.ts';\nimport type { SQLitePreparedQuery } from '../session.ts';\nimport type { SQLiteViewBase } from '../view-base.ts';\nimport type { SQLiteViewWithSelection } from '../view.ts';\nimport type { SQLiteSelectBase, SQLiteSelectQueryBuilderBase } from './select.ts';\n\nexport interface SQLiteSelectJoinConfig {\n\ton: SQL | undefined;\n\ttable: SQLiteTable | Subquery | SQLiteViewBase | SQL;\n\talias: string | undefined;\n\tjoinType: JoinType;\n}\n\nexport type BuildAliasTable<TTable extends SQLiteTable | View, TAlias extends string> = TTable extends Table\n\t? SQLiteTableWithColumns<\n\t\tUpdateTableConfig<TTable['_']['config'], {\n\t\t\tname: TAlias;\n\t\t\tcolumns: MapColumnsToTableAlias<TTable['_']['columns'], TAlias, 'sqlite'>;\n\t\t}>\n\t>\n\t: TTable extends View ? SQLiteViewWithSelection<\n\t\t\tTAlias,\n\t\t\tTTable['_']['existing'],\n\t\t\tMapColumnsToTableAlias<TTable['_']['selectedFields'], TAlias, 'sqlite'>\n\t\t>\n\t: never;\n\nexport interface SQLiteSelectConfig {\n\twithList?: Subquery[];\n\tfields: Record<string, unknown>;\n\tfieldsFlat?: SelectedFieldsOrdered;\n\twhere?: SQL;\n\thaving?: SQL;\n\ttable: SQLiteTable | Subquery | SQLiteViewBase | SQL;\n\tlimit?: number | Placeholder;\n\toffset?: number | Placeholder;\n\tjoins?: SQLiteSelectJoinConfig[];\n\torderBy?: (SQLiteColumn | SQL | SQL.Aliased)[];\n\tgroupBy?: (SQLiteColumn | SQL | SQL.Aliased)[];\n\tdistinct?: boolean;\n\tsetOperators: {\n\t\trightSelect: TypedQueryBuilder<any, any>;\n\t\ttype: SetOperator;\n\t\tisAll: boolean;\n\t\torderBy?: (SQLiteColumn | SQL | SQL.Aliased)[];\n\t\tlimit?: number | Placeholder;\n\t\toffset?: number | Placeholder;\n\t}[];\n}\n\nexport type SQLiteSelectJoin<\n\tT extends AnySQLiteSelectQueryBuilder,\n\tTDynamic extends boolean,\n\tTJoinType extends JoinType,\n\tTJoinedTable extends SQLiteTable | Subquery | SQLiteViewBase | SQL,\n\tTJoinedName extends GetSelectTableName<TJoinedTable> = GetSelectTableName<TJoinedTable>,\n> = T extends any ? SQLiteSelectWithout<\n\t\tSQLiteSelectKind<\n\t\t\tT['_']['hkt'],\n\t\t\tT['_']['tableName'],\n\t\t\tT['_']['resultType'],\n\t\t\tT['_']['runResult'],\n\t\t\tAppendToResult<\n\t\t\t\tT['_']['tableName'],\n\t\t\t\tT['_']['selection'],\n\t\t\t\tTJoinedName,\n\t\t\t\tTJoinedTable extends SQLiteTable ? TJoinedTable['_']['columns']\n\t\t\t\t\t: TJoinedTable extends Subquery | View ? Assume<TJoinedTable['_']['selectedFields'], SelectedFields>\n\t\t\t\t\t: never,\n\t\t\t\tT['_']['selectMode']\n\t\t\t>,\n\t\t\tT['_']['selectMode'] extends 'partial' ? T['_']['selectMode'] : 'multiple',\n\t\t\tAppendToNullabilityMap<T['_']['nullabilityMap'], TJoinedName, TJoinType>,\n\t\t\tT['_']['dynamic'],\n\t\t\tT['_']['excludedMethods']\n\t\t>,\n\t\tTDynamic,\n\t\tT['_']['excludedMethods']\n\t>\n\t: never;\n\nexport type SQLiteSelectJoinFn<\n\tT extends AnySQLiteSelectQueryBuilder,\n\tTDynamic extends boolean,\n\tTJoinType extends JoinType,\n> = <\n\tTJoinedTable extends SQLiteTable | Subquery | SQLiteViewBase | SQL,\n\tTJoinedName extends GetSelectTableName<TJoinedTable> = GetSelectTableName<TJoinedTable>,\n>(\n\ttable: TJoinedTable,\n\ton: ((aliases: T['_']['selection']) => SQL | undefined) | SQL | undefined,\n) => SQLiteSelectJoin<T, TDynamic, TJoinType, TJoinedTable, TJoinedName>;\n\nexport type SQLiteSelectCrossJoinFn<\n\tT extends AnySQLiteSelectQueryBuilder,\n\tTDynamic extends boolean,\n> = <\n\tTJoinedTable extends SQLiteTable | Subquery | SQLiteViewBase | SQL,\n\tTJoinedName extends GetSelectTableName<TJoinedTable> = GetSelectTableName<TJoinedTable>,\n>(table: TJoinedTable) => SQLiteSelectJoin<T, TDynamic, 'cross', TJoinedTable, TJoinedName>;\n\nexport type SelectedFieldsFlat = SelectFieldsFlatBase<SQLiteColumn>;\n\nexport type SelectedFields = SelectFieldsBase<SQLiteColumn, SQLiteTable>;\n\nexport type SelectedFieldsOrdered = SelectFieldsOrderedBase<SQLiteColumn>;\n\nexport interface SQLiteSelectHKTBase {\n\ttableName: string | undefined;\n\tresultType: 'sync' | 'async';\n\trunResult: unknown;\n\tselection: unknown;\n\tselectMode: SelectMode;\n\tnullabilityMap: unknown;\n\tdynamic: boolean;\n\texcludedMethods: string;\n\tresult: unknown;\n\tselectedFields: unknown;\n\t_type: unknown;\n}\n\nexport type SQLiteSelectKind<\n\tT extends SQLiteSelectHKTBase,\n\tTTableName extends string | undefined,\n\tTResultType extends 'sync' | 'async',\n\tTRunResult,\n\tTSelection extends ColumnsSelection,\n\tTSelectMode extends SelectMode,\n\tTNullabilityMap extends Record<string, JoinNullability>,\n\tTDynamic extends boolean,\n\tTExcludedMethods extends string,\n\tTResult = SelectResult<TSelection, TSelectMode, TNullabilityMap>[],\n\tTSelectedFields = BuildSubquerySelection<TSelection, TNullabilityMap>,\n> = (T & {\n\ttableName: TTableName;\n\tresultType: TResultType;\n\trunResult: TRunResult;\n\tselection: TSelection;\n\tselectMode: TSelectMode;\n\tnullabilityMap: TNullabilityMap;\n\tdynamic: TDynamic;\n\texcludedMethods: TExcludedMethods;\n\tresult: TResult;\n\tselectedFields: TSelectedFields;\n})['_type'];\n\nexport interface SQLiteSelectQueryBuilderHKT extends SQLiteSelectHKTBase {\n\t_type: SQLiteSelectQueryBuilderBase<\n\t\tSQLiteSelectQueryBuilderHKT,\n\t\tthis['tableName'],\n\t\tthis['resultType'],\n\t\tthis['runResult'],\n\t\tAssume<this['selection'], ColumnsSelection>,\n\t\tthis['selectMode'],\n\t\tAssume<this['nullabilityMap'], Record<string, JoinNullability>>,\n\t\tthis['dynamic'],\n\t\tthis['excludedMethods'],\n\t\tAssume<this['result'], any[]>,\n\t\tAssume<this['selectedFields'], ColumnsSelection>\n\t>;\n}\n\nexport interface SQLiteSelectHKT extends SQLiteSelectHKTBase {\n\t_type: SQLiteSelectBase<\n\t\tthis['tableName'],\n\t\tthis['resultType'],\n\t\tthis['runResult'],\n\t\tAssume<this['selection'], ColumnsSelection>,\n\t\tthis['selectMode'],\n\t\tAssume<this['nullabilityMap'], Record<string, JoinNullability>>,\n\t\tthis['dynamic'],\n\t\tthis['excludedMethods'],\n\t\tAssume<this['result'], any[]>,\n\t\tAssume<this['selectedFields'], ColumnsSelection>\n\t>;\n}\n\nexport type SQLiteSetOperatorExcludedMethods =\n\t| 'config'\n\t| 'leftJoin'\n\t| 'rightJoin'\n\t| 'innerJoin'\n\t| 'fullJoin'\n\t| 'where'\n\t| 'having'\n\t| 'groupBy';\n\nexport type CreateSQLiteSelectFromBuilderMode<\n\tTBuilderMode extends 'db' | 'qb',\n\tTTableName extends string | undefined,\n\tTResultType extends 'sync' | 'async',\n\tTRunResult,\n\tTSelection extends ColumnsSelection,\n\tTSelectMode extends SelectMode,\n> = TBuilderMode extends 'db' ? SQLiteSelectBase<\n\t\tTTableName,\n\t\tTResultType,\n\t\tTRunResult,\n\t\tTSelection,\n\t\tTSelectMode\n\t>\n\t: SQLiteSelectQueryBuilderBase<\n\t\tSQLiteSelectQueryBuilderHKT,\n\t\tTTableName,\n\t\tTResultType,\n\t\tTRunResult,\n\t\tTSelection,\n\t\tTSelectMode\n\t>;\n\nexport type SQLiteSelectWithout<\n\tT extends AnySQLiteSelectQueryBuilder,\n\tTDynamic extends boolean,\n\tK extends keyof T & string,\n\tTResetExcluded extends boolean = false,\n> = TDynamic extends true ? T : Omit<\n\tSQLiteSelectKind<\n\t\tT['_']['hkt'],\n\t\tT['_']['tableName'],\n\t\tT['_']['resultType'],\n\t\tT['_']['runResult'],\n\t\tT['_']['selection'],\n\t\tT['_']['selectMode'],\n\t\tT['_']['nullabilityMap'],\n\t\tTDynamic,\n\t\tTResetExcluded extends true ? K : T['_']['excludedMethods'] | K,\n\t\tT['_']['result'],\n\t\tT['_']['selectedFields']\n\t>,\n\tTResetExcluded extends true ? K : T['_']['excludedMethods'] | K\n>;\n\nexport type SQLiteSelectExecute<T extends AnySQLiteSelect> = T['_']['result'];\n\nexport type SQLiteSelectPrepare<T extends AnySQLiteSelect> = SQLitePreparedQuery<\n\t{\n\t\ttype: T['_']['resultType'];\n\t\trun: T['_']['runResult'];\n\t\tall: T['_']['result'];\n\t\tget: T['_']['result'][number] | undefined;\n\t\tvalues: any[][];\n\t\texecute: SQLiteSelectExecute<T>;\n\t}\n>;\n\nexport type SQLiteSelectDynamic<T extends AnySQLiteSelectQueryBuilder> = SQLiteSelectKind<\n\tT['_']['hkt'],\n\tT['_']['tableName'],\n\tT['_']['resultType'],\n\tT['_']['runResult'],\n\tT['_']['selection'],\n\tT['_']['selectMode'],\n\tT['_']['nullabilityMap'],\n\ttrue,\n\tnever,\n\tT['_']['result'],\n\tT['_']['selectedFields']\n>;\n\nexport type SQLiteSelectQueryBuilder<\n\tTHKT extends SQLiteSelectHKTBase = SQLiteSelectQueryBuilderHKT,\n\tTTableName extends string | undefined = string | undefined,\n\tTResultType extends 'sync' | 'async' = 'sync' | 'async',\n\tTRunResult = unknown,\n\tTSelection extends ColumnsSelection = ColumnsSelection,\n\tTSelectMode extends SelectMode = SelectMode,\n\tTNullabilityMap extends Record<string, JoinNullability> = Record<string, JoinNullability>,\n\tTResult extends any[] = unknown[],\n\tTSelectedFields extends ColumnsSelection = ColumnsSelection,\n> = SQLiteSelectQueryBuilderBase<\n\tTHKT,\n\tTTableName,\n\tTResultType,\n\tTRunResult,\n\tTSelection,\n\tTSelectMode,\n\tTNullabilityMap,\n\ttrue,\n\tnever,\n\tTResult,\n\tTSelectedFields\n>;\n\nexport type AnySQLiteSelectQueryBuilder = SQLiteSelectQueryBuilderBase<\n\tany,\n\tany,\n\tany,\n\tany,\n\tany,\n\tany,\n\tany,\n\tany,\n\tany,\n\tany,\n\tany\n>;\n\nexport type AnySQLiteSetOperatorInterface = SQLiteSetOperatorInterface<any, any, any, any, any, any, any, any, any>;\n\nexport interface SQLiteSetOperatorInterface<\n\tTTableName extends string | undefined,\n\tTResultType extends 'sync' | 'async',\n\tTRunResult,\n\tTSelection extends ColumnsSelection,\n\tTSelectMode extends SelectMode = 'single',\n\tTNullabilityMap extends Record<string, JoinNullability> = TTableName extends string ? Record<TTableName, 'not-null'>\n\t\t: {},\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n\tTResult extends any[] = SelectResult<TSelection, TSelectMode, TNullabilityMap>[],\n\tTSelectedFields extends ColumnsSelection = BuildSubquerySelection<TSelection, TNullabilityMap>,\n> {\n\t_: {\n\t\treadonly hkt: SQLiteSelectHKTBase;\n\t\treadonly tableName: TTableName;\n\t\treadonly resultType: TResultType;\n\t\treadonly runResult: TRunResult;\n\t\treadonly selection: TSelection;\n\t\treadonly selectMode: TSelectMode;\n\t\treadonly nullabilityMap: TNullabilityMap;\n\t\treadonly dynamic: TDynamic;\n\t\treadonly excludedMethods: TExcludedMethods;\n\t\treadonly result: TResult;\n\t\treadonly selectedFields: TSelectedFields;\n\t};\n}\n\nexport type SQLiteSetOperatorWithResult<TResult extends any[]> = SQLiteSetOperatorInterface<\n\tany,\n\tany,\n\tany,\n\tany,\n\tany,\n\tany,\n\tany,\n\tany,\n\tTResult,\n\tany\n>;\n\nexport type SQLiteSelect<\n\tTTableName extends string | undefined = string | undefined,\n\tTResultType extends 'sync' | 'async' = 'sync' | 'async',\n\tTRunResult = unknown,\n\tTSelection extends ColumnsSelection = Record<string, any>,\n\tTSelectMode extends SelectMode = SelectMode,\n\tTNullabilityMap extends Record<string, JoinNullability> = Record<string, JoinNullability>,\n> = SQLiteSelectBase<TTableName, TResultType, TRunResult, TSelection, TSelectMode, TNullabilityMap, true, never>;\n\nexport type AnySQLiteSelect = SQLiteSelectBase<any, any, any, any, any, any, any, any, any, any>;\n\nexport type SQLiteSetOperator<\n\tTTableName extends string | undefined = string | undefined,\n\tTResultType extends 'sync' | 'async' = 'sync' | 'async',\n\tTRunResult = unknown,\n\tTSelection extends ColumnsSelection = Record<string, any>,\n\tTSelectMode extends SelectMode = SelectMode,\n\tTNullabilityMap extends Record<string, JoinNullability> = Record<string, JoinNullability>,\n> = SQLiteSelectBase<\n\tTTableName,\n\tTResultType,\n\tTRunResult,\n\tTSelection,\n\tTSelectMode,\n\tTNullabilityMap,\n\ttrue,\n\tSQLiteSetOperatorExcludedMethods\n>;\n\nexport type SetOperatorRightSelect<\n\tTValue extends SQLiteSetOperatorWithResult<TResult>,\n\tTResult extends any[],\n> = TValue extends SQLiteSetOperatorInterface<any, any, any, any, any, any, any, any, infer TValueResult, any>\n\t? ValidateShape<\n\t\tTValueResult[number],\n\t\tTResult[number],\n\t\tTypedQueryBuilder<any, TValueResult>\n\t>\n\t: TValue;\n\nexport type SetOperatorRestSelect<\n\tTValue extends readonly SQLiteSetOperatorWithResult<TResult>[],\n\tTResult extends any[],\n> = TValue extends [infer First, ...infer Rest]\n\t? First extends SQLiteSetOperatorInterface<any, any, any, any, any, any, any, any, infer TValueResult, any>\n\t\t? Rest extends AnySQLiteSetOperatorInterface[] ? [\n\t\t\t\tValidateShape<TValueResult[number], TResult[number], TypedQueryBuilder<any, TValueResult>>,\n\t\t\t\t...SetOperatorRestSelect<Rest, TResult>,\n\t\t\t]\n\t\t: ValidateShape<TValueResult[number], TResult[number], TypedQueryBuilder<any, TValueResult>[]>\n\t: never\n\t: TValue;\n\nexport type SQLiteCreateSetOperatorFn = <\n\tTTableName extends string | undefined,\n\tTResultType extends 'sync' | 'async',\n\tTRunResult,\n\tTSelection extends ColumnsSelection,\n\tTValue extends SQLiteSetOperatorWithResult<TResult>,\n\tTRest extends SQLiteSetOperatorWithResult<TResult>[],\n\tTSelectMode extends SelectMode = 'single',\n\tTNullabilityMap extends Record<string, JoinNullability> = TTableName extends string ? Record<TTableName, 'not-null'>\n\t\t: {},\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n\tTResult extends any[] = SelectResult<TSelection, TSelectMode, TNullabilityMap>[],\n\tTSelectedFields extends ColumnsSelection = BuildSubquerySelection<TSelection, TNullabilityMap>,\n>(\n\tleftSelect: SQLiteSetOperatorInterface<\n\t\tTTableName,\n\t\tTResultType,\n\t\tTRunResult,\n\t\tTSelection,\n\t\tTSelectMode,\n\t\tTNullabilityMap,\n\t\tTDynamic,\n\t\tTExcludedMethods,\n\t\tTResult,\n\t\tTSelectedFields\n\t>,\n\trightSelect: SetOperatorRightSelect<TValue, TResult>,\n\t...restSelects: SetOperatorRestSelect<TRest, TResult>\n) => SQLiteSelectWithout<\n\tSQLiteSelectBase<\n\t\tTTableName,\n\t\tTResultType,\n\t\tTRunResult,\n\t\tTSelection,\n\t\tTSelectMode,\n\t\tTNullabilityMap,\n\t\tTDynamic,\n\t\tTExcludedMethods,\n\t\tTResult,\n\t\tTSelectedFields\n\t>,\n\tfalse,\n\tSQLiteSetOperatorExcludedMethods,\n\ttrue\n>;\n\nexport type GetSQLiteSetOperators = {\n\tunion: SQLiteCreateSetOperatorFn;\n\tintersect: SQLiteCreateSetOperatorFn;\n\texcept: SQLiteCreateSetOperatorFn;\n\tunionAll: SQLiteCreateSetOperatorFn;\n};\n","import type { GetColumnData } from '~/column.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport type { JoinType, SelectResultFields } from '~/query-builders/select.types.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport type { Placeholder, Query, SQL, SQLWrapper } from '~/sql/sql.ts';\nimport type { SQLiteDialect } from '~/sqlite-core/dialect.ts';\nimport type { SQLitePreparedQuery, SQLiteSession } from '~/sqlite-core/session.ts';\nimport { SQLiteTable } from '~/sqlite-core/table.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { Table } from '~/table.ts';\nimport {\n\ttype DrizzleTypeError,\n\tgetTableLikeName,\n\tmapUpdateSet,\n\torderSelectedFields,\n\ttype UpdateSet,\n\ttype ValueOrArray,\n} from '~/utils.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport type { SQLiteColumn } from '../columns/common.ts';\nimport { extractUsedTable } from '../utils.ts';\nimport { SQLiteViewBase } from '../view-base.ts';\nimport type { SelectedFields, SelectedFieldsOrdered, SQLiteSelectJoinConfig } from './select.types.ts';\n\nexport interface SQLiteUpdateConfig {\n\twhere?: SQL | undefined;\n\tlimit?: number | Placeholder;\n\torderBy?: (SQLiteColumn | SQL | SQL.Aliased)[];\n\tset: UpdateSet;\n\ttable: SQLiteTable;\n\tfrom?: SQLiteTable | Subquery | SQLiteViewBase | SQL;\n\tjoins: SQLiteSelectJoinConfig[];\n\treturning?: SelectedFieldsOrdered;\n\twithList?: Subquery[];\n}\n\nexport type SQLiteUpdateSetSource<TTable extends SQLiteTable> =\n\t& {\n\t\t[Key in keyof TTable['$inferInsert']]?:\n\t\t\t| GetColumnData<TTable['_']['columns'][Key], 'query'>\n\t\t\t| SQL\n\t\t\t| SQLiteColumn\n\t\t\t| undefined;\n\t}\n\t& {};\n\nexport class SQLiteUpdateBuilder<\n\tTTable extends SQLiteTable,\n\tTResultType extends 'sync' | 'async',\n\tTRunResult,\n> {\n\tstatic readonly [entityKind]: string = 'SQLiteUpdateBuilder';\n\n\tdeclare readonly _: {\n\t\treadonly table: TTable;\n\t};\n\n\tconstructor(\n\t\tprotected table: TTable,\n\t\tprotected session: SQLiteSession<any, any, any, any>,\n\t\tprotected dialect: SQLiteDialect,\n\t\tprivate withList?: Subquery[],\n\t) {}\n\n\tset(\n\t\tvalues: SQLiteUpdateSetSource<TTable>,\n\t): SQLiteUpdateWithout<\n\t\tSQLiteUpdateBase<TTable, TResultType, TRunResult>,\n\t\tfalse,\n\t\t'leftJoin' | 'rightJoin' | 'innerJoin' | 'fullJoin'\n\t> {\n\t\treturn new SQLiteUpdateBase(\n\t\t\tthis.table,\n\t\t\tmapUpdateSet(this.table, values),\n\t\t\tthis.session,\n\t\t\tthis.dialect,\n\t\t\tthis.withList,\n\t\t) as any;\n\t}\n}\n\nexport type SQLiteUpdateWithout<\n\tT extends AnySQLiteUpdate,\n\tTDynamic extends boolean,\n\tK extends keyof T & string,\n> = TDynamic extends true ? T : Omit<\n\tSQLiteUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['resultType'],\n\t\tT['_']['runResult'],\n\t\tT['_']['from'],\n\t\tT['_']['returning'],\n\t\tTDynamic,\n\t\tT['_']['excludedMethods'] | K\n\t>,\n\tT['_']['excludedMethods'] | K\n>;\n\nexport type SQLiteUpdateWithJoins<\n\tT extends AnySQLiteUpdate,\n\tTDynamic extends boolean,\n\tTFrom extends SQLiteTable | Subquery | SQLiteViewBase | SQL,\n> = TDynamic extends true ? T : Omit<\n\tSQLiteUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['resultType'],\n\t\tT['_']['runResult'],\n\t\tTFrom,\n\t\tT['_']['returning'],\n\t\tTDynamic,\n\t\tExclude<T['_']['excludedMethods'] | 'from', 'leftJoin' | 'rightJoin' | 'innerJoin' | 'fullJoin'>\n\t>,\n\tExclude<T['_']['excludedMethods'] | 'from', 'leftJoin' | 'rightJoin' | 'innerJoin' | 'fullJoin'>\n>;\n\nexport type SQLiteUpdateReturningAll<T extends AnySQLiteUpdate, TDynamic extends boolean> = SQLiteUpdateWithout<\n\tSQLiteUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['resultType'],\n\t\tT['_']['runResult'],\n\t\tT['_']['from'],\n\t\tT['_']['table']['$inferSelect'],\n\t\tTDynamic,\n\t\tT['_']['excludedMethods']\n\t>,\n\tTDynamic,\n\t'returning'\n>;\n\nexport type SQLiteUpdateReturning<\n\tT extends AnySQLiteUpdate,\n\tTDynamic extends boolean,\n\tTSelectedFields extends SelectedFields,\n> = SQLiteUpdateWithout<\n\tSQLiteUpdateBase<\n\t\tT['_']['table'],\n\t\tT['_']['resultType'],\n\t\tT['_']['runResult'],\n\t\tT['_']['from'],\n\t\tSelectResultFields<TSelectedFields>,\n\t\tTDynamic,\n\t\tT['_']['excludedMethods']\n\t>,\n\tTDynamic,\n\t'returning'\n>;\n\nexport type SQLiteUpdateExecute<T extends AnySQLiteUpdate> = T['_']['returning'] extends undefined ? T['_']['runResult']\n\t: T['_']['returning'][];\n\nexport type SQLiteUpdatePrepare<T extends AnySQLiteUpdate> = SQLitePreparedQuery<\n\t{\n\t\ttype: T['_']['resultType'];\n\t\trun: T['_']['runResult'];\n\t\tall: T['_']['returning'] extends undefined ? DrizzleTypeError<'.all() cannot be used without .returning()'>\n\t\t\t: T['_']['returning'][];\n\t\tget: T['_']['returning'] extends undefined ? DrizzleTypeError<'.get() cannot be used without .returning()'>\n\t\t\t: T['_']['returning'];\n\t\tvalues: T['_']['returning'] extends undefined ? DrizzleTypeError<'.values() cannot be used without .returning()'>\n\t\t\t: any[][];\n\t\texecute: SQLiteUpdateExecute<T>;\n\t}\n>;\n\nexport type SQLiteUpdateJoinFn<\n\tT extends AnySQLiteUpdate,\n> = <\n\tTJoinedTable extends SQLiteTable | Subquery | SQLiteViewBase | SQL,\n>(\n\ttable: TJoinedTable,\n\ton:\n\t\t| (\n\t\t\t(\n\t\t\t\tupdateTable: T['_']['table']['_']['columns'],\n\t\t\t\tfrom: T['_']['from'] extends SQLiteTable ? T['_']['from']['_']['columns']\n\t\t\t\t\t: T['_']['from'] extends Subquery | SQLiteViewBase ? T['_']['from']['_']['selectedFields']\n\t\t\t\t\t: never,\n\t\t\t) => SQL | undefined\n\t\t)\n\t\t| SQL\n\t\t| undefined,\n) => T;\n\nexport type SQLiteUpdateDynamic<T extends AnySQLiteUpdate> = SQLiteUpdate<\n\tT['_']['table'],\n\tT['_']['resultType'],\n\tT['_']['runResult'],\n\tT['_']['returning']\n>;\n\nexport type SQLiteUpdate<\n\tTTable extends SQLiteTable = SQLiteTable,\n\tTResultType extends 'sync' | 'async' = 'sync' | 'async',\n\tTRunResult = any,\n\tTFrom extends SQLiteTable | Subquery | SQLiteViewBase | SQL | undefined = undefined,\n\tTReturning extends Record<string, unknown> | undefined = Record<string, unknown> | undefined,\n> = SQLiteUpdateBase<TTable, TResultType, TRunResult, TFrom, TReturning, true, never>;\n\nexport type AnySQLiteUpdate = SQLiteUpdateBase<any, any, any, any, any, any, any>;\n\nexport interface SQLiteUpdateBase<\n\tTTable extends SQLiteTable = SQLiteTable,\n\tTResultType extends 'sync' | 'async' = 'sync' | 'async',\n\tTRunResult = unknown,\n\tTFrom extends SQLiteTable | Subquery | SQLiteViewBase | SQL | undefined = undefined,\n\tTReturning = undefined,\n\tTDynamic extends boolean = false,\n\tTExcludedMethods extends string = never,\n> extends SQLWrapper, QueryPromise<TReturning extends undefined ? TRunResult : TReturning[]> {\n\treadonly _: {\n\t\treadonly dialect: 'sqlite';\n\t\treadonly table: TTable;\n\t\treadonly resultType: TResultType;\n\t\treadonly runResult: TRunResult;\n\t\treadonly from: TFrom;\n\t\treadonly returning: TReturning;\n\t\treadonly dynamic: TDynamic;\n\t\treadonly excludedMethods: TExcludedMethods;\n\t\treadonly result: TReturning extends undefined ? TRunResult : TReturning[];\n\t};\n}\n\nexport class SQLiteUpdateBase<\n\tTTable extends SQLiteTable = SQLiteTable,\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tTResultType extends 'sync' | 'async' = 'sync' | 'async',\n\tTRunResult = unknown,\n\tTFrom extends SQLiteTable | Subquery | SQLiteViewBase | SQL | undefined = undefined,\n\tTReturning = 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 ? TRunResult : TReturning[]>\n\timplements RunnableQuery<TReturning extends undefined ? TRunResult : TReturning[], 'sqlite'>, SQLWrapper\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteUpdate';\n\n\t/** @internal */\n\tconfig: SQLiteUpdateConfig;\n\n\tconstructor(\n\t\ttable: TTable,\n\t\tset: UpdateSet,\n\t\tprivate session: SQLiteSession<any, any, any, any>,\n\t\tprivate dialect: SQLiteDialect,\n\t\twithList?: Subquery[],\n\t) {\n\t\tsuper();\n\t\tthis.config = { set, table, withList, joins: [] };\n\t}\n\n\tfrom<TFrom extends SQLiteTable | Subquery | SQLiteViewBase | SQL>(\n\t\tsource: TFrom,\n\t): SQLiteUpdateWithJoins<this, TDynamic, TFrom> {\n\t\tthis.config.from = source;\n\t\treturn this as any;\n\t}\n\n\tprivate createJoin<TJoinType extends JoinType>(\n\t\tjoinType: TJoinType,\n\t): SQLiteUpdateJoinFn<this> {\n\t\treturn ((\n\t\t\ttable: SQLiteTable | Subquery | SQLiteViewBase | SQL,\n\t\t\ton: ((updateTable: TTable, from: TFrom) => SQL | undefined) | SQL | undefined,\n\t\t) => {\n\t\t\tconst tableName = getTableLikeName(table);\n\n\t\t\tif (typeof tableName === 'string' && this.config.joins.some((join) => join.alias === tableName)) {\n\t\t\t\tthrow new Error(`Alias \"${tableName}\" is already used in this query`);\n\t\t\t}\n\n\t\t\tif (typeof on === 'function') {\n\t\t\t\tconst from = this.config.from\n\t\t\t\t\t? is(table, SQLiteTable)\n\t\t\t\t\t\t? table[Table.Symbol.Columns]\n\t\t\t\t\t\t: is(table, Subquery)\n\t\t\t\t\t\t? table._.selectedFields\n\t\t\t\t\t\t: is(table, SQLiteViewBase)\n\t\t\t\t\t\t? table[ViewBaseConfig].selectedFields\n\t\t\t\t\t\t: undefined\n\t\t\t\t\t: undefined;\n\t\t\t\ton = on(\n\t\t\t\t\tnew Proxy(\n\t\t\t\t\t\tthis.config.table[Table.Symbol.Columns],\n\t\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t\t) as any,\n\t\t\t\t\tfrom && new Proxy(\n\t\t\t\t\t\tfrom,\n\t\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'sql', sqlBehavior: 'sql' }),\n\t\t\t\t\t) as any,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tthis.config.joins.push({ on, table, joinType, alias: tableName });\n\n\t\t\treturn this as any;\n\t\t}) as any;\n\t}\n\n\tleftJoin = this.createJoin('left');\n\n\trightJoin = this.createJoin('right');\n\n\tinnerJoin = this.createJoin('inner');\n\n\tfullJoin = this.createJoin('full');\n\n\t/**\n\t * Adds a 'where' clause to the query.\n\t *\n\t * Calling this method will update only those rows that fulfill a specified condition.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/update}\n\t *\n\t * @param where the 'where' clause.\n\t *\n\t * @example\n\t * You can use conditional operators and `sql function` to filter the rows to be updated.\n\t *\n\t * ```ts\n\t * // Update all cars with green color\n\t * db.update(cars).set({ color: 'red' })\n\t * .where(eq(cars.color, 'green'));\n\t * // or\n\t * db.update(cars).set({ color: 'red' })\n\t * .where(sql`${cars.color} = 'green'`)\n\t * ```\n\t *\n\t * You can logically combine conditional operators with `and()` and `or()` operators:\n\t *\n\t * ```ts\n\t * // Update all BMW cars with a green color\n\t * db.update(cars).set({ color: 'red' })\n\t * .where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n\t *\n\t * // Update all cars with the green or blue color\n\t * db.update(cars).set({ color: 'red' })\n\t * .where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n\t * ```\n\t */\n\twhere(where: SQL | undefined): SQLiteUpdateWithout<this, TDynamic, 'where'> {\n\t\tthis.config.where = where;\n\t\treturn this as any;\n\t}\n\n\torderBy(\n\t\tbuilder: (updateTable: TTable) => ValueOrArray<SQLiteColumn | SQL | SQL.Aliased>,\n\t): SQLiteUpdateWithout<this, TDynamic, 'orderBy'>;\n\torderBy(...columns: (SQLiteColumn | SQL | SQL.Aliased)[]): SQLiteUpdateWithout<this, TDynamic, 'orderBy'>;\n\torderBy(\n\t\t...columns:\n\t\t\t| [(updateTable: TTable) => ValueOrArray<SQLiteColumn | SQL | SQL.Aliased>]\n\t\t\t| (SQLiteColumn | SQL | SQL.Aliased)[]\n\t): SQLiteUpdateWithout<this, TDynamic, 'orderBy'> {\n\t\tif (typeof columns[0] === 'function') {\n\t\t\tconst orderBy = columns[0](\n\t\t\t\tnew Proxy(\n\t\t\t\t\tthis.config.table[Table.Symbol.Columns],\n\t\t\t\t\tnew SelectionProxyHandler({ sqlAliasedBehavior: 'alias', sqlBehavior: 'sql' }),\n\t\t\t\t) as any,\n\t\t\t);\n\n\t\t\tconst orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];\n\t\t\tthis.config.orderBy = orderByArray;\n\t\t} else {\n\t\t\tconst orderByArray = columns as (SQLiteColumn | SQL | SQL.Aliased)[];\n\t\t\tthis.config.orderBy = orderByArray;\n\t\t}\n\t\treturn this as any;\n\t}\n\n\tlimit(limit: number | Placeholder): SQLiteUpdateWithout<this, TDynamic, 'limit'> {\n\t\tthis.config.limit = limit;\n\t\treturn this as any;\n\t}\n\n\t/**\n\t * Adds a `returning` clause to the query.\n\t *\n\t * Calling this method will return the specified fields of the updated rows. If no fields are specified, all fields will be returned.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/update#update-with-returning}\n\t *\n\t * @example\n\t * ```ts\n\t * // Update all cars with the green color and return all fields\n\t * const updatedCars: Car[] = await db.update(cars)\n\t * .set({ color: 'red' })\n\t * .where(eq(cars.color, 'green'))\n\t * .returning();\n\t *\n\t * // Update all cars with the green color and return only their id and brand fields\n\t * const updatedCarsIdsAndBrands: { id: number, brand: string }[] = await db.update(cars)\n\t * .set({ color: 'red' })\n\t * .where(eq(cars.color, 'green'))\n\t * .returning({ id: cars.id, brand: cars.brand });\n\t * ```\n\t */\n\treturning(): SQLiteUpdateReturningAll<this, TDynamic>;\n\treturning<TSelectedFields extends SelectedFields>(\n\t\tfields: TSelectedFields,\n\t): SQLiteUpdateReturning<this, TDynamic, TSelectedFields>;\n\treturning(\n\t\tfields: SelectedFields = this.config.table[SQLiteTable.Symbol.Columns],\n\t): SQLiteUpdateWithout<AnySQLiteUpdate, TDynamic, 'returning'> {\n\t\tthis.config.returning = orderSelectedFields<SQLiteColumn>(fields);\n\t\treturn this as any;\n\t}\n\n\t/** @internal */\n\tgetSQL(): SQL {\n\t\treturn this.dialect.buildUpdateQuery(this.config);\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\t/** @internal */\n\t_prepare(isOneTimeQuery = true): SQLiteUpdatePrepare<this> {\n\t\treturn this.session[isOneTimeQuery ? 'prepareOneTimeQuery' : 'prepareQuery'](\n\t\t\tthis.dialect.sqlToQuery(this.getSQL()),\n\t\t\tthis.config.returning,\n\t\t\tthis.config.returning ? 'all' : 'run',\n\t\t\ttrue,\n\t\t\tundefined,\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) as SQLiteUpdatePrepare<this>;\n\t}\n\n\tprepare(): SQLiteUpdatePrepare<this> {\n\t\treturn this._prepare(false);\n\t}\n\n\trun: ReturnType<this['prepare']>['run'] = (placeholderValues) => {\n\t\treturn this._prepare().run(placeholderValues);\n\t};\n\n\tall: ReturnType<this['prepare']>['all'] = (placeholderValues) => {\n\t\treturn this._prepare().all(placeholderValues);\n\t};\n\n\tget: ReturnType<this['prepare']>['get'] = (placeholderValues) => {\n\t\treturn this._prepare().get(placeholderValues);\n\t};\n\n\tvalues: ReturnType<this['prepare']>['values'] = (placeholderValues) => {\n\t\treturn this._prepare().values(placeholderValues);\n\t};\n\n\toverride async execute(): Promise<SQLiteUpdateExecute<this>> {\n\t\treturn (this.config.returning ? this.all() : this.run()) as SQLiteUpdateExecute<this>;\n\t}\n\n\t$dynamic(): SQLiteUpdateDynamic<this> {\n\t\treturn this as any;\n\t}\n}\n","export * from './delete.ts';\nexport * from './insert.ts';\nexport * from './query-builder.ts';\nexport * from './select.ts';\nexport * from './select.types.ts';\nexport * from './update.ts';\n","import { entityKind } from '~/entity.ts';\nimport { SQL, sql, type SQLWrapper } from '~/sql/sql.ts';\nimport type { SQLiteSession } from '../session.ts';\nimport type { SQLiteTable } from '../table.ts';\nimport type { SQLiteView } from '../view.ts';\n\nexport class SQLiteCountBuilder<\n\tTSession extends SQLiteSession<any, any, any, any>,\n> extends SQL<number> implements Promise<number>, SQLWrapper {\n\tprivate sql: SQL<number>;\n\n\tstatic override readonly [entityKind] = 'SQLiteCountBuilderAsync';\n\t[Symbol.toStringTag] = 'SQLiteCountBuilderAsync';\n\n\tprivate session: TSession;\n\n\tprivate static buildEmbeddedCount(\n\t\tsource: SQLiteTable | SQLiteView | SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`(select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters})`;\n\t}\n\n\tprivate static buildCount(\n\t\tsource: SQLiteTable | SQLiteView | SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t): SQL<number> {\n\t\treturn sql<number>`select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters}`;\n\t}\n\n\tconstructor(\n\t\treadonly params: {\n\t\t\tsource: SQLiteTable | SQLiteView | SQL | SQLWrapper;\n\t\t\tfilters?: SQL<unknown>;\n\t\t\tsession: TSession;\n\t\t},\n\t) {\n\t\tsuper(SQLiteCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);\n\n\t\tthis.session = params.session;\n\n\t\tthis.sql = SQLiteCountBuilder.buildCount(\n\t\t\tparams.source,\n\t\t\tparams.filters,\n\t\t);\n\t}\n\n\tthen<TResult1 = number, TResult2 = never>(\n\t\tonfulfilled?: ((value: number) => TResult1 | PromiseLike<TResult1>) | null | undefined,\n\t\tonrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null | undefined,\n\t): Promise<TResult1 | TResult2> {\n\t\treturn Promise.resolve(this.session.count(this.sql)).then(\n\t\t\tonfulfilled,\n\t\t\tonrejected,\n\t\t);\n\t}\n\n\tcatch(\n\t\tonRejected?: ((reason: any) => never | PromiseLike<never>) | null | undefined,\n\t): Promise<number> {\n\t\treturn this.then(undefined, onRejected);\n\t}\n\n\tfinally(onFinally?: (() => void) | null | undefined): Promise<number> {\n\t\treturn this.then(\n\t\t\t(value) => {\n\t\t\t\tonFinally?.();\n\t\t\t\treturn value;\n\t\t\t},\n\t\t\t(reason) => {\n\t\t\t\tonFinally?.();\n\t\t\t\tthrow reason;\n\t\t\t},\n\t\t);\n\t}\n}\n","import { entityKind } from '~/entity.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport {\n\ttype BuildQueryResult,\n\ttype BuildRelationalQueryResult,\n\ttype DBQueryConfig,\n\tmapRelationalRow,\n\ttype TableRelationalConfig,\n\ttype TablesRelationalConfig,\n} from '~/relations.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport type { Query, QueryWithTypings, SQL, SQLWrapper } from '~/sql/sql.ts';\nimport type { KnownKeysOnly } from '~/utils.ts';\nimport type { SQLiteDialect } from '../dialect.ts';\nimport type { PreparedQueryConfig, SQLitePreparedQuery, SQLiteSession } from '../session.ts';\nimport type { SQLiteTable } from '../table.ts';\n\nexport type SQLiteRelationalQueryKind<TMode extends 'sync' | 'async', TResult> = TMode extends 'async'\n\t? SQLiteRelationalQuery<TMode, TResult>\n\t: SQLiteSyncRelationalQuery<TResult>;\n\nexport class RelationalQueryBuilder<\n\tTMode extends 'sync' | 'async',\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n\tTFields extends TableRelationalConfig,\n> {\n\tstatic readonly [entityKind]: string = 'SQLiteAsyncRelationalQueryBuilder';\n\n\tconstructor(\n\t\tprotected mode: TMode,\n\t\tprotected fullSchema: Record<string, unknown>,\n\t\tprotected schema: TSchema,\n\t\tprotected tableNamesMap: Record<string, string>,\n\t\tprotected table: SQLiteTable,\n\t\tprotected tableConfig: TableRelationalConfig,\n\t\tprotected dialect: SQLiteDialect,\n\t\tprotected session: SQLiteSession<'async', unknown, TFullSchema, TSchema>,\n\t) {}\n\n\tfindMany<TConfig extends DBQueryConfig<'many', true, TSchema, TFields>>(\n\t\tconfig?: KnownKeysOnly<TConfig, DBQueryConfig<'many', true, TSchema, TFields>>,\n\t): SQLiteRelationalQueryKind<TMode, BuildQueryResult<TSchema, TFields, TConfig>[]> {\n\t\treturn (this.mode === 'sync'\n\t\t\t? new SQLiteSyncRelationalQuery(\n\t\t\t\tthis.fullSchema,\n\t\t\t\tthis.schema,\n\t\t\t\tthis.tableNamesMap,\n\t\t\t\tthis.table,\n\t\t\t\tthis.tableConfig,\n\t\t\t\tthis.dialect,\n\t\t\t\tthis.session,\n\t\t\t\tconfig ? (config as DBQueryConfig<'many', true>) : {},\n\t\t\t\t'many',\n\t\t\t)\n\t\t\t: new SQLiteRelationalQuery(\n\t\t\t\tthis.fullSchema,\n\t\t\t\tthis.schema,\n\t\t\t\tthis.tableNamesMap,\n\t\t\t\tthis.table,\n\t\t\t\tthis.tableConfig,\n\t\t\t\tthis.dialect,\n\t\t\t\tthis.session,\n\t\t\t\tconfig ? (config as DBQueryConfig<'many', true>) : {},\n\t\t\t\t'many',\n\t\t\t)) as SQLiteRelationalQueryKind<TMode, BuildQueryResult<TSchema, TFields, TConfig>[]>;\n\t}\n\n\tfindFirst<TSelection extends Omit<DBQueryConfig<'many', true, TSchema, TFields>, 'limit'>>(\n\t\tconfig?: KnownKeysOnly<TSelection, Omit<DBQueryConfig<'many', true, TSchema, TFields>, 'limit'>>,\n\t): SQLiteRelationalQueryKind<TMode, BuildQueryResult<TSchema, TFields, TSelection> | undefined> {\n\t\treturn (this.mode === 'sync'\n\t\t\t? new SQLiteSyncRelationalQuery(\n\t\t\t\tthis.fullSchema,\n\t\t\t\tthis.schema,\n\t\t\t\tthis.tableNamesMap,\n\t\t\t\tthis.table,\n\t\t\t\tthis.tableConfig,\n\t\t\t\tthis.dialect,\n\t\t\t\tthis.session,\n\t\t\t\tconfig ? { ...(config as DBQueryConfig<'many', true> | undefined), limit: 1 } : { limit: 1 },\n\t\t\t\t'first',\n\t\t\t)\n\t\t\t: new SQLiteRelationalQuery(\n\t\t\t\tthis.fullSchema,\n\t\t\t\tthis.schema,\n\t\t\t\tthis.tableNamesMap,\n\t\t\t\tthis.table,\n\t\t\t\tthis.tableConfig,\n\t\t\t\tthis.dialect,\n\t\t\t\tthis.session,\n\t\t\t\tconfig ? { ...(config as DBQueryConfig<'many', true> | undefined), limit: 1 } : { limit: 1 },\n\t\t\t\t'first',\n\t\t\t)) as SQLiteRelationalQueryKind<TMode, BuildQueryResult<TSchema, TFields, TSelection> | undefined>;\n\t}\n}\n\nexport class SQLiteRelationalQuery<TType extends 'sync' | 'async', TResult> extends QueryPromise<TResult>\n\timplements RunnableQuery<TResult, 'sqlite'>, SQLWrapper\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteAsyncRelationalQuery';\n\n\tdeclare readonly _: {\n\t\treadonly dialect: 'sqlite';\n\t\treadonly type: TType;\n\t\treadonly result: TResult;\n\t};\n\n\t/** @internal */\n\tmode: 'many' | 'first';\n\n\tconstructor(\n\t\tprivate fullSchema: Record<string, unknown>,\n\t\tprivate schema: TablesRelationalConfig,\n\t\tprivate tableNamesMap: Record<string, string>,\n\t\t/** @internal */\n\t\tpublic table: SQLiteTable,\n\t\tprivate tableConfig: TableRelationalConfig,\n\t\tprivate dialect: SQLiteDialect,\n\t\tprivate session: SQLiteSession<'sync' | 'async', unknown, Record<string, unknown>, TablesRelationalConfig>,\n\t\tprivate config: DBQueryConfig<'many', true> | true,\n\t\tmode: 'many' | 'first',\n\t) {\n\t\tsuper();\n\t\tthis.mode = mode;\n\t}\n\n\t/** @internal */\n\tgetSQL(): SQL {\n\t\treturn this.dialect.buildRelationalQuery({\n\t\t\tfullSchema: this.fullSchema,\n\t\t\tschema: this.schema,\n\t\t\ttableNamesMap: this.tableNamesMap,\n\t\t\ttable: this.table,\n\t\t\ttableConfig: this.tableConfig,\n\t\t\tqueryConfig: this.config,\n\t\t\ttableAlias: this.tableConfig.tsName,\n\t\t}).sql as SQL;\n\t}\n\n\t/** @internal */\n\t_prepare(\n\t\tisOneTimeQuery = false,\n\t): SQLitePreparedQuery<PreparedQueryConfig & { type: TType; all: TResult; get: TResult; execute: TResult }> {\n\t\tconst { query, builtQuery } = this._toSQL();\n\n\t\treturn this.session[isOneTimeQuery ? 'prepareOneTimeQuery' : 'prepareQuery'](\n\t\t\tbuiltQuery,\n\t\t\tundefined,\n\t\t\tthis.mode === 'first' ? 'get' : 'all',\n\t\t\ttrue,\n\t\t\t(rawRows, mapColumnValue) => {\n\t\t\t\tconst rows = rawRows.map((row) =>\n\t\t\t\t\tmapRelationalRow(this.schema, this.tableConfig, row, query.selection, mapColumnValue)\n\t\t\t\t);\n\t\t\t\tif (this.mode === 'first') {\n\t\t\t\t\treturn rows[0] as TResult;\n\t\t\t\t}\n\t\t\t\treturn rows as TResult;\n\t\t\t},\n\t\t) as SQLitePreparedQuery<PreparedQueryConfig & { type: TType; all: TResult; get: TResult; execute: TResult }>;\n\t}\n\n\tprepare(): SQLitePreparedQuery<PreparedQueryConfig & { type: TType; all: TResult; get: TResult; execute: TResult }> {\n\t\treturn this._prepare(false);\n\t}\n\n\tprivate _toSQL(): { query: BuildRelationalQueryResult; builtQuery: QueryWithTypings } {\n\t\tconst query = this.dialect.buildRelationalQuery({\n\t\t\tfullSchema: this.fullSchema,\n\t\t\tschema: this.schema,\n\t\t\ttableNamesMap: this.tableNamesMap,\n\t\t\ttable: this.table,\n\t\t\ttableConfig: this.tableConfig,\n\t\t\tqueryConfig: this.config,\n\t\t\ttableAlias: this.tableConfig.tsName,\n\t\t});\n\n\t\tconst builtQuery = this.dialect.sqlToQuery(query.sql as SQL);\n\n\t\treturn { query, builtQuery };\n\t}\n\n\ttoSQL(): Query {\n\t\treturn this._toSQL().builtQuery;\n\t}\n\n\t/** @internal */\n\texecuteRaw(): TResult {\n\t\tif (this.mode === 'first') {\n\t\t\treturn this._prepare(false).get() as TResult;\n\t\t}\n\t\treturn this._prepare(false).all() as TResult;\n\t}\n\n\toverride async execute(): Promise<TResult> {\n\t\treturn this.executeRaw();\n\t}\n}\n\nexport class SQLiteSyncRelationalQuery<TResult> extends SQLiteRelationalQuery<'sync', TResult> {\n\tstatic override readonly [entityKind]: string = 'SQLiteSyncRelationalQuery';\n\n\tsync(): TResult {\n\t\treturn this.executeRaw();\n\t}\n}\n","import { entityKind } from '~/entity.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { RunnableQuery } from '~/runnable-query.ts';\nimport type { PreparedQuery } from '~/session.ts';\nimport type { SQL, SQLWrapper } from '~/sql/sql.ts';\nimport type { SQLiteAsyncDialect } from '../dialect.ts';\n\ntype SQLiteRawAction = 'all' | 'get' | 'values' | 'run';\nexport interface SQLiteRawConfig {\n\taction: SQLiteRawAction;\n}\n\nexport interface SQLiteRaw<TResult> extends QueryPromise<TResult>, RunnableQuery<TResult, 'sqlite'>, SQLWrapper {}\n\nexport class SQLiteRaw<TResult> extends QueryPromise<TResult>\n\timplements RunnableQuery<TResult, 'sqlite'>, SQLWrapper, PreparedQuery\n{\n\tstatic override readonly [entityKind]: string = 'SQLiteRaw';\n\n\tdeclare readonly _: {\n\t\treadonly dialect: 'sqlite';\n\t\treadonly result: TResult;\n\t};\n\n\t/** @internal */\n\tconfig: SQLiteRawConfig;\n\n\tconstructor(\n\t\tpublic execute: () => Promise<TResult>,\n\t\t/** @internal */\n\t\tpublic getSQL: () => SQL,\n\t\taction: SQLiteRawAction,\n\t\tprivate dialect: SQLiteAsyncDialect,\n\t\tprivate mapBatchResult: (result: unknown) => unknown,\n\t) {\n\t\tsuper();\n\t\tthis.config = { action };\n\t}\n\n\tgetQuery() {\n\t\treturn { ...this.dialect.sqlToQuery(this.getSQL()), method: this.config.action };\n\t}\n\n\tmapResult(result: unknown, isFromBatch?: boolean) {\n\t\treturn isFromBatch ? this.mapBatchResult(result) : result;\n\t}\n\n\t_prepare(): PreparedQuery {\n\t\treturn this;\n\t}\n\n\t/** @internal */\n\tisResponseInArrayMode(): boolean {\n\t\treturn false;\n\t}\n}\n","import type { Cache } from '~/cache/core/cache.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport type { ExtractTablesWithRelations, RelationalSchemaConfig, TablesRelationalConfig } from '~/relations.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport { type ColumnsSelection, type SQL, sql, type SQLWrapper } from '~/sql/sql.ts';\nimport type { SQLiteAsyncDialect, SQLiteSyncDialect } from '~/sqlite-core/dialect.ts';\nimport {\n\tQueryBuilder,\n\tSQLiteDeleteBase,\n\tSQLiteInsertBuilder,\n\tSQLiteSelectBuilder,\n\tSQLiteUpdateBuilder,\n} from '~/sqlite-core/query-builders/index.ts';\nimport type {\n\tDBResult,\n\tResult,\n\tSQLiteSession,\n\tSQLiteTransaction,\n\tSQLiteTransactionConfig,\n} from '~/sqlite-core/session.ts';\nimport type { SQLiteTable } from '~/sqlite-core/table.ts';\nimport { WithSubquery } from '~/subquery.ts';\nimport type { DrizzleTypeError } from '~/utils.ts';\nimport { SQLiteCountBuilder } from './query-builders/count.ts';\nimport { RelationalQueryBuilder } from './query-builders/query.ts';\nimport { SQLiteRaw } from './query-builders/raw.ts';\nimport type { SelectedFields } from './query-builders/select.types.ts';\nimport type { WithBuilder } from './subquery.ts';\nimport type { SQLiteViewBase } from './view-base.ts';\n\nexport class BaseSQLiteDatabase<\n\tTResultKind extends 'sync' | 'async',\n\tTRunResult,\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTSchema extends TablesRelationalConfig = ExtractTablesWithRelations<TFullSchema>,\n> {\n\tstatic readonly [entityKind]: string = 'BaseSQLiteDatabase';\n\n\tdeclare readonly _: {\n\t\treadonly schema: TSchema | undefined;\n\t\treadonly fullSchema: TFullSchema;\n\t\treadonly tableNamesMap: Record<string, string>;\n\t};\n\n\tquery: TFullSchema extends Record<string, never>\n\t\t? DrizzleTypeError<'Seems like the schema generic is missing - did you forget to add it to your DB type?'>\n\t\t: {\n\t\t\t[K in keyof TSchema]: RelationalQueryBuilder<TResultKind, TFullSchema, TSchema, TSchema[K]>;\n\t\t};\n\n\tconstructor(\n\t\tprivate resultKind: TResultKind,\n\t\t/** @internal */\n\t\treadonly dialect: { sync: SQLiteSyncDialect; async: SQLiteAsyncDialect }[TResultKind],\n\t\t/** @internal */\n\t\treadonly session: SQLiteSession<TResultKind, TRunResult, TFullSchema, TSchema>,\n\t\tschema: RelationalSchemaConfig<TSchema> | undefined,\n\t) {\n\t\tthis._ = schema\n\t\t\t? {\n\t\t\t\tschema: schema.schema,\n\t\t\t\tfullSchema: schema.fullSchema as TFullSchema,\n\t\t\t\ttableNamesMap: schema.tableNamesMap,\n\t\t\t}\n\t\t\t: {\n\t\t\t\tschema: undefined,\n\t\t\t\tfullSchema: {} as TFullSchema,\n\t\t\t\ttableNamesMap: {},\n\t\t\t};\n\t\tthis.query = {} as typeof this['query'];\n\t\tconst query = this.query as {\n\t\t\t[K in keyof TSchema]: RelationalQueryBuilder<TResultKind, TFullSchema, TSchema, TSchema[K]>;\n\t\t};\n\t\tif (this._.schema) {\n\t\t\tfor (const [tableName, columns] of Object.entries(this._.schema)) {\n\t\t\t\tquery[tableName as keyof TSchema] = new RelationalQueryBuilder(\n\t\t\t\t\tresultKind,\n\t\t\t\t\tschema!.fullSchema,\n\t\t\t\t\tthis._.schema,\n\t\t\t\t\tthis._.tableNamesMap,\n\t\t\t\t\tschema!.fullSchema[tableName] as SQLiteTable,\n\t\t\t\t\tcolumns,\n\t\t\t\t\tdialect,\n\t\t\t\t\tsession as SQLiteSession<any, any, any, any> as any,\n\t\t\t\t) as typeof query[keyof TSchema];\n\t\t\t}\n\t\t}\n\t\tthis.$cache = { invalidate: async (_params: any) => {} };\n\t}\n\n\t/**\n\t * Creates a subquery that defines a temporary named result set as a CTE.\n\t *\n\t * It is useful for breaking down complex queries into simpler parts and for reusing the result set in subsequent parts of the query.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#with-clause}\n\t *\n\t * @param alias The alias for the subquery.\n\t *\n\t * Failure to provide an alias will result in a DrizzleTypeError, preventing the subquery from being referenced in other queries.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Create a subquery with alias 'sq' and use it in the select query\n\t * const sq = db.$with('sq').as(db.select().from(users).where(eq(users.id, 42)));\n\t *\n\t * const result = await db.with(sq).select().from(sq);\n\t * ```\n\t *\n\t * To select arbitrary SQL values as fields in a CTE and reference them in other CTEs or in the main query, you need to add aliases to them:\n\t *\n\t * ```ts\n\t * // Select an arbitrary SQL value as a field in a CTE and reference it in the main query\n\t * const sq = db.$with('sq').as(db.select({\n\t * name: sql<string>`upper(${users.name})`.as('name'),\n\t * })\n\t * .from(users));\n\t *\n\t * const result = await db.with(sq).select({ name: sq.name }).from(sq);\n\t * ```\n\t */\n\t$with: WithBuilder = (alias: string, selection?: ColumnsSelection) => {\n\t\tconst self = this;\n\t\tconst as = (\n\t\t\tqb:\n\t\t\t\t| TypedQueryBuilder<ColumnsSelection | undefined>\n\t\t\t\t| SQL\n\t\t\t\t| ((qb: QueryBuilder) => TypedQueryBuilder<ColumnsSelection | undefined> | SQL),\n\t\t) => {\n\t\t\tif (typeof qb === 'function') {\n\t\t\t\tqb = qb(new QueryBuilder(self.dialect));\n\t\t\t}\n\n\t\t\treturn new Proxy(\n\t\t\t\tnew WithSubquery(\n\t\t\t\t\tqb.getSQL(),\n\t\t\t\t\tselection ?? ('getSelectedFields' in qb ? qb.getSelectedFields() ?? {} : {}) as SelectedFields,\n\t\t\t\t\talias,\n\t\t\t\t\ttrue,\n\t\t\t\t),\n\t\t\t\tnew SelectionProxyHandler({ alias, sqlAliasedBehavior: 'alias', sqlBehavior: 'error' }),\n\t\t\t);\n\t\t};\n\t\treturn { as };\n\t};\n\n\t$count(\n\t\tsource: SQLiteTable | SQLiteViewBase | SQL | SQLWrapper,\n\t\tfilters?: SQL<unknown>,\n\t) {\n\t\treturn new SQLiteCountBuilder({ source, filters, session: this.session });\n\t}\n\n\t/**\n\t * Incorporates a previously defined CTE (using `$with`) into the main query.\n\t *\n\t * This method allows the main query to reference a temporary named result set.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#with-clause}\n\t *\n\t * @param queries The CTEs to incorporate into the main query.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Define a subquery 'sq' as a CTE using $with\n\t * const sq = db.$with('sq').as(db.select().from(users).where(eq(users.id, 42)));\n\t *\n\t * // Incorporate the CTE 'sq' into the main query and select from it\n\t * const result = await db.with(sq).select().from(sq);\n\t * ```\n\t */\n\twith(...queries: WithSubquery[]) {\n\t\tconst self = this;\n\n\t\t/**\n\t\t * Creates a select query.\n\t\t *\n\t\t * Calling this method with no arguments will select all columns from the table. Pass a selection object to specify the columns you want to select.\n\t\t *\n\t\t * Use `.from()` method to specify which table to select from.\n\t\t *\n\t\t * See docs: {@link https://orm.drizzle.team/docs/select}\n\t\t *\n\t\t * @param fields The selection object.\n\t\t *\n\t\t * @example\n\t\t *\n\t\t * ```ts\n\t\t * // Select all columns and all rows from the 'cars' table\n\t\t * const allCars: Car[] = await db.select().from(cars);\n\t\t *\n\t\t * // Select specific columns and all rows from the 'cars' table\n\t\t * const carsIdsAndBrands: { id: number; brand: string }[] = await db.select({\n\t\t * id: cars.id,\n\t\t * brand: cars.brand\n\t\t * })\n\t\t * .from(cars);\n\t\t * ```\n\t\t *\n\t\t * Like in SQL, you can use arbitrary expressions as selection fields, not just table columns:\n\t\t *\n\t\t * ```ts\n\t\t * // Select specific columns along with expression and all rows from the 'cars' table\n\t\t * const carsIdsAndLowerNames: { id: number; lowerBrand: string }[] = await db.select({\n\t\t * id: cars.id,\n\t\t * lowerBrand: sql<string>`lower(${cars.brand})`,\n\t\t * })\n\t\t * .from(cars);\n\t\t * ```\n\t\t */\n\t\tfunction select(): SQLiteSelectBuilder<undefined, TResultKind, TRunResult>;\n\t\tfunction select<TSelection extends SelectedFields>(\n\t\t\tfields: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection, TResultKind, TRunResult>;\n\t\tfunction select(\n\t\t\tfields?: SelectedFields,\n\t\t): SQLiteSelectBuilder<SelectedFields | undefined, TResultKind, TRunResult> {\n\t\t\treturn new SQLiteSelectBuilder({\n\t\t\t\tfields: fields ?? undefined,\n\t\t\t\tsession: self.session,\n\t\t\t\tdialect: self.dialect,\n\t\t\t\twithList: queries,\n\t\t\t});\n\t\t}\n\n\t\t/**\n\t\t * Adds `distinct` expression to the select query.\n\t\t *\n\t\t * Calling this method will return only unique values. When multiple columns are selected, it returns rows with unique combinations of values in these columns.\n\t\t *\n\t\t * Use `.from()` method to specify which table to select from.\n\t\t *\n\t\t * See docs: {@link https://orm.drizzle.team/docs/select#distinct}\n\t\t *\n\t\t * @param fields The selection object.\n\t\t *\n\t\t * @example\n\t\t *\n\t\t * ```ts\n\t\t * // Select all unique rows from the 'cars' table\n\t\t * await db.selectDistinct()\n\t\t * .from(cars)\n\t\t * .orderBy(cars.id, cars.brand, cars.color);\n\t\t *\n\t\t * // Select all unique brands from the 'cars' table\n\t\t * await db.selectDistinct({ brand: cars.brand })\n\t\t * .from(cars)\n\t\t * .orderBy(cars.brand);\n\t\t * ```\n\t\t */\n\t\tfunction selectDistinct(): SQLiteSelectBuilder<undefined, TResultKind, TRunResult>;\n\t\tfunction selectDistinct<TSelection extends SelectedFields>(\n\t\t\tfields: TSelection,\n\t\t): SQLiteSelectBuilder<TSelection, TResultKind, TRunResult>;\n\t\tfunction selectDistinct(\n\t\t\tfields?: SelectedFields,\n\t\t): SQLiteSelectBuilder<SelectedFields | undefined, TResultKind, TRunResult> {\n\t\t\treturn new SQLiteSelectBuilder({\n\t\t\t\tfields: fields ?? undefined,\n\t\t\t\tsession: self.session,\n\t\t\t\tdialect: self.dialect,\n\t\t\t\twithList: queries,\n\t\t\t\tdistinct: true,\n\t\t\t});\n\t\t}\n\n\t\t/**\n\t\t * Creates an update query.\n\t\t *\n\t\t * Calling this method without `.where()` clause will update all rows in a table. The `.where()` clause specifies which rows should be updated.\n\t\t *\n\t\t * Use `.set()` method to specify which values to update.\n\t\t *\n\t\t * See docs: {@link https://orm.drizzle.team/docs/update}\n\t\t *\n\t\t * @param table The table to update.\n\t\t *\n\t\t * @example\n\t\t *\n\t\t * ```ts\n\t\t * // Update all rows in the 'cars' table\n\t\t * await db.update(cars).set({ color: 'red' });\n\t\t *\n\t\t * // Update rows with filters and conditions\n\t\t * await db.update(cars).set({ color: 'red' }).where(eq(cars.brand, 'BMW'));\n\t\t *\n\t\t * // Update with returning clause\n\t\t * const updatedCar: Car[] = await db.update(cars)\n\t\t * .set({ color: 'red' })\n\t\t * .where(eq(cars.id, 1))\n\t\t * .returning();\n\t\t * ```\n\t\t */\n\t\tfunction update<TTable extends SQLiteTable>(table: TTable): SQLiteUpdateBuilder<TTable, TResultKind, TRunResult> {\n\t\t\treturn new SQLiteUpdateBuilder(table, self.session, self.dialect, queries);\n\t\t}\n\n\t\t/**\n\t\t * Creates an insert query.\n\t\t *\n\t\t * Calling this method will create new rows in a table. Use `.values()` method to specify which values to insert.\n\t\t *\n\t\t * See docs: {@link https://orm.drizzle.team/docs/insert}\n\t\t *\n\t\t * @param table The table to insert into.\n\t\t *\n\t\t * @example\n\t\t *\n\t\t * ```ts\n\t\t * // Insert one row\n\t\t * await db.insert(cars).values({ brand: 'BMW' });\n\t\t *\n\t\t * // Insert multiple rows\n\t\t * await db.insert(cars).values([{ brand: 'BMW' }, { brand: 'Porsche' }]);\n\t\t *\n\t\t * // Insert with returning clause\n\t\t * const insertedCar: Car[] = await db.insert(cars)\n\t\t * .values({ brand: 'BMW' })\n\t\t * .returning();\n\t\t * ```\n\t\t */\n\t\tfunction insert<TTable extends SQLiteTable>(into: TTable): SQLiteInsertBuilder<TTable, TResultKind, TRunResult> {\n\t\t\treturn new SQLiteInsertBuilder(into, self.session, self.dialect, queries);\n\t\t}\n\n\t\t/**\n\t\t * Creates a delete query.\n\t\t *\n\t\t * Calling this method without `.where()` clause will delete all rows in a table. The `.where()` clause specifies which rows should be deleted.\n\t\t *\n\t\t * See docs: {@link https://orm.drizzle.team/docs/delete}\n\t\t *\n\t\t * @param table The table to delete from.\n\t\t *\n\t\t * @example\n\t\t *\n\t\t * ```ts\n\t\t * // Delete all rows in the 'cars' table\n\t\t * await db.delete(cars);\n\t\t *\n\t\t * // Delete rows with filters and conditions\n\t\t * await db.delete(cars).where(eq(cars.color, 'green'));\n\t\t *\n\t\t * // Delete with returning clause\n\t\t * const deletedCar: Car[] = await db.delete(cars)\n\t\t * .where(eq(cars.id, 1))\n\t\t * .returning();\n\t\t * ```\n\t\t */\n\t\tfunction delete_<TTable extends SQLiteTable>(from: TTable): SQLiteDeleteBase<TTable, TResultKind, TRunResult> {\n\t\t\treturn new SQLiteDeleteBase(from, self.session, self.dialect, queries);\n\t\t}\n\n\t\treturn { select, selectDistinct, update, insert, delete: delete_ };\n\t}\n\n\t/**\n\t * Creates a select query.\n\t *\n\t * Calling this method with no arguments will select all columns from the table. Pass a selection object to specify the columns you want to select.\n\t *\n\t * Use `.from()` method to specify which table to select from.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select}\n\t *\n\t * @param fields The selection object.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all columns and all rows from the 'cars' table\n\t * const allCars: Car[] = await db.select().from(cars);\n\t *\n\t * // Select specific columns and all rows from the 'cars' table\n\t * const carsIdsAndBrands: { id: number; brand: string }[] = await db.select({\n\t * id: cars.id,\n\t * brand: cars.brand\n\t * })\n\t * .from(cars);\n\t * ```\n\t *\n\t * Like in SQL, you can use arbitrary expressions as selection fields, not just table columns:\n\t *\n\t * ```ts\n\t * // Select specific columns along with expression and all rows from the 'cars' table\n\t * const carsIdsAndLowerNames: { id: number; lowerBrand: string }[] = await db.select({\n\t * id: cars.id,\n\t * lowerBrand: sql<string>`lower(${cars.brand})`,\n\t * })\n\t * .from(cars);\n\t * ```\n\t */\n\tselect(): SQLiteSelectBuilder<undefined, TResultKind, TRunResult>;\n\tselect<TSelection extends SelectedFields>(\n\t\tfields: TSelection,\n\t): SQLiteSelectBuilder<TSelection, TResultKind, TRunResult>;\n\tselect(fields?: SelectedFields): SQLiteSelectBuilder<SelectedFields | undefined, TResultKind, TRunResult> {\n\t\treturn new SQLiteSelectBuilder({ fields: fields ?? undefined, session: this.session, dialect: this.dialect });\n\t}\n\n\t/**\n\t * Adds `distinct` expression to the select query.\n\t *\n\t * Calling this method will return only unique values. When multiple columns are selected, it returns rows with unique combinations of values in these columns.\n\t *\n\t * Use `.from()` method to specify which table to select from.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/select#distinct}\n\t *\n\t * @param fields The selection object.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Select all unique rows from the 'cars' table\n\t * await db.selectDistinct()\n\t * .from(cars)\n\t * .orderBy(cars.id, cars.brand, cars.color);\n\t *\n\t * // Select all unique brands from the 'cars' table\n\t * await db.selectDistinct({ brand: cars.brand })\n\t * .from(cars)\n\t * .orderBy(cars.brand);\n\t * ```\n\t */\n\tselectDistinct(): SQLiteSelectBuilder<undefined, TResultKind, TRunResult>;\n\tselectDistinct<TSelection extends SelectedFields>(\n\t\tfields: TSelection,\n\t): SQLiteSelectBuilder<TSelection, TResultKind, TRunResult>;\n\tselectDistinct(\n\t\tfields?: SelectedFields,\n\t): SQLiteSelectBuilder<SelectedFields | undefined, TResultKind, TRunResult> {\n\t\treturn new SQLiteSelectBuilder({\n\t\t\tfields: fields ?? undefined,\n\t\t\tsession: this.session,\n\t\t\tdialect: this.dialect,\n\t\t\tdistinct: true,\n\t\t});\n\t}\n\n\t/**\n\t * Creates an update query.\n\t *\n\t * Calling this method without `.where()` clause will update all rows in a table. The `.where()` clause specifies which rows should be updated.\n\t *\n\t * Use `.set()` method to specify which values to update.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/update}\n\t *\n\t * @param table The table to update.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Update all rows in the 'cars' table\n\t * await db.update(cars).set({ color: 'red' });\n\t *\n\t * // Update rows with filters and conditions\n\t * await db.update(cars).set({ color: 'red' }).where(eq(cars.brand, 'BMW'));\n\t *\n\t * // Update with returning clause\n\t * const updatedCar: Car[] = await db.update(cars)\n\t * .set({ color: 'red' })\n\t * .where(eq(cars.id, 1))\n\t * .returning();\n\t * ```\n\t */\n\tupdate<TTable extends SQLiteTable>(table: TTable): SQLiteUpdateBuilder<TTable, TResultKind, TRunResult> {\n\t\treturn new SQLiteUpdateBuilder(table, this.session, this.dialect);\n\t}\n\n\t$cache: { invalidate: Cache['onMutate'] };\n\n\t/**\n\t * Creates an insert query.\n\t *\n\t * Calling this method will create new rows in a table. Use `.values()` method to specify which values to insert.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/insert}\n\t *\n\t * @param table The table to insert into.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Insert one row\n\t * await db.insert(cars).values({ brand: 'BMW' });\n\t *\n\t * // Insert multiple rows\n\t * await db.insert(cars).values([{ brand: 'BMW' }, { brand: 'Porsche' }]);\n\t *\n\t * // Insert with returning clause\n\t * const insertedCar: Car[] = await db.insert(cars)\n\t * .values({ brand: 'BMW' })\n\t * .returning();\n\t * ```\n\t */\n\tinsert<TTable extends SQLiteTable>(into: TTable): SQLiteInsertBuilder<TTable, TResultKind, TRunResult> {\n\t\treturn new SQLiteInsertBuilder(into, this.session, this.dialect);\n\t}\n\n\t/**\n\t * Creates a delete query.\n\t *\n\t * Calling this method without `.where()` clause will delete all rows in a table. The `.where()` clause specifies which rows should be deleted.\n\t *\n\t * See docs: {@link https://orm.drizzle.team/docs/delete}\n\t *\n\t * @param table The table to delete from.\n\t *\n\t * @example\n\t *\n\t * ```ts\n\t * // Delete all rows in the 'cars' table\n\t * await db.delete(cars);\n\t *\n\t * // Delete rows with filters and conditions\n\t * await db.delete(cars).where(eq(cars.color, 'green'));\n\t *\n\t * // Delete with returning clause\n\t * const deletedCar: Car[] = await db.delete(cars)\n\t * .where(eq(cars.id, 1))\n\t * .returning();\n\t * ```\n\t */\n\tdelete<TTable extends SQLiteTable>(from: TTable): SQLiteDeleteBase<TTable, TResultKind, TRunResult> {\n\t\treturn new SQLiteDeleteBase(from, this.session, this.dialect);\n\t}\n\n\trun(query: SQLWrapper | string): DBResult<TResultKind, TRunResult> {\n\t\tconst sequel = typeof query === 'string' ? sql.raw(query) : query.getSQL();\n\t\tif (this.resultKind === 'async') {\n\t\t\treturn new SQLiteRaw(\n\t\t\t\tasync () => this.session.run(sequel),\n\t\t\t\t() => sequel,\n\t\t\t\t'run',\n\t\t\t\tthis.dialect as SQLiteAsyncDialect,\n\t\t\t\tthis.session.extractRawRunValueFromBatchResult.bind(this.session),\n\t\t\t) as DBResult<TResultKind, TRunResult>;\n\t\t}\n\t\treturn this.session.run(sequel) as DBResult<TResultKind, TRunResult>;\n\t}\n\n\tall<T = unknown>(query: SQLWrapper | string): DBResult<TResultKind, T[]> {\n\t\tconst sequel = typeof query === 'string' ? sql.raw(query) : query.getSQL();\n\t\tif (this.resultKind === 'async') {\n\t\t\treturn new SQLiteRaw(\n\t\t\t\tasync () => this.session.all(sequel),\n\t\t\t\t() => sequel,\n\t\t\t\t'all',\n\t\t\t\tthis.dialect as SQLiteAsyncDialect,\n\t\t\t\tthis.session.extractRawAllValueFromBatchResult.bind(this.session),\n\t\t\t) as any;\n\t\t}\n\t\treturn this.session.all(sequel) as DBResult<TResultKind, T[]>;\n\t}\n\n\tget<T = unknown>(query: SQLWrapper | string): DBResult<TResultKind, T> {\n\t\tconst sequel = typeof query === 'string' ? sql.raw(query) : query.getSQL();\n\t\tif (this.resultKind === 'async') {\n\t\t\treturn new SQLiteRaw(\n\t\t\t\tasync () => this.session.get(sequel),\n\t\t\t\t() => sequel,\n\t\t\t\t'get',\n\t\t\t\tthis.dialect as SQLiteAsyncDialect,\n\t\t\t\tthis.session.extractRawGetValueFromBatchResult.bind(this.session),\n\t\t\t) as DBResult<TResultKind, T>;\n\t\t}\n\t\treturn this.session.get(sequel) as DBResult<TResultKind, T>;\n\t}\n\n\tvalues<T extends unknown[] = unknown[]>(query: SQLWrapper | string): DBResult<TResultKind, T[]> {\n\t\tconst sequel = typeof query === 'string' ? sql.raw(query) : query.getSQL();\n\t\tif (this.resultKind === 'async') {\n\t\t\treturn new SQLiteRaw(\n\t\t\t\tasync () => this.session.values(sequel),\n\t\t\t\t() => sequel,\n\t\t\t\t'values',\n\t\t\t\tthis.dialect as SQLiteAsyncDialect,\n\t\t\t\tthis.session.extractRawValuesValueFromBatchResult.bind(this.session),\n\t\t\t) as any;\n\t\t}\n\t\treturn this.session.values(sequel) as DBResult<TResultKind, T[]>;\n\t}\n\n\ttransaction<T>(\n\t\ttransaction: (tx: SQLiteTransaction<TResultKind, TRunResult, TFullSchema, TSchema>) => Result<TResultKind, T>,\n\t\tconfig?: SQLiteTransactionConfig,\n\t): Result<TResultKind, T> {\n\t\treturn this.session.transaction(transaction, config);\n\t}\n}\n\nexport type SQLiteWithReplicas<Q> = Q & { $primary: Q; $replicas: Q[] };\n\nexport const withReplicas = <\n\tTResultKind extends 'sync' | 'async',\n\tTRunResult,\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n\tQ extends BaseSQLiteDatabase<\n\t\tTResultKind,\n\t\tTRunResult,\n\t\tTFullSchema,\n\t\tTSchema extends Record<string, unknown> ? ExtractTablesWithRelations<TFullSchema> : TSchema\n\t>,\n>(\n\tprimary: Q,\n\treplicas: [Q, ...Q[]],\n\tgetReplica: (replicas: Q[]) => Q = () => replicas[Math.floor(Math.random() * replicas.length)]!,\n): SQLiteWithReplicas<Q> => {\n\tconst select: Q['select'] = (...args: []) => getReplica(replicas).select(...args);\n\tconst selectDistinct: Q['selectDistinct'] = (...args: []) => getReplica(replicas).selectDistinct(...args);\n\tconst $count: Q['$count'] = (...args: [any]) => getReplica(replicas).$count(...args);\n\tconst $with: Q['with'] = (...args: []) => getReplica(replicas).with(...args);\n\n\tconst update: Q['update'] = (...args: [any]) => primary.update(...args);\n\tconst insert: Q['insert'] = (...args: [any]) => primary.insert(...args);\n\tconst $delete: Q['delete'] = (...args: [any]) => primary.delete(...args);\n\tconst run: Q['run'] = (...args: [any]) => primary.run(...args);\n\tconst all: Q['all'] = (...args: [any]) => primary.all(...args);\n\tconst get: Q['get'] = (...args: [any]) => primary.get(...args);\n\tconst values: Q['values'] = (...args: [any]) => primary.values(...args);\n\tconst transaction: Q['transaction'] = (...args: [any]) => primary.transaction(...args);\n\n\treturn {\n\t\t...primary,\n\t\tupdate,\n\t\tinsert,\n\t\tdelete: $delete,\n\t\trun,\n\t\tall,\n\t\tget,\n\t\tvalues,\n\t\ttransaction,\n\t\t$primary: primary,\n\t\t$replicas: replicas,\n\t\tselect,\n\t\tselectDistinct,\n\t\t$count,\n\t\twith: $with,\n\t\tget query() {\n\t\t\treturn getReplica(replicas).query;\n\t\t},\n\t};\n};\n","import { entityKind } from '~/entity.ts';\nimport type { Table } from '~/index.ts';\nimport type { CacheConfig } from './types.ts';\n\nexport abstract class Cache {\n\tstatic readonly [entityKind]: string = 'Cache';\n\n\tabstract strategy(): 'explicit' | 'all';\n\n\t/**\n\t * Invoked if we should check cache for cached response\n\t * @param sql\n\t * @param tables\n\t */\n\tabstract get(\n\t\tkey: string,\n\t\ttables: string[],\n\t\tisTag: boolean,\n\t\tisAutoInvalidate?: boolean,\n\t): Promise<any[] | undefined>;\n\n\t/**\n\t * Invoked if new query should be inserted to cache\n\t * @param sql\n\t * @param tables\n\t */\n\tabstract put(\n\t\thashedQuery: string,\n\t\tresponse: any,\n\t\ttables: string[],\n\t\tisTag: boolean,\n\t\tconfig?: CacheConfig,\n\t): Promise<void>;\n\n\t/**\n\t * Invoked if insert, update, delete was invoked\n\t * @param tables\n\t */\n\tabstract onMutate(\n\t\tparams: MutationOption,\n\t): Promise<void>;\n}\n\nexport class NoopCache extends Cache {\n\toverride strategy() {\n\t\treturn 'all' as const;\n\t}\n\n\tstatic override readonly [entityKind]: string = 'NoopCache';\n\n\toverride async get(_key: string): Promise<any[] | undefined> {\n\t\treturn undefined;\n\t}\n\toverride async put(\n\t\t_hashedQuery: string,\n\t\t_response: any,\n\t\t_tables: string[],\n\t\t_config?: any,\n\t): Promise<void> {\n\t\t// noop\n\t}\n\toverride async onMutate(_params: MutationOption): Promise<void> {\n\t\t// noop\n\t}\n}\n\nexport type MutationOption = { tags?: string | string[]; tables?: Table<any> | Table<any>[] | string | string[] };\n\nexport async function hashQuery(sql: string, params?: any[]) {\n\tconst dataToHash = `${sql}-${JSON.stringify(params)}`;\n\tconst encoder = new TextEncoder();\n\tconst data = encoder.encode(dataToHash);\n\tconst hashBuffer = await crypto.subtle.digest('SHA-256', data);\n\tconst hashArray = [...new Uint8Array(hashBuffer)];\n\tconst hashHex = hashArray.map((b) => b.toString(16).padStart(2, '0')).join('');\n\n\treturn hashHex;\n}\n","export * from './cache.ts';\n","import { TableAliasProxyHandler } from '~/alias.ts';\nimport type { BuildAliasTable } from './query-builders/select.types.ts';\n\nimport type { SQLiteTable } from './table.ts';\nimport type { SQLiteViewBase } from './view-base.ts';\n\nexport function alias<TTable extends SQLiteTable | SQLiteViewBase, TAlias extends string>(\n\ttable: TTable,\n\talias: TAlias,\n): BuildAliasTable<TTable, TAlias> {\n\treturn new Proxy(table, new TableAliasProxyHandler(alias, false)) as any;\n}\n","import { type Cache, hashQuery, NoopCache } from '~/cache/core/cache.ts';\nimport type { WithCacheConfig } from '~/cache/core/types.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { DrizzleError, DrizzleQueryError, TransactionRollbackError } from '~/errors.ts';\nimport { QueryPromise } from '~/query-promise.ts';\nimport type { TablesRelationalConfig } from '~/relations.ts';\nimport type { PreparedQuery } from '~/session.ts';\nimport type { Query, SQL } from '~/sql/sql.ts';\nimport type { SQLiteAsyncDialect, SQLiteSyncDialect } from '~/sqlite-core/dialect.ts';\nimport { BaseSQLiteDatabase } from './db.ts';\nimport type { SQLiteRaw } from './query-builders/raw.ts';\nimport type { SelectedFieldsOrdered } from './query-builders/select.types.ts';\n\nexport interface PreparedQueryConfig {\n\ttype: 'sync' | 'async';\n\trun: unknown;\n\tall: unknown;\n\tget: unknown;\n\tvalues: unknown;\n\texecute: unknown;\n}\n\nexport class ExecuteResultSync<T> extends QueryPromise<T> {\n\tstatic override readonly [entityKind]: string = 'ExecuteResultSync';\n\n\tconstructor(private resultCb: () => T) {\n\t\tsuper();\n\t}\n\n\toverride async execute(): Promise<T> {\n\t\treturn this.resultCb();\n\t}\n\n\tsync(): T {\n\t\treturn this.resultCb();\n\t}\n}\n\nexport type ExecuteResult<TType extends 'sync' | 'async', TResult> = TType extends 'async' ? Promise<TResult>\n\t: ExecuteResultSync<TResult>;\n\nexport abstract class SQLitePreparedQuery<T extends PreparedQueryConfig> implements PreparedQuery {\n\tstatic readonly [entityKind]: string = 'PreparedQuery';\n\n\t/** @internal */\n\tjoinsNotNullableMap?: Record<string, boolean>;\n\n\tconstructor(\n\t\tprivate mode: 'sync' | 'async',\n\t\tprivate executeMethod: SQLiteExecuteMethod,\n\t\tprotected query: Query,\n\t\tprivate cache?: Cache,\n\t\t// per query related metadata\n\t\tprivate queryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t} | undefined,\n\t\t// config that was passed through $withCache\n\t\tprivate cacheConfig?: WithCacheConfig,\n\t) {\n\t\t// it means that no $withCache options were passed and it should be just enabled\n\t\tif (cache && cache.strategy() === 'all' && cacheConfig === undefined) {\n\t\t\tthis.cacheConfig = { enable: true, autoInvalidate: true };\n\t\t}\n\t\tif (!this.cacheConfig?.enable) {\n\t\t\tthis.cacheConfig = undefined;\n\t\t}\n\t}\n\n\t/** @internal */\n\tprotected async queryWithCache<T>(\n\t\tqueryString: string,\n\t\tparams: any[],\n\t\tquery: () => Promise<T>,\n\t): Promise<T> {\n\t\tif (this.cache === undefined || is(this.cache, NoopCache) || this.queryMetadata === undefined) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// don't do any mutations, if globally is false\n\t\tif (this.cacheConfig && !this.cacheConfig.enable) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// For mutate queries, we should query the database, wait for a response, and then perform invalidation\n\t\tif (\n\t\t\t(\n\t\t\t\tthis.queryMetadata.type === 'insert' || this.queryMetadata.type === 'update'\n\t\t\t\t|| this.queryMetadata.type === 'delete'\n\t\t\t) && this.queryMetadata.tables.length > 0\n\t\t) {\n\t\t\ttry {\n\t\t\t\tconst [res] = await Promise.all([\n\t\t\t\t\tquery(),\n\t\t\t\t\tthis.cache.onMutate({ tables: this.queryMetadata.tables }),\n\t\t\t\t]);\n\t\t\t\treturn res;\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// don't do any reads if globally disabled\n\t\tif (!this.cacheConfig) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\tif (this.queryMetadata.type === 'select') {\n\t\t\tconst fromCache = await this.cache.get(\n\t\t\t\tthis.cacheConfig.tag ?? await hashQuery(queryString, params),\n\t\t\t\tthis.queryMetadata.tables,\n\t\t\t\tthis.cacheConfig.tag !== undefined,\n\t\t\t\tthis.cacheConfig.autoInvalidate,\n\t\t\t);\n\t\t\tif (fromCache === undefined) {\n\t\t\t\tlet result;\n\t\t\t\ttry {\n\t\t\t\t\tresult = await query();\n\t\t\t\t} catch (e) {\n\t\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t\t}\n\n\t\t\t\t// put actual key\n\t\t\t\tawait this.cache.put(\n\t\t\t\t\tthis.cacheConfig.tag ?? await hashQuery(queryString, params),\n\t\t\t\t\tresult,\n\t\t\t\t\t// make sure we send tables that were used in a query only if user wants to invalidate it on each write\n\t\t\t\t\tthis.cacheConfig.autoInvalidate ? this.queryMetadata.tables : [],\n\t\t\t\t\tthis.cacheConfig.tag !== undefined,\n\t\t\t\t\tthis.cacheConfig.config,\n\t\t\t\t);\n\t\t\t\t// put flag if we should invalidate or not\n\t\t\t\treturn result;\n\t\t\t}\n\n\t\t\treturn fromCache as unknown as T;\n\t\t}\n\t\ttry {\n\t\t\treturn await query();\n\t\t} catch (e) {\n\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t}\n\t}\n\n\tgetQuery(): Query {\n\t\treturn this.query;\n\t}\n\n\tabstract run(placeholderValues?: Record<string, unknown>): Result<T['type'], T['run']>;\n\n\tmapRunResult(result: unknown, _isFromBatch?: boolean): unknown {\n\t\treturn result;\n\t}\n\n\tabstract all(placeholderValues?: Record<string, unknown>): Result<T['type'], T['all']>;\n\n\tmapAllResult(_result: unknown, _isFromBatch?: boolean): unknown {\n\t\tthrow new Error('Not implemented');\n\t}\n\n\tabstract get(placeholderValues?: Record<string, unknown>): Result<T['type'], T['get']>;\n\n\tmapGetResult(_result: unknown, _isFromBatch?: boolean): unknown {\n\t\tthrow new Error('Not implemented');\n\t}\n\n\tabstract values(placeholderValues?: Record<string, unknown>): Result<T['type'], T['values']>;\n\n\texecute(placeholderValues?: Record<string, unknown>): ExecuteResult<T['type'], T['execute']> {\n\t\tif (this.mode === 'async') {\n\t\t\treturn this[this.executeMethod](placeholderValues) as ExecuteResult<T['type'], T['execute']>;\n\t\t}\n\t\treturn new ExecuteResultSync(() => this[this.executeMethod](placeholderValues));\n\t}\n\n\tmapResult(response: unknown, isFromBatch?: boolean) {\n\t\tswitch (this.executeMethod) {\n\t\t\tcase 'run': {\n\t\t\t\treturn this.mapRunResult(response, isFromBatch);\n\t\t\t}\n\t\t\tcase 'all': {\n\t\t\t\treturn this.mapAllResult(response, isFromBatch);\n\t\t\t}\n\t\t\tcase 'get': {\n\t\t\t\treturn this.mapGetResult(response, isFromBatch);\n\t\t\t}\n\t\t}\n\t}\n\n\t/** @internal */\n\tabstract isResponseInArrayMode(): boolean;\n}\n\nexport interface SQLiteTransactionConfig {\n\tbehavior?: 'deferred' | 'immediate' | 'exclusive';\n}\n\nexport type SQLiteExecuteMethod = 'run' | 'all' | 'get';\n\nexport abstract class SQLiteSession<\n\tTResultKind extends 'sync' | 'async',\n\tTRunResult,\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> {\n\tstatic readonly [entityKind]: string = 'SQLiteSession';\n\n\tconstructor(\n\t\t/** @internal */\n\t\treadonly dialect: { sync: SQLiteSyncDialect; async: SQLiteAsyncDialect }[TResultKind],\n\t) {}\n\n\tabstract prepareQuery(\n\t\tquery: Query,\n\t\tfields: SelectedFieldsOrdered | undefined,\n\t\texecuteMethod: SQLiteExecuteMethod,\n\t\tisResponseInArrayMode: boolean,\n\t\tcustomResultMapper?: (rows: unknown[][], mapColumnValue?: (value: unknown) => unknown) => unknown,\n\t\tqueryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t},\n\t\tcacheConfig?: WithCacheConfig,\n\t): SQLitePreparedQuery<PreparedQueryConfig & { type: TResultKind }>;\n\n\tprepareOneTimeQuery(\n\t\tquery: Query,\n\t\tfields: SelectedFieldsOrdered | undefined,\n\t\texecuteMethod: SQLiteExecuteMethod,\n\t\tisResponseInArrayMode: boolean,\n\t\tcustomResultMapper?: (rows: unknown[][], mapColumnValue?: (value: unknown) => unknown) => unknown,\n\t\tqueryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t},\n\t\tcacheConfig?: WithCacheConfig,\n\t): SQLitePreparedQuery<PreparedQueryConfig & { type: TResultKind }> {\n\t\treturn this.prepareQuery(\n\t\t\tquery,\n\t\t\tfields,\n\t\t\texecuteMethod,\n\t\t\tisResponseInArrayMode,\n\t\t\tcustomResultMapper,\n\t\t\tqueryMetadata,\n\t\t\tcacheConfig,\n\t\t);\n\t}\n\n\tabstract transaction<T>(\n\t\ttransaction: (tx: SQLiteTransaction<TResultKind, TRunResult, TFullSchema, TSchema>) => Result<TResultKind, T>,\n\t\tconfig?: SQLiteTransactionConfig,\n\t): Result<TResultKind, T>;\n\n\trun(query: SQL): Result<TResultKind, TRunResult> {\n\t\tconst staticQuery = this.dialect.sqlToQuery(query);\n\t\ttry {\n\t\t\treturn this.prepareOneTimeQuery(staticQuery, undefined, 'run', false).run() as Result<TResultKind, TRunResult>;\n\t\t} catch (err) {\n\t\t\tthrow new DrizzleError({ cause: err, message: `Failed to run the query '${staticQuery.sql}'` });\n\t\t}\n\t}\n\n\t/** @internal */\n\textractRawRunValueFromBatchResult(result: unknown) {\n\t\treturn result;\n\t}\n\n\tall<T = unknown>(query: SQL): Result<TResultKind, T[]> {\n\t\treturn this.prepareOneTimeQuery(this.dialect.sqlToQuery(query), undefined, 'run', false).all() as Result<\n\t\t\tTResultKind,\n\t\t\tT[]\n\t\t>;\n\t}\n\n\t/** @internal */\n\textractRawAllValueFromBatchResult(_result: unknown): unknown {\n\t\tthrow new Error('Not implemented');\n\t}\n\n\tget<T = unknown>(query: SQL): Result<TResultKind, T> {\n\t\treturn this.prepareOneTimeQuery(this.dialect.sqlToQuery(query), undefined, 'run', false).get() as Result<\n\t\t\tTResultKind,\n\t\t\tT\n\t\t>;\n\t}\n\n\t/** @internal */\n\textractRawGetValueFromBatchResult(_result: unknown): unknown {\n\t\tthrow new Error('Not implemented');\n\t}\n\n\tvalues<T extends any[] = unknown[]>(\n\t\tquery: SQL,\n\t): Result<TResultKind, T[]> {\n\t\treturn this.prepareOneTimeQuery(this.dialect.sqlToQuery(query), undefined, 'run', false).values() as Result<\n\t\t\tTResultKind,\n\t\t\tT[]\n\t\t>;\n\t}\n\n\tasync count(sql: SQL) {\n\t\tconst result = await this.values(sql) as [[number]];\n\n\t\treturn result[0][0];\n\t}\n\n\t/** @internal */\n\textractRawValuesValueFromBatchResult(_result: unknown): unknown {\n\t\tthrow new Error('Not implemented');\n\t}\n}\n\nexport type Result<TKind extends 'sync' | 'async', TResult> = { sync: TResult; async: Promise<TResult> }[TKind];\n\nexport type DBResult<TKind extends 'sync' | 'async', TResult> = { sync: TResult; async: SQLiteRaw<TResult> }[TKind];\n\nexport abstract class SQLiteTransaction<\n\tTResultType extends 'sync' | 'async',\n\tTRunResult,\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends BaseSQLiteDatabase<TResultType, TRunResult, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'SQLiteTransaction';\n\n\tconstructor(\n\t\tresultType: TResultType,\n\t\tdialect: { sync: SQLiteSyncDialect; async: SQLiteAsyncDialect }[TResultType],\n\t\tsession: SQLiteSession<TResultType, TRunResult, TFullSchema, TSchema>,\n\t\tprotected schema: {\n\t\t\tfullSchema: Record<string, unknown>;\n\t\t\tschema: TSchema;\n\t\t\ttableNamesMap: Record<string, string>;\n\t\t} | undefined,\n\t\tprotected readonly nestedIndex = 0,\n\t) {\n\t\tsuper(resultType, dialect, session, schema);\n\t}\n\n\trollback(): never {\n\t\tthrow new TransactionRollbackError();\n\t}\n}\n","import type { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport type { AddAliasToSelection } from '~/query-builders/select.types.ts';\nimport type { ColumnsSelection, SQL } from '~/sql/sql.ts';\nimport type { Subquery, WithSubquery, WithSubqueryWithoutSelection } from '~/subquery.ts';\nimport type { QueryBuilder } from './query-builders/query-builder.ts';\n\nexport type SubqueryWithSelection<TSelection extends ColumnsSelection, TAlias extends string> =\n\t& Subquery<TAlias, AddAliasToSelection<TSelection, TAlias, 'sqlite'>>\n\t& AddAliasToSelection<TSelection, TAlias, 'sqlite'>;\n\nexport type WithSubqueryWithSelection<TSelection extends ColumnsSelection, TAlias extends string> =\n\t& WithSubquery<TAlias, AddAliasToSelection<TSelection, TAlias, 'sqlite'>>\n\t& AddAliasToSelection<TSelection, TAlias, 'sqlite'>;\n\nexport interface WithBuilder {\n\t<TAlias extends string>(alias: TAlias): {\n\t\tas: {\n\t\t\t<TSelection extends ColumnsSelection>(\n\t\t\t\tqb: TypedQueryBuilder<TSelection> | ((qb: QueryBuilder) => TypedQueryBuilder<TSelection>),\n\t\t\t): WithSubqueryWithSelection<TSelection, TAlias>;\n\t\t\t(\n\t\t\t\tqb: TypedQueryBuilder<undefined> | ((qb: QueryBuilder) => TypedQueryBuilder<undefined>),\n\t\t\t): WithSubqueryWithoutSelection<TAlias>;\n\t\t};\n\t};\n\t<TAlias extends string, TSelection extends ColumnsSelection>(alias: TAlias, selection: TSelection): {\n\t\tas: (qb: SQL | ((qb: QueryBuilder) => SQL)) => WithSubqueryWithSelection<TSelection, TAlias>;\n\t};\n}\n","import type { BuildColumns } from '~/column-builder.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { TypedQueryBuilder } from '~/query-builders/query-builder.ts';\nimport type { AddAliasToSelection } from '~/query-builders/select.types.ts';\nimport { SelectionProxyHandler } from '~/selection-proxy.ts';\nimport type { ColumnsSelection, SQL } from '~/sql/sql.ts';\nimport { getTableColumns } from '~/utils.ts';\nimport type { SQLiteColumn, SQLiteColumnBuilderBase } from './columns/common.ts';\nimport { QueryBuilder } from './query-builders/query-builder.ts';\nimport { sqliteTable } from './table.ts';\nimport { SQLiteViewBase } from './view-base.ts';\n\nexport interface ViewBuilderConfig {\n\talgorithm?: 'undefined' | 'merge' | 'temptable';\n\tdefiner?: string;\n\tsqlSecurity?: 'definer' | 'invoker';\n\twithCheckOption?: 'cascaded' | 'local';\n}\n\nexport class ViewBuilderCore<\n\tTConfig extends { name: string; columns?: unknown },\n> {\n\tstatic readonly [entityKind]: string = 'SQLiteViewBuilderCore';\n\n\tdeclare readonly _: {\n\t\treadonly name: TConfig['name'];\n\t\treadonly columns: TConfig['columns'];\n\t};\n\n\tconstructor(\n\t\tprotected name: TConfig['name'],\n\t) {}\n\n\tprotected config: ViewBuilderConfig = {};\n}\n\nexport class ViewBuilder<TName extends string = string> extends ViewBuilderCore<{ name: TName }> {\n\tstatic override readonly [entityKind]: string = 'SQLiteViewBuilder';\n\n\tas<TSelection extends ColumnsSelection>(\n\t\tqb: TypedQueryBuilder<TSelection> | ((qb: QueryBuilder) => TypedQueryBuilder<TSelection>),\n\t): SQLiteViewWithSelection<TName, false, AddAliasToSelection<TSelection, TName, 'sqlite'>> {\n\t\tif (typeof qb === 'function') {\n\t\t\tqb = qb(new QueryBuilder());\n\t\t}\n\t\tconst selectionProxy = new SelectionProxyHandler<TSelection>({\n\t\t\talias: this.name,\n\t\t\tsqlBehavior: 'error',\n\t\t\tsqlAliasedBehavior: 'alias',\n\t\t\treplaceOriginalName: true,\n\t\t});\n\t\t// const aliasedSelectedFields = new Proxy(qb.getSelectedFields(), selectionProxy);\n\t\tconst aliasedSelectedFields = qb.getSelectedFields();\n\t\treturn new Proxy(\n\t\t\tnew SQLiteView({\n\t\t\t\t// sqliteConfig: this.config,\n\t\t\t\tconfig: {\n\t\t\t\t\tname: this.name,\n\t\t\t\t\tschema: undefined,\n\t\t\t\t\tselectedFields: aliasedSelectedFields,\n\t\t\t\t\tquery: qb.getSQL().inlineParams(),\n\t\t\t\t},\n\t\t\t}),\n\t\t\tselectionProxy as any,\n\t\t) as SQLiteViewWithSelection<TName, false, AddAliasToSelection<TSelection, TName, 'sqlite'>>;\n\t}\n}\n\nexport class ManualViewBuilder<\n\tTName extends string = string,\n\tTColumns extends Record<string, SQLiteColumnBuilderBase> = Record<string, SQLiteColumnBuilderBase>,\n> extends ViewBuilderCore<\n\t{ name: TName; columns: TColumns }\n> {\n\tstatic override readonly [entityKind]: string = 'SQLiteManualViewBuilder';\n\n\tprivate columns: Record<string, SQLiteColumn>;\n\n\tconstructor(\n\t\tname: TName,\n\t\tcolumns: TColumns,\n\t) {\n\t\tsuper(name);\n\t\tthis.columns = getTableColumns(sqliteTable(name, columns)) as BuildColumns<TName, TColumns, 'sqlite'>;\n\t}\n\n\texisting(): SQLiteViewWithSelection<TName, true, BuildColumns<TName, TColumns, 'sqlite'>> {\n\t\treturn new Proxy(\n\t\t\tnew SQLiteView({\n\t\t\t\tconfig: {\n\t\t\t\t\tname: this.name,\n\t\t\t\t\tschema: undefined,\n\t\t\t\t\tselectedFields: this.columns,\n\t\t\t\t\tquery: undefined,\n\t\t\t\t},\n\t\t\t}),\n\t\t\tnew SelectionProxyHandler({\n\t\t\t\talias: this.name,\n\t\t\t\tsqlBehavior: 'error',\n\t\t\t\tsqlAliasedBehavior: 'alias',\n\t\t\t\treplaceOriginalName: true,\n\t\t\t}),\n\t\t) as SQLiteViewWithSelection<TName, true, BuildColumns<TName, TColumns, 'sqlite'>>;\n\t}\n\n\tas(query: SQL): SQLiteViewWithSelection<TName, false, BuildColumns<TName, TColumns, 'sqlite'>> {\n\t\treturn new Proxy(\n\t\t\tnew SQLiteView({\n\t\t\t\tconfig: {\n\t\t\t\t\tname: this.name,\n\t\t\t\t\tschema: undefined,\n\t\t\t\t\tselectedFields: this.columns,\n\t\t\t\t\tquery: query.inlineParams(),\n\t\t\t\t},\n\t\t\t}),\n\t\t\tnew SelectionProxyHandler({\n\t\t\t\talias: this.name,\n\t\t\t\tsqlBehavior: 'error',\n\t\t\t\tsqlAliasedBehavior: 'alias',\n\t\t\t\treplaceOriginalName: true,\n\t\t\t}),\n\t\t) as SQLiteViewWithSelection<TName, false, BuildColumns<TName, TColumns, 'sqlite'>>;\n\t}\n}\n\nexport class SQLiteView<\n\tTName extends string = string,\n\tTExisting extends boolean = boolean,\n\tTSelection extends ColumnsSelection = ColumnsSelection,\n> extends SQLiteViewBase<TName, TExisting, TSelection> {\n\tstatic override readonly [entityKind]: string = 'SQLiteView';\n\n\tconstructor({ config }: {\n\t\tconfig: {\n\t\t\tname: TName;\n\t\t\tschema: string | undefined;\n\t\t\tselectedFields: ColumnsSelection;\n\t\t\tquery: SQL | undefined;\n\t\t};\n\t}) {\n\t\tsuper(config);\n\t}\n}\n\nexport type SQLiteViewWithSelection<\n\tTName extends string,\n\tTExisting extends boolean,\n\tTSelection extends ColumnsSelection,\n> = SQLiteView<TName, TExisting, TSelection> & TSelection;\n\nexport function sqliteView<TName extends string>(name: TName): ViewBuilder<TName>;\nexport function sqliteView<TName extends string, TColumns extends Record<string, SQLiteColumnBuilderBase>>(\n\tname: TName,\n\tcolumns: TColumns,\n): ManualViewBuilder<TName, TColumns>;\nexport function sqliteView(\n\tname: string,\n\tselection?: Record<string, SQLiteColumnBuilderBase>,\n): ViewBuilder | ManualViewBuilder {\n\tif (selection) {\n\t\treturn new ManualViewBuilder(name, selection);\n\t}\n\treturn new ViewBuilder(name);\n}\n\nexport const view = sqliteView;\n","export * from './alias.ts';\nexport * from './checks.ts';\nexport * from './columns/index.ts';\nexport * from './db.ts';\nexport * from './dialect.ts';\nexport * from './foreign-keys.ts';\nexport * from './indexes.ts';\nexport * from './primary-keys.ts';\nexport * from './query-builders/index.ts';\nexport * from './session.ts';\nexport * from './subquery.ts';\nexport * from './table.ts';\nexport * from './unique-constraint.ts';\nexport * from './utils.ts';\nexport * from './view.ts';\n","import type { Database, RunResult, Statement } from 'better-sqlite3';\nimport { type Cache, NoopCache } from '~/cache/core/index.ts';\nimport type { WithCacheConfig } from '~/cache/core/types.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { Logger } from '~/logger.ts';\nimport { NoopLogger } from '~/logger.ts';\nimport type { RelationalSchemaConfig, TablesRelationalConfig } from '~/relations.ts';\nimport { fillPlaceholders, type Query, sql } from '~/sql/sql.ts';\nimport type { SQLiteSyncDialect } from '~/sqlite-core/dialect.ts';\nimport { SQLiteTransaction } from '~/sqlite-core/index.ts';\nimport type { SelectedFieldsOrdered } from '~/sqlite-core/query-builders/select.types.ts';\nimport {\n\ttype PreparedQueryConfig as PreparedQueryConfigBase,\n\ttype SQLiteExecuteMethod,\n\tSQLitePreparedQuery as PreparedQueryBase,\n\tSQLiteSession,\n\ttype SQLiteTransactionConfig,\n} from '~/sqlite-core/session.ts';\nimport { mapResultRow } from '~/utils.ts';\n\nexport interface BetterSQLiteSessionOptions {\n\tlogger?: Logger;\n\tcache?: Cache;\n}\n\ntype PreparedQueryConfig = Omit<PreparedQueryConfigBase, 'statement' | 'run'>;\n\nexport class BetterSQLiteSession<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends SQLiteSession<'sync', RunResult, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'BetterSQLiteSession';\n\n\tprivate logger: Logger;\n\tprivate cache: Cache;\n\n\tconstructor(\n\t\tprivate client: Database,\n\t\tdialect: SQLiteSyncDialect,\n\t\tprivate schema: RelationalSchemaConfig<TSchema> | undefined,\n\t\toptions: BetterSQLiteSessionOptions = {},\n\t) {\n\t\tsuper(dialect);\n\t\tthis.logger = options.logger ?? new NoopLogger();\n\t\tthis.cache = options.cache ?? new NoopCache();\n\t}\n\n\tprepareQuery<T extends Omit<PreparedQueryConfig, 'run'>>(\n\t\tquery: Query,\n\t\tfields: SelectedFieldsOrdered | undefined,\n\t\texecuteMethod: SQLiteExecuteMethod,\n\t\tisResponseInArrayMode: boolean,\n\t\tcustomResultMapper?: (rows: unknown[][]) => unknown,\n\t\tqueryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t},\n\t\tcacheConfig?: WithCacheConfig,\n\t): PreparedQuery<T> {\n\t\tconst stmt = this.client.prepare(query.sql);\n\t\treturn new PreparedQuery(\n\t\t\tstmt,\n\t\t\tquery,\n\t\t\tthis.logger,\n\t\t\tthis.cache,\n\t\t\tqueryMetadata,\n\t\t\tcacheConfig,\n\t\t\tfields,\n\t\t\texecuteMethod,\n\t\t\tisResponseInArrayMode,\n\t\t\tcustomResultMapper,\n\t\t);\n\t}\n\n\toverride transaction<T>(\n\t\ttransaction: (tx: BetterSQLiteTransaction<TFullSchema, TSchema>) => T,\n\t\tconfig: SQLiteTransactionConfig = {},\n\t): T {\n\t\tconst tx = new BetterSQLiteTransaction('sync', this.dialect, this, this.schema);\n\t\tconst nativeTx = this.client.transaction(transaction);\n\t\treturn nativeTx[config.behavior ?? 'deferred'](tx);\n\t}\n}\n\nexport class BetterSQLiteTransaction<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends SQLiteTransaction<'sync', RunResult, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'BetterSQLiteTransaction';\n\n\toverride transaction<T>(transaction: (tx: BetterSQLiteTransaction<TFullSchema, TSchema>) => T): T {\n\t\tconst savepointName = `sp${this.nestedIndex}`;\n\t\tconst tx = new BetterSQLiteTransaction('sync', this.dialect, this.session, this.schema, this.nestedIndex + 1);\n\t\tthis.session.run(sql.raw(`savepoint ${savepointName}`));\n\t\ttry {\n\t\t\tconst result = transaction(tx);\n\t\t\tthis.session.run(sql.raw(`release savepoint ${savepointName}`));\n\t\t\treturn result;\n\t\t} catch (err) {\n\t\t\tthis.session.run(sql.raw(`rollback to savepoint ${savepointName}`));\n\t\t\tthrow err;\n\t\t}\n\t}\n}\n\nexport class PreparedQuery<T extends PreparedQueryConfig = PreparedQueryConfig> extends PreparedQueryBase<\n\t{ type: 'sync'; run: RunResult; all: T['all']; get: T['get']; values: T['values']; execute: T['execute'] }\n> {\n\tstatic override readonly [entityKind]: string = 'BetterSQLitePreparedQuery';\n\n\tconstructor(\n\t\tprivate stmt: Statement,\n\t\tquery: Query,\n\t\tprivate logger: Logger,\n\t\tcache: Cache,\n\t\tqueryMetadata: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t} | undefined,\n\t\tcacheConfig: WithCacheConfig | undefined,\n\t\tprivate fields: SelectedFieldsOrdered | undefined,\n\t\texecuteMethod: SQLiteExecuteMethod,\n\t\tprivate _isResponseInArrayMode: boolean,\n\t\tprivate customResultMapper?: (rows: unknown[][]) => unknown,\n\t) {\n\t\tsuper('sync', executeMethod, query, cache, queryMetadata, cacheConfig);\n\t}\n\n\trun(placeholderValues?: Record<string, unknown>): RunResult {\n\t\tconst params = fillPlaceholders(this.query.params, placeholderValues ?? {});\n\t\tthis.logger.logQuery(this.query.sql, params);\n\t\treturn this.stmt.run(...params);\n\t}\n\n\tall(placeholderValues?: Record<string, unknown>): T['all'] {\n\t\tconst { fields, joinsNotNullableMap, query, logger, stmt, customResultMapper } = this;\n\t\tif (!fields && !customResultMapper) {\n\t\t\tconst params = fillPlaceholders(query.params, placeholderValues ?? {});\n\t\t\tlogger.logQuery(query.sql, params);\n\t\t\treturn stmt.all(...params);\n\t\t}\n\n\t\tconst rows = this.values(placeholderValues) as unknown[][];\n\t\tif (customResultMapper) {\n\t\t\treturn customResultMapper(rows) as T['all'];\n\t\t}\n\t\treturn rows.map((row) => mapResultRow(fields!, row, joinsNotNullableMap));\n\t}\n\n\tget(placeholderValues?: Record<string, unknown>): T['get'] {\n\t\tconst params = fillPlaceholders(this.query.params, placeholderValues ?? {});\n\t\tthis.logger.logQuery(this.query.sql, params);\n\n\t\tconst { fields, stmt, joinsNotNullableMap, customResultMapper } = this;\n\t\tif (!fields && !customResultMapper) {\n\t\t\treturn stmt.get(...params);\n\t\t}\n\n\t\tconst row = stmt.raw().get(...params) as unknown[];\n\n\t\tif (!row) {\n\t\t\treturn undefined;\n\t\t}\n\n\t\tif (customResultMapper) {\n\t\t\treturn customResultMapper([row]) as T['get'];\n\t\t}\n\n\t\treturn mapResultRow(fields!, row, joinsNotNullableMap);\n\t}\n\n\tvalues(placeholderValues?: Record<string, unknown>): T['values'] {\n\t\tconst params = fillPlaceholders(this.query.params, placeholderValues ?? {});\n\t\tthis.logger.logQuery(this.query.sql, params);\n\t\treturn this.stmt.raw().all(...params) as T['values'];\n\t}\n\n\t/** @internal */\n\tisResponseInArrayMode(): boolean {\n\t\treturn this._isResponseInArrayMode;\n\t}\n}\n","import Client, { type Database, type Options, type RunResult } from 'better-sqlite3';\nimport { entityKind } from '~/entity.ts';\nimport { DefaultLogger } from '~/logger.ts';\nimport {\n\tcreateTableRelationsHelpers,\n\textractTablesRelationalConfig,\n\ttype RelationalSchemaConfig,\n\ttype TablesRelationalConfig,\n} from '~/relations.ts';\nimport { BaseSQLiteDatabase } from '~/sqlite-core/db.ts';\nimport { SQLiteSyncDialect } from '~/sqlite-core/dialect.ts';\nimport { type DrizzleConfig, isConfig } from '~/utils.ts';\nimport { BetterSQLiteSession } from './session.ts';\n\nexport type DrizzleBetterSQLite3DatabaseConfig =\n\t| ({\n\t\tsource?:\n\t\t\t| string\n\t\t\t| Buffer;\n\t} & Options)\n\t| string\n\t| undefined;\n\nexport class BetterSQLite3Database<TSchema extends Record<string, unknown> = Record<string, never>>\n\textends BaseSQLiteDatabase<'sync', RunResult, TSchema>\n{\n\tstatic override readonly [entityKind]: string = 'BetterSQLite3Database';\n}\n\nfunction construct<TSchema extends Record<string, unknown> = Record<string, never>>(\n\tclient: Database,\n\tconfig: Omit<DrizzleConfig<TSchema>, 'cache'> = {},\n): BetterSQLite3Database<TSchema> & {\n\t$client: Database;\n} {\n\tconst dialect = new SQLiteSyncDialect({ casing: config.casing });\n\tlet logger;\n\tif (config.logger === true) {\n\t\tlogger = new DefaultLogger();\n\t} else if (config.logger !== false) {\n\t\tlogger = config.logger;\n\t}\n\n\tlet schema: RelationalSchemaConfig<TablesRelationalConfig> | undefined;\n\tif (config.schema) {\n\t\tconst tablesConfig = extractTablesRelationalConfig(\n\t\t\tconfig.schema,\n\t\t\tcreateTableRelationsHelpers,\n\t\t);\n\t\tschema = {\n\t\t\tfullSchema: config.schema,\n\t\t\tschema: tablesConfig.tables,\n\t\t\ttableNamesMap: tablesConfig.tableNamesMap,\n\t\t};\n\t}\n\n\tconst session = new BetterSQLiteSession(client, dialect, schema, { logger });\n\tconst db = new BetterSQLite3Database('sync', dialect, session, schema);\n\t(<any> db).$client = client;\n\t// (<any> db).$cache = config.cache;\n\t// if ((<any> db).$cache) {\n\t// \t(<any> db).$cache['invalidate'] = config.cache?.onMutate;\n\t// }\n\n\treturn db as any;\n}\n\nexport function drizzle<\n\tTSchema extends Record<string, unknown> = Record<string, never>,\n>(\n\t...params:\n\t\t| []\n\t\t| [\n\t\t\tDatabase | string,\n\t\t]\n\t\t| [\n\t\t\tDatabase | string,\n\t\t\tDrizzleConfig<TSchema>,\n\t\t]\n\t\t| [\n\t\t\t(\n\t\t\t\t& DrizzleConfig<TSchema>\n\t\t\t\t& ({\n\t\t\t\t\tconnection?: DrizzleBetterSQLite3DatabaseConfig;\n\t\t\t\t} | {\n\t\t\t\t\tclient: Database;\n\t\t\t\t})\n\t\t\t),\n\t\t]\n): BetterSQLite3Database<TSchema> & {\n\t$client: Database;\n} {\n\tif (params[0] === undefined || typeof params[0] === 'string') {\n\t\tconst instance = params[0] === undefined ? new Client() : new Client(params[0]);\n\n\t\treturn construct(instance, params[1]) as any;\n\t}\n\n\tif (isConfig(params[0])) {\n\t\tconst { connection, client, ...drizzleConfig } = params[0] as\n\t\t\t& {\n\t\t\t\tconnection?: DrizzleBetterSQLite3DatabaseConfig;\n\t\t\t\tclient?: Database;\n\t\t\t}\n\t\t\t& DrizzleConfig<TSchema>;\n\n\t\tif (client) return construct(client, drizzleConfig) as any;\n\n\t\tif (typeof connection === 'object') {\n\t\t\tconst { source, ...options } = connection;\n\n\t\t\tconst instance = new Client(source, options);\n\n\t\t\treturn construct(instance, drizzleConfig) as any;\n\t\t}\n\n\t\tconst instance = new Client(connection);\n\n\t\treturn construct(instance, drizzleConfig) as any;\n\t}\n\n\treturn construct(params[0] as Database, params[1] as DrizzleConfig<TSchema> | undefined) as any;\n}\n\nexport namespace drizzle {\n\texport function mock<TSchema extends Record<string, unknown> = Record<string, never>>(\n\t\tconfig?: DrizzleConfig<TSchema>,\n\t): BetterSQLite3Database<TSchema> & {\n\t\t$client: '$client is not available on drizzle.mock()';\n\t} {\n\t\treturn construct({} as any, config) as any;\n\t}\n}\n","export * from './driver.ts';\nexport * from './session.ts';\n","function parsePgArrayValue(arrayString, startFrom, inQuotes) {\n for (let i = startFrom; i < arrayString.length; i++) {\n const char = arrayString[i];\n if (char === \"\\\\\") {\n i++;\n continue;\n }\n if (char === '\"') {\n return [arrayString.slice(startFrom, i).replace(/\\\\/g, \"\"), i + 1];\n }\n if (inQuotes) {\n continue;\n }\n if (char === \",\" || char === \"}\") {\n return [arrayString.slice(startFrom, i).replace(/\\\\/g, \"\"), i];\n }\n }\n return [arrayString.slice(startFrom).replace(/\\\\/g, \"\"), arrayString.length];\n}\nfunction parsePgNestedArray(arrayString, startFrom = 0) {\n const result = [];\n let i = startFrom;\n let lastCharIsComma = false;\n while (i < arrayString.length) {\n const char = arrayString[i];\n if (char === \",\") {\n if (lastCharIsComma || i === startFrom) {\n result.push(\"\");\n }\n lastCharIsComma = true;\n i++;\n continue;\n }\n lastCharIsComma = false;\n if (char === \"\\\\\") {\n i += 2;\n continue;\n }\n if (char === '\"') {\n const [value2, startFrom2] = parsePgArrayValue(arrayString, i + 1, true);\n result.push(value2);\n i = startFrom2;\n continue;\n }\n if (char === \"}\") {\n return [result, i + 1];\n }\n if (char === \"{\") {\n const [value2, startFrom2] = parsePgNestedArray(arrayString, i + 1);\n result.push(value2);\n i = startFrom2;\n continue;\n }\n const [value, newStartFrom] = parsePgArrayValue(arrayString, i, false);\n result.push(value);\n i = newStartFrom;\n }\n return [result, i];\n}\nfunction parsePgArray(arrayString) {\n const [result] = parsePgNestedArray(arrayString, 1);\n return result;\n}\nfunction makePgArray(array) {\n return `{${array.map((item) => {\n if (Array.isArray(item)) {\n return makePgArray(item);\n }\n if (typeof item === \"string\") {\n return `\"${item.replace(/\\\\/g, \"\\\\\\\\\").replace(/\"/g, '\\\\\"')}\"`;\n }\n return `${item}`;\n }).join(\",\")}}`;\n}\nexport {\n makePgArray,\n parsePgArray,\n parsePgNestedArray\n};\n//# sourceMappingURL=array.js.map","const entityKind = Symbol.for(\"drizzle:entityKind\");\nconst hasOwnEntityKind = Symbol.for(\"drizzle:hasOwnEntityKind\");\nfunction is(value, type) {\n if (!value || typeof value !== \"object\") {\n return false;\n }\n if (value instanceof type) {\n return true;\n }\n if (!Object.prototype.hasOwnProperty.call(type, entityKind)) {\n throw new Error(\n `Class \"${type.name ?? \"<unknown>\"}\" doesn't look like a Drizzle entity. If this is incorrect and the class is provided by Drizzle, please report this as a bug.`\n );\n }\n let cls = Object.getPrototypeOf(value).constructor;\n if (cls) {\n while (cls) {\n if (entityKind in cls && cls[entityKind] === type[entityKind]) {\n return true;\n }\n cls = Object.getPrototypeOf(cls);\n }\n }\n return false;\n}\nexport {\n entityKind,\n hasOwnEntityKind,\n is\n};\n//# sourceMappingURL=entity.js.map","const TableName = Symbol.for(\"drizzle:Name\");\nexport {\n TableName\n};\n//# sourceMappingURL=table.utils.js.map","function iife(fn, ...args) {\n return fn(...args);\n}\nexport {\n iife\n};\n//# sourceMappingURL=tracing-utils.js.map","// package.json\nvar version = \"0.45.2\";\n\n// src/version.ts\nvar compatibilityVersion = 10;\nexport {\n compatibilityVersion,\n version as npmVersion\n};\n","const ViewBaseConfig = Symbol.for(\"drizzle:ViewBaseConfig\");\nexport {\n ViewBaseConfig\n};\n//# sourceMappingURL=view-common.js.map","import { readFileSync, existsSync, readdirSync } from 'fs';\nimport { join, resolve } from 'path';\nimport { homedir } from 'os';\nimport { eq } from 'drizzle-orm';\nimport { sqliteTable, text } from 'drizzle-orm/sqlite-core';\n\nexport interface KitchenPluginManifest {\n id: string;\n name: string;\n teamTypes: string[];\n tabs: {\n id: string;\n label: string;\n icon: string;\n bundle: string;\n }[];\n apiRoutes?: string;\n migrations?: string;\n}\n\ntype PluginConfigRow = {\n value: string | null;\n};\n\ntype PluginDb = {\n select(): {\n from(table: typeof configTable): {\n where(condition: unknown): {\n get(): PluginConfigRow | undefined;\n };\n };\n };\n insert(table: typeof configTable): {\n values(row: { key: string; value: string; updatedAt: string }): {\n onConflictDoUpdate(opts: {\n target: typeof configTable.key;\n set: { value: string; updatedAt: string };\n }): void;\n };\n };\n};\n\nexport interface KitchenPluginContext {\n db: PluginDb;\n teamDir: string;\n encrypt(data: unknown): string;\n decrypt(blob: string): unknown;\n registerCron(opts: { schedule: string; handler: string }): void;\n getConfig(key: string): string | null;\n setConfig(key: string, value: string): void;\n}\n\n// Plugin config table schema\nconst configTable = sqliteTable('config', {\n key: text('key').primaryKey(),\n value: text('value'),\n updatedAt: text('updated_at').default('CURRENT_TIMESTAMP'),\n});\n\n// Cache for discovered plugins\nlet cachedPlugins: Map<string, KitchenPluginManifest> | null = null;\n\n/**\n * The canonical location for Kitchen plugins installed via CLI.\n */\nexport function getPluginsDir(): string {\n return join(homedir(), '.openclaw', 'kitchen', 'plugins');\n}\n\n/**\n * Scan a node_modules directory for Kitchen plugin manifests.\n */\nfunction scanNodeModules(nodeModulesPath: string, plugins: Map<string, KitchenPluginManifest>): void {\n if (!existsSync(nodeModulesPath)) return;\n\n let entries: string[];\n try {\n entries = readdirSync(nodeModulesPath);\n } catch {\n return;\n }\n\n for (const entry of entries) {\n const entryPath = join(nodeModulesPath, entry);\n\n if (entry.startsWith('@')) {\n // Scoped package - check subdirectories\n try {\n const scopedEntries = readdirSync(entryPath);\n for (const scopedEntry of scopedEntries) {\n const packagePath = join(entryPath, scopedEntry);\n const manifest = loadPluginManifest(packagePath);\n if (manifest && !plugins.has(manifest.id)) {\n plugins.set(manifest.id, manifest);\n }\n }\n } catch {\n // Ignore errors reading scoped directories\n }\n } else {\n // Regular package\n const manifest = loadPluginManifest(entryPath);\n if (manifest && !plugins.has(manifest.id)) {\n plugins.set(manifest.id, manifest);\n }\n }\n }\n}\n\n/**\n * Discover all Kitchen plugins.\n *\n * Search order (first match wins per plugin id):\n * 1. ~/.openclaw/kitchen/plugins/node_modules/ (CLI-installed plugins)\n * 2. CWD/node_modules/ (dev / legacy fallback)\n */\nexport function discoverKitchenPlugins(): Map<string, KitchenPluginManifest> {\n if (cachedPlugins) return cachedPlugins;\n\n const plugins = new Map<string, KitchenPluginManifest>();\n\n // Primary: dedicated plugins directory\n const pluginsDir = getPluginsDir();\n scanNodeModules(join(pluginsDir, 'node_modules'), plugins);\n\n // Fallback: CWD node_modules (useful for dev mode)\n scanNodeModules(resolve('node_modules'), plugins);\n\n cachedPlugins = plugins;\n return plugins;\n}\n\n/**\n * Load plugin manifest from a package directory\n */\nfunction loadPluginManifest(packagePath: string): KitchenPluginManifest | null {\n try {\n const packageJsonPath = join(packagePath, 'package.json');\n if (!existsSync(packageJsonPath)) return null;\n\n const packageJson = JSON.parse(readFileSync(packageJsonPath, 'utf8'));\n const kitchenPlugin = packageJson.kitchenPlugin;\n\n if (!kitchenPlugin || typeof kitchenPlugin !== 'object') return null;\n\n // Validate required fields\n if (!kitchenPlugin.id || !kitchenPlugin.name || !Array.isArray(kitchenPlugin.teamTypes)) {\n console.warn(`Invalid Kitchen plugin manifest in ${packagePath}`);\n return null;\n }\n\n // Validate and resolve bundle paths\n const tabs = Array.isArray(kitchenPlugin.tabs) ? kitchenPlugin.tabs : [];\n for (const tab of tabs) {\n if (tab.bundle && !existsSync(join(packagePath, tab.bundle))) {\n console.warn(`Plugin ${kitchenPlugin.id}: bundle not found at ${tab.bundle}`);\n return null;\n }\n }\n\n return {\n id: String(kitchenPlugin.id),\n name: String(kitchenPlugin.name),\n teamTypes: kitchenPlugin.teamTypes as string[],\n tabs: tabs.map((tab: Record<string, unknown>) => ({\n id: String(tab.id || ''),\n label: String(tab.label || ''),\n icon: String(tab.icon || 'folder'),\n bundle: resolve(packagePath, String(tab.bundle || '')),\n })),\n apiRoutes: kitchenPlugin.apiRoutes ? resolve(packagePath, String(kitchenPlugin.apiRoutes)) : undefined,\n migrations: kitchenPlugin.migrations ? resolve(packagePath, String(kitchenPlugin.migrations)) : undefined,\n };\n } catch (error) {\n console.warn(`Failed to load plugin manifest from ${packagePath}:`, error);\n return null;\n }\n}\n\n/**\n * Create isolated SQLite database for a plugin\n */\nexport function createPluginDb(pluginId: string): PluginDb {\n const dbDir = resolve(homedir(), '.openclaw', 'kitchen', 'plugins', pluginId);\n const dbPath = join(dbDir, `${pluginId}.db`);\n\n // Ensure directory exists\n try {\n try {\n // eslint-disable-next-line @typescript-eslint/no-require-imports\n const fs = require('fs');\n fs.mkdirSync(dbDir, { recursive: true });\n } catch {\n // Directory might already exist\n }\n } catch {\n // Directory might already exist\n }\n\n // Lazy-load sqlite so plugin discovery routes do not require the native module.\n // eslint-disable-next-line @typescript-eslint/no-require-imports\n const Database = require('better-sqlite3');\n // eslint-disable-next-line @typescript-eslint/no-require-imports\n const { drizzle } = require('drizzle-orm/better-sqlite3');\n\n const sqlite = new Database(dbPath);\n const db = drizzle(sqlite, { schema: { config: configTable } });\n\n // Create config table if it doesn't exist\n sqlite.exec(`\n CREATE TABLE IF NOT EXISTS config (\n key TEXT PRIMARY KEY,\n value TEXT,\n updated_at TEXT DEFAULT CURRENT_TIMESTAMP\n )\n `);\n\n return db as unknown as PluginDb;\n}\n\n/**\n * Create plugin context for a given plugin\n */\nexport function createPluginContext(\n pluginId: string,\n teamDir: string,\n authToken: string\n): KitchenPluginContext {\n const db = createPluginDb(pluginId);\n\n // Simple AES-256-GCM encryption using auth token\n const encrypt = (data: unknown): string => {\n // eslint-disable-next-line @typescript-eslint/no-require-imports\n const crypto = require('crypto');\n const key = crypto.pbkdf2Sync(authToken, 'kitchen-plugin-salt', 100000, 32, 'sha256');\n const iv = crypto.randomBytes(16);\n const cipher = crypto.createCipher('aes-256-gcm', key);\n cipher.setAAD(iv);\n \n let encrypted = cipher.update(JSON.stringify(data), 'utf8', 'base64');\n encrypted += cipher.final('base64');\n const authTag = cipher.getAuthTag();\n \n return Buffer.concat([iv, authTag, Buffer.from(encrypted, 'base64')]).toString('base64');\n };\n\n const decrypt = (blob: string): unknown => {\n // eslint-disable-next-line @typescript-eslint/no-require-imports\n const crypto = require('crypto');\n const key = crypto.pbkdf2Sync(authToken, 'kitchen-plugin-salt', 100000, 32, 'sha256');\n const buffer = Buffer.from(blob, 'base64');\n \n const iv = buffer.subarray(0, 16);\n const authTag = buffer.subarray(16, 32);\n const encrypted = buffer.subarray(32).toString('base64');\n \n const decipher = crypto.createDecipher('aes-256-gcm', key);\n decipher.setAAD(iv);\n decipher.setAuthTag(authTag);\n \n let decrypted = decipher.update(encrypted, 'base64', 'utf8');\n decrypted += decipher.final('utf8');\n \n return JSON.parse(decrypted);\n };\n\n const registerCron = (opts: { schedule: string; handler: string }): void => {\n // Integration with OpenClaw cron system will be implemented in future versions\n console.log(`Plugin ${pluginId} registered cron:`, opts);\n };\n\n const getConfig = (key: string): string | null => {\n const result = db.select().from(configTable).where(eq(configTable.key, key)).get();\n return result?.value || null;\n };\n\n const setConfig = (key: string, value: string): void => {\n db.insert(configTable)\n .values({ key, value, updatedAt: new Date().toISOString() })\n .onConflictDoUpdate({ target: configTable.key, set: { value, updatedAt: new Date().toISOString() } });\n };\n\n return {\n db,\n teamDir,\n encrypt,\n decrypt,\n registerCron,\n getConfig,\n setConfig,\n };\n}\n\n/**\n * Filter plugins by team type\n */\nexport function getPluginsForTeamType(teamType: string): KitchenPluginManifest[] {\n const plugins = discoverKitchenPlugins();\n return Array.from(plugins.values()).filter(plugin =>\n plugin.teamTypes.includes(teamType)\n );\n}\n\n/**\n * Clear plugin cache (for testing)\n */\nexport function clearPluginCache(): void {\n cachedPlugins = null;\n}","import { entityKind } from \"./entity.js\";\nclass Column {\n constructor(table, config) {\n this.table = table;\n this.config = config;\n this.name = config.name;\n this.keyAsName = config.keyAsName;\n this.notNull = config.notNull;\n this.default = config.default;\n this.defaultFn = config.defaultFn;\n this.onUpdateFn = config.onUpdateFn;\n this.hasDefault = config.hasDefault;\n this.primary = config.primaryKey;\n this.isUnique = config.isUnique;\n this.uniqueName = config.uniqueName;\n this.uniqueType = config.uniqueType;\n this.dataType = config.dataType;\n this.columnType = config.columnType;\n this.generated = config.generated;\n this.generatedIdentity = config.generatedIdentity;\n }\n static [entityKind] = \"Column\";\n name;\n keyAsName;\n primary;\n notNull;\n default;\n defaultFn;\n onUpdateFn;\n hasDefault;\n isUnique;\n uniqueName;\n uniqueType;\n dataType;\n columnType;\n enumValues = void 0;\n generated = void 0;\n generatedIdentity = void 0;\n config;\n mapFromDriverValue(value) {\n return value;\n }\n mapToDriverValue(value) {\n return value;\n }\n // ** @internal */\n shouldDisableInsert() {\n return this.config.generated !== void 0 && this.config.generated.type !== \"byDefault\";\n }\n}\nexport {\n Column\n};\n//# sourceMappingURL=column.js.map","import { entityKind } from \"./entity.js\";\nclass Subquery {\n static [entityKind] = \"Subquery\";\n constructor(sql, fields, alias, isWith = false, usedTables = []) {\n this._ = {\n brand: \"Subquery\",\n sql,\n selectedFields: fields,\n alias,\n isWith,\n usedTables\n };\n }\n // getSQL(): SQL<unknown> {\n // \treturn new SQL([this]);\n // }\n}\nclass WithSubquery extends Subquery {\n static [entityKind] = \"WithSubquery\";\n}\nexport {\n Subquery,\n WithSubquery\n};\n//# sourceMappingURL=subquery.js.map","import { entityKind } from \"./entity.js\";\nclass ColumnBuilder {\n static [entityKind] = \"ColumnBuilder\";\n config;\n constructor(name, dataType, columnType) {\n this.config = {\n name,\n keyAsName: name === \"\",\n notNull: false,\n default: void 0,\n hasDefault: false,\n primaryKey: false,\n isUnique: false,\n uniqueName: void 0,\n uniqueType: void 0,\n dataType,\n columnType,\n generated: void 0\n };\n }\n /**\n * Changes the data type of the column. Commonly used with `json` columns. Also, useful for branded types.\n *\n * @example\n * ```ts\n * const users = pgTable('users', {\n * \tid: integer('id').$type<UserId>().primaryKey(),\n * \tdetails: json('details').$type<UserDetails>().notNull(),\n * });\n * ```\n */\n $type() {\n return this;\n }\n /**\n * Adds a `not null` clause to the column definition.\n *\n * Affects the `select` model of the table - columns *without* `not null` will be nullable on select.\n */\n notNull() {\n this.config.notNull = true;\n return this;\n }\n /**\n * Adds a `default <value>` clause to the column definition.\n *\n * Affects the `insert` model of the table - columns *with* `default` are optional on insert.\n *\n * If you need to set a dynamic default value, use {@link $defaultFn} instead.\n */\n default(value) {\n this.config.default = value;\n this.config.hasDefault = true;\n return this;\n }\n /**\n * Adds a dynamic default value to the column.\n * The function will be called when the row is inserted, and the returned value will be used as the column value.\n *\n * **Note:** This value does not affect the `drizzle-kit` behavior, it is only used at runtime in `drizzle-orm`.\n */\n $defaultFn(fn) {\n this.config.defaultFn = fn;\n this.config.hasDefault = true;\n return this;\n }\n /**\n * Alias for {@link $defaultFn}.\n */\n $default = this.$defaultFn;\n /**\n * Adds a dynamic update value to the column.\n * The function will be called when the row is updated, and the returned value will be used as the column value if none is provided.\n * If no `default` (or `$defaultFn`) value is provided, the function will be called when the row is inserted as well, and the returned value will be used as the column value.\n *\n * **Note:** This value does not affect the `drizzle-kit` behavior, it is only used at runtime in `drizzle-orm`.\n */\n $onUpdateFn(fn) {\n this.config.onUpdateFn = fn;\n this.config.hasDefault = true;\n return this;\n }\n /**\n * Alias for {@link $onUpdateFn}.\n */\n $onUpdate = this.$onUpdateFn;\n /**\n * Adds a `primary key` clause to the column definition. This implicitly makes the column `not null`.\n *\n * In SQLite, `integer primary key` implicitly makes the column auto-incrementing.\n */\n primaryKey() {\n this.config.primaryKey = true;\n this.config.notNull = true;\n return this;\n }\n /** @internal Sets the name of the column to the key within the table definition if a name was not given. */\n setName(name) {\n if (this.config.name !== \"\") return;\n this.config.name = name;\n }\n}\nexport {\n ColumnBuilder\n};\n//# sourceMappingURL=column-builder.js.map","import { entityKind } from \"./entity.js\";\nimport { TableName } from \"./table.utils.js\";\nconst Schema = Symbol.for(\"drizzle:Schema\");\nconst Columns = Symbol.for(\"drizzle:Columns\");\nconst ExtraConfigColumns = Symbol.for(\"drizzle:ExtraConfigColumns\");\nconst OriginalName = Symbol.for(\"drizzle:OriginalName\");\nconst BaseName = Symbol.for(\"drizzle:BaseName\");\nconst IsAlias = Symbol.for(\"drizzle:IsAlias\");\nconst ExtraConfigBuilder = Symbol.for(\"drizzle:ExtraConfigBuilder\");\nconst IsDrizzleTable = Symbol.for(\"drizzle:IsDrizzleTable\");\nclass Table {\n static [entityKind] = \"Table\";\n /** @internal */\n static Symbol = {\n Name: TableName,\n Schema,\n OriginalName,\n Columns,\n ExtraConfigColumns,\n BaseName,\n IsAlias,\n ExtraConfigBuilder\n };\n /**\n * @internal\n * Can be changed if the table is aliased.\n */\n [TableName];\n /**\n * @internal\n * Used to store the original name of the table, before any aliasing.\n */\n [OriginalName];\n /** @internal */\n [Schema];\n /** @internal */\n [Columns];\n /** @internal */\n [ExtraConfigColumns];\n /**\n * @internal\n * Used to store the table name before the transformation via the `tableCreator` functions.\n */\n [BaseName];\n /** @internal */\n [IsAlias] = false;\n /** @internal */\n [IsDrizzleTable] = true;\n /** @internal */\n [ExtraConfigBuilder] = void 0;\n constructor(name, schema, baseName) {\n this[TableName] = this[OriginalName] = name;\n this[Schema] = schema;\n this[BaseName] = baseName;\n }\n}\nfunction isTable(table) {\n return typeof table === \"object\" && table !== null && IsDrizzleTable in table;\n}\nfunction getTableName(table) {\n return table[TableName];\n}\nfunction getTableUniqueName(table) {\n return `${table[Schema] ?? \"public\"}.${table[TableName]}`;\n}\nexport {\n BaseName,\n Columns,\n ExtraConfigBuilder,\n ExtraConfigColumns,\n IsAlias,\n OriginalName,\n Schema,\n Table,\n getTableName,\n getTableUniqueName,\n isTable\n};\n//# sourceMappingURL=table.js.map","import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgEnumObjectColumnBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgEnumObjectColumnBuilder\";\n constructor(name, enumInstance) {\n super(name, \"string\", \"PgEnumObjectColumn\");\n this.config.enum = enumInstance;\n }\n /** @internal */\n build(table) {\n return new PgEnumObjectColumn(\n table,\n this.config\n );\n }\n}\nclass PgEnumObjectColumn extends PgColumn {\n static [entityKind] = \"PgEnumObjectColumn\";\n enum;\n enumValues = this.config.enum.enumValues;\n constructor(table, config) {\n super(table, config);\n this.enum = config.enum;\n }\n getSQLType() {\n return this.enum.enumName;\n }\n}\nconst isPgEnumSym = Symbol.for(\"drizzle:isPgEnum\");\nfunction isPgEnum(obj) {\n return !!obj && typeof obj === \"function\" && isPgEnumSym in obj && obj[isPgEnumSym] === true;\n}\nclass PgEnumColumnBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgEnumColumnBuilder\";\n constructor(name, enumInstance) {\n super(name, \"string\", \"PgEnumColumn\");\n this.config.enum = enumInstance;\n }\n /** @internal */\n build(table) {\n return new PgEnumColumn(\n table,\n this.config\n );\n }\n}\nclass PgEnumColumn extends PgColumn {\n static [entityKind] = \"PgEnumColumn\";\n enum = this.config.enum;\n enumValues = this.config.enum.enumValues;\n constructor(table, config) {\n super(table, config);\n this.enum = config.enum;\n }\n getSQLType() {\n return this.enum.enumName;\n }\n}\nfunction pgEnum(enumName, input) {\n return Array.isArray(input) ? pgEnumWithSchema(enumName, [...input], void 0) : pgEnumObjectWithSchema(enumName, input, void 0);\n}\nfunction pgEnumWithSchema(enumName, values, schema) {\n const enumInstance = Object.assign(\n (name) => new PgEnumColumnBuilder(name ?? \"\", enumInstance),\n {\n enumName,\n enumValues: values,\n schema,\n [isPgEnumSym]: true\n }\n );\n return enumInstance;\n}\nfunction pgEnumObjectWithSchema(enumName, values, schema) {\n const enumInstance = Object.assign(\n (name) => new PgEnumObjectColumnBuilder(name ?? \"\", enumInstance),\n {\n enumName,\n enumValues: Object.values(values),\n schema,\n [isPgEnumSym]: true\n }\n );\n return enumInstance;\n}\nexport {\n PgEnumColumn,\n PgEnumColumnBuilder,\n PgEnumObjectColumn,\n PgEnumObjectColumnBuilder,\n isPgEnum,\n pgEnum,\n pgEnumObjectWithSchema,\n pgEnumWithSchema\n};\n//# sourceMappingURL=enum.js.map","import { entityKind } from \"../entity.js\";\nimport { TableName } from \"../table.utils.js\";\nclass ForeignKeyBuilder {\n static [entityKind] = \"PgForeignKeyBuilder\";\n /** @internal */\n reference;\n /** @internal */\n _onUpdate = \"no action\";\n /** @internal */\n _onDelete = \"no action\";\n constructor(config, actions) {\n this.reference = () => {\n const { name, columns, foreignColumns } = config();\n return { name, columns, foreignTable: foreignColumns[0].table, foreignColumns };\n };\n if (actions) {\n this._onUpdate = actions.onUpdate;\n this._onDelete = actions.onDelete;\n }\n }\n onUpdate(action) {\n this._onUpdate = action === void 0 ? \"no action\" : action;\n return this;\n }\n onDelete(action) {\n this._onDelete = action === void 0 ? \"no action\" : action;\n return this;\n }\n /** @internal */\n build(table) {\n return new ForeignKey(table, this);\n }\n}\nclass ForeignKey {\n constructor(table, builder) {\n this.table = table;\n this.reference = builder.reference;\n this.onUpdate = builder._onUpdate;\n this.onDelete = builder._onDelete;\n }\n static [entityKind] = \"PgForeignKey\";\n reference;\n onUpdate;\n onDelete;\n getName() {\n const { name, columns, foreignColumns } = this.reference();\n const columnNames = columns.map((column) => column.name);\n const foreignColumnNames = foreignColumns.map((column) => column.name);\n const chunks = [\n this.table[TableName],\n ...columnNames,\n foreignColumns[0].table[TableName],\n ...foreignColumnNames\n ];\n return name ?? `${chunks.join(\"_\")}_fk`;\n }\n}\nfunction foreignKey(config) {\n function mappedConfig() {\n const { name, columns, foreignColumns } = config;\n return {\n name,\n columns,\n foreignColumns\n };\n }\n return new ForeignKeyBuilder(mappedConfig);\n}\nexport {\n ForeignKey,\n ForeignKeyBuilder,\n foreignKey\n};\n//# sourceMappingURL=foreign-keys.js.map","import { entityKind } from \"../entity.js\";\nimport { TableName } from \"../table.utils.js\";\nfunction unique(name) {\n return new UniqueOnConstraintBuilder(name);\n}\nfunction uniqueKeyName(table, columns) {\n return `${table[TableName]}_${columns.join(\"_\")}_unique`;\n}\nclass UniqueConstraintBuilder {\n constructor(columns, name) {\n this.name = name;\n this.columns = columns;\n }\n static [entityKind] = \"PgUniqueConstraintBuilder\";\n /** @internal */\n columns;\n /** @internal */\n nullsNotDistinctConfig = false;\n nullsNotDistinct() {\n this.nullsNotDistinctConfig = true;\n return this;\n }\n /** @internal */\n build(table) {\n return new UniqueConstraint(table, this.columns, this.nullsNotDistinctConfig, this.name);\n }\n}\nclass UniqueOnConstraintBuilder {\n static [entityKind] = \"PgUniqueOnConstraintBuilder\";\n /** @internal */\n name;\n constructor(name) {\n this.name = name;\n }\n on(...columns) {\n return new UniqueConstraintBuilder(columns, this.name);\n }\n}\nclass UniqueConstraint {\n constructor(table, columns, nullsNotDistinct, name) {\n this.table = table;\n this.columns = columns;\n this.name = name ?? uniqueKeyName(this.table, this.columns.map((column) => column.name));\n this.nullsNotDistinct = nullsNotDistinct;\n }\n static [entityKind] = \"PgUniqueConstraint\";\n columns;\n name;\n nullsNotDistinct = false;\n getName() {\n return this.name;\n }\n}\nexport {\n UniqueConstraint,\n UniqueConstraintBuilder,\n UniqueOnConstraintBuilder,\n unique,\n uniqueKeyName\n};\n//# sourceMappingURL=unique-constraint.js.map","import { iife } from \"./tracing-utils.js\";\nimport { npmVersion } from \"./version.js\";\nlet otel;\nlet rawTracer;\nconst tracer = {\n startActiveSpan(name, fn) {\n if (!otel) {\n return fn();\n }\n if (!rawTracer) {\n rawTracer = otel.trace.getTracer(\"drizzle-orm\", npmVersion);\n }\n return iife(\n (otel2, rawTracer2) => rawTracer2.startActiveSpan(\n name,\n (span) => {\n try {\n return fn(span);\n } catch (e) {\n span.setStatus({\n code: otel2.SpanStatusCode.ERROR,\n message: e instanceof Error ? e.message : \"Unknown error\"\n // eslint-disable-line no-instanceof/no-instanceof\n });\n throw e;\n } finally {\n span.end();\n }\n }\n ),\n otel,\n rawTracer\n );\n }\n};\nexport {\n tracer\n};\n//# sourceMappingURL=tracing.js.map","import { entityKind } from \"../entity.js\";\nimport { TableName } from \"../table.utils.js\";\nclass ForeignKeyBuilder {\n static [entityKind] = \"SQLiteForeignKeyBuilder\";\n /** @internal */\n reference;\n /** @internal */\n _onUpdate;\n /** @internal */\n _onDelete;\n constructor(config, actions) {\n this.reference = () => {\n const { name, columns, foreignColumns } = config();\n return { name, columns, foreignTable: foreignColumns[0].table, foreignColumns };\n };\n if (actions) {\n this._onUpdate = actions.onUpdate;\n this._onDelete = actions.onDelete;\n }\n }\n onUpdate(action) {\n this._onUpdate = action;\n return this;\n }\n onDelete(action) {\n this._onDelete = action;\n return this;\n }\n /** @internal */\n build(table) {\n return new ForeignKey(table, this);\n }\n}\nclass ForeignKey {\n constructor(table, builder) {\n this.table = table;\n this.reference = builder.reference;\n this.onUpdate = builder._onUpdate;\n this.onDelete = builder._onDelete;\n }\n static [entityKind] = \"SQLiteForeignKey\";\n reference;\n onUpdate;\n onDelete;\n getName() {\n const { name, columns, foreignColumns } = this.reference();\n const columnNames = columns.map((column) => column.name);\n const foreignColumnNames = foreignColumns.map((column) => column.name);\n const chunks = [\n this.table[TableName],\n ...columnNames,\n foreignColumns[0].table[TableName],\n ...foreignColumnNames\n ];\n return name ?? `${chunks.join(\"_\")}_fk`;\n }\n}\nfunction foreignKey(config) {\n function mappedConfig() {\n if (typeof config === \"function\") {\n const { name, columns, foreignColumns } = config();\n return {\n name,\n columns,\n foreignColumns\n };\n }\n return config;\n }\n return new ForeignKeyBuilder(mappedConfig);\n}\nexport {\n ForeignKey,\n ForeignKeyBuilder,\n foreignKey\n};\n//# sourceMappingURL=foreign-keys.js.map","import { entityKind } from \"../entity.js\";\nimport { TableName } from \"../table.utils.js\";\nfunction uniqueKeyName(table, columns) {\n return `${table[TableName]}_${columns.join(\"_\")}_unique`;\n}\nfunction unique(name) {\n return new UniqueOnConstraintBuilder(name);\n}\nclass UniqueConstraintBuilder {\n constructor(columns, name) {\n this.name = name;\n this.columns = columns;\n }\n static [entityKind] = \"SQLiteUniqueConstraintBuilder\";\n /** @internal */\n columns;\n /** @internal */\n build(table) {\n return new UniqueConstraint(table, this.columns, this.name);\n }\n}\nclass UniqueOnConstraintBuilder {\n static [entityKind] = \"SQLiteUniqueOnConstraintBuilder\";\n /** @internal */\n name;\n constructor(name) {\n this.name = name;\n }\n on(...columns) {\n return new UniqueConstraintBuilder(columns, this.name);\n }\n}\nclass UniqueConstraint {\n constructor(table, columns, name) {\n this.table = table;\n this.columns = columns;\n this.name = name ?? uniqueKeyName(this.table, this.columns.map((column) => column.name));\n }\n static [entityKind] = \"SQLiteUniqueConstraint\";\n columns;\n name;\n getName() {\n return this.name;\n }\n}\nexport {\n UniqueConstraint,\n UniqueConstraintBuilder,\n UniqueOnConstraintBuilder,\n unique,\n uniqueKeyName\n};\n//# sourceMappingURL=unique-constraint.js.map","import { entityKind } from \"../../entity.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteRealBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteRealBuilder\";\n constructor(name) {\n super(name, \"number\", \"SQLiteReal\");\n }\n /** @internal */\n build(table) {\n return new SQLiteReal(table, this.config);\n }\n}\nclass SQLiteReal extends SQLiteColumn {\n static [entityKind] = \"SQLiteReal\";\n getSQLType() {\n return \"real\";\n }\n}\nfunction real(name) {\n return new SQLiteRealBuilder(name ?? \"\");\n}\nexport {\n SQLiteReal,\n SQLiteRealBuilder,\n real\n};\n//# sourceMappingURL=real.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig, textDecoder } from \"../../utils.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteBigIntBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteBigIntBuilder\";\n constructor(name) {\n super(name, \"bigint\", \"SQLiteBigInt\");\n }\n /** @internal */\n build(table) {\n return new SQLiteBigInt(table, this.config);\n }\n}\nclass SQLiteBigInt extends SQLiteColumn {\n static [entityKind] = \"SQLiteBigInt\";\n getSQLType() {\n return \"blob\";\n }\n mapFromDriverValue(value) {\n if (typeof Buffer !== \"undefined\" && Buffer.from) {\n const buf = Buffer.isBuffer(value) ? value : value instanceof ArrayBuffer ? Buffer.from(value) : value.buffer ? Buffer.from(value.buffer, value.byteOffset, value.byteLength) : Buffer.from(value);\n return BigInt(buf.toString(\"utf8\"));\n }\n return BigInt(textDecoder.decode(value));\n }\n mapToDriverValue(value) {\n return Buffer.from(value.toString());\n }\n}\nclass SQLiteBlobJsonBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteBlobJsonBuilder\";\n constructor(name) {\n super(name, \"json\", \"SQLiteBlobJson\");\n }\n /** @internal */\n build(table) {\n return new SQLiteBlobJson(\n table,\n this.config\n );\n }\n}\nclass SQLiteBlobJson extends SQLiteColumn {\n static [entityKind] = \"SQLiteBlobJson\";\n getSQLType() {\n return \"blob\";\n }\n mapFromDriverValue(value) {\n if (typeof Buffer !== \"undefined\" && Buffer.from) {\n const buf = Buffer.isBuffer(value) ? value : value instanceof ArrayBuffer ? Buffer.from(value) : value.buffer ? Buffer.from(value.buffer, value.byteOffset, value.byteLength) : Buffer.from(value);\n return JSON.parse(buf.toString(\"utf8\"));\n }\n return JSON.parse(textDecoder.decode(value));\n }\n mapToDriverValue(value) {\n return Buffer.from(JSON.stringify(value));\n }\n}\nclass SQLiteBlobBufferBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteBlobBufferBuilder\";\n constructor(name) {\n super(name, \"buffer\", \"SQLiteBlobBuffer\");\n }\n /** @internal */\n build(table) {\n return new SQLiteBlobBuffer(table, this.config);\n }\n}\nclass SQLiteBlobBuffer extends SQLiteColumn {\n static [entityKind] = \"SQLiteBlobBuffer\";\n mapFromDriverValue(value) {\n if (Buffer.isBuffer(value)) {\n return value;\n }\n return Buffer.from(value);\n }\n getSQLType() {\n return \"blob\";\n }\n}\nfunction blob(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (config?.mode === \"json\") {\n return new SQLiteBlobJsonBuilder(name);\n }\n if (config?.mode === \"bigint\") {\n return new SQLiteBigIntBuilder(name);\n }\n return new SQLiteBlobBufferBuilder(name);\n}\nexport {\n SQLiteBigInt,\n SQLiteBigIntBuilder,\n SQLiteBlobBuffer,\n SQLiteBlobBufferBuilder,\n SQLiteBlobJson,\n SQLiteBlobJsonBuilder,\n blob\n};\n//# sourceMappingURL=blob.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteCustomColumnBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteCustomColumnBuilder\";\n constructor(name, fieldConfig, customTypeParams) {\n super(name, \"custom\", \"SQLiteCustomColumn\");\n this.config.fieldConfig = fieldConfig;\n this.config.customTypeParams = customTypeParams;\n }\n /** @internal */\n build(table) {\n return new SQLiteCustomColumn(\n table,\n this.config\n );\n }\n}\nclass SQLiteCustomColumn extends SQLiteColumn {\n static [entityKind] = \"SQLiteCustomColumn\";\n sqlName;\n mapTo;\n mapFrom;\n constructor(table, config) {\n super(table, config);\n this.sqlName = config.customTypeParams.dataType(config.fieldConfig);\n this.mapTo = config.customTypeParams.toDriver;\n this.mapFrom = config.customTypeParams.fromDriver;\n }\n getSQLType() {\n return this.sqlName;\n }\n mapFromDriverValue(value) {\n return typeof this.mapFrom === \"function\" ? this.mapFrom(value) : value;\n }\n mapToDriverValue(value) {\n return typeof this.mapTo === \"function\" ? this.mapTo(value) : value;\n }\n}\nfunction customType(customTypeParams) {\n return (a, b) => {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new SQLiteCustomColumnBuilder(\n name,\n config,\n customTypeParams\n );\n };\n}\nexport {\n SQLiteCustomColumn,\n SQLiteCustomColumnBuilder,\n customType\n};\n//# sourceMappingURL=custom.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteNumericBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteNumericBuilder\";\n constructor(name) {\n super(name, \"string\", \"SQLiteNumeric\");\n }\n /** @internal */\n build(table) {\n return new SQLiteNumeric(\n table,\n this.config\n );\n }\n}\nclass SQLiteNumeric extends SQLiteColumn {\n static [entityKind] = \"SQLiteNumeric\";\n mapFromDriverValue(value) {\n if (typeof value === \"string\") return value;\n return String(value);\n }\n getSQLType() {\n return \"numeric\";\n }\n}\nclass SQLiteNumericNumberBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteNumericNumberBuilder\";\n constructor(name) {\n super(name, \"number\", \"SQLiteNumericNumber\");\n }\n /** @internal */\n build(table) {\n return new SQLiteNumericNumber(\n table,\n this.config\n );\n }\n}\nclass SQLiteNumericNumber extends SQLiteColumn {\n static [entityKind] = \"SQLiteNumericNumber\";\n mapFromDriverValue(value) {\n if (typeof value === \"number\") return value;\n return Number(value);\n }\n mapToDriverValue = String;\n getSQLType() {\n return \"numeric\";\n }\n}\nclass SQLiteNumericBigIntBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteNumericBigIntBuilder\";\n constructor(name) {\n super(name, \"bigint\", \"SQLiteNumericBigInt\");\n }\n /** @internal */\n build(table) {\n return new SQLiteNumericBigInt(\n table,\n this.config\n );\n }\n}\nclass SQLiteNumericBigInt extends SQLiteColumn {\n static [entityKind] = \"SQLiteNumericBigInt\";\n mapFromDriverValue = BigInt;\n mapToDriverValue = String;\n getSQLType() {\n return \"numeric\";\n }\n}\nfunction numeric(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n const mode = config?.mode;\n return mode === \"number\" ? new SQLiteNumericNumberBuilder(name) : mode === \"bigint\" ? new SQLiteNumericBigIntBuilder(name) : new SQLiteNumericBuilder(name);\n}\nexport {\n SQLiteNumeric,\n SQLiteNumericBigInt,\n SQLiteNumericBigIntBuilder,\n SQLiteNumericBuilder,\n SQLiteNumericNumber,\n SQLiteNumericNumberBuilder,\n numeric\n};\n//# sourceMappingURL=numeric.js.map","import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteTextBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteTextBuilder\";\n constructor(name, config) {\n super(name, \"string\", \"SQLiteText\");\n this.config.enumValues = config.enum;\n this.config.length = config.length;\n }\n /** @internal */\n build(table) {\n return new SQLiteText(\n table,\n this.config\n );\n }\n}\nclass SQLiteText extends SQLiteColumn {\n static [entityKind] = \"SQLiteText\";\n enumValues = this.config.enumValues;\n length = this.config.length;\n constructor(table, config) {\n super(table, config);\n }\n getSQLType() {\n return `text${this.config.length ? `(${this.config.length})` : \"\"}`;\n }\n}\nclass SQLiteTextJsonBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteTextJsonBuilder\";\n constructor(name) {\n super(name, \"json\", \"SQLiteTextJson\");\n }\n /** @internal */\n build(table) {\n return new SQLiteTextJson(\n table,\n this.config\n );\n }\n}\nclass SQLiteTextJson extends SQLiteColumn {\n static [entityKind] = \"SQLiteTextJson\";\n getSQLType() {\n return \"text\";\n }\n mapFromDriverValue(value) {\n return JSON.parse(value);\n }\n mapToDriverValue(value) {\n return JSON.stringify(value);\n }\n}\nfunction text(a, b = {}) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (config.mode === \"json\") {\n return new SQLiteTextJsonBuilder(name);\n }\n return new SQLiteTextBuilder(name, config);\n}\nexport {\n SQLiteText,\n SQLiteTextBuilder,\n SQLiteTextJson,\n SQLiteTextJsonBuilder,\n text\n};\n//# sourceMappingURL=text.js.map","import { entityKind } from \"../entity.js\";\nimport { Table } from \"../table.js\";\nimport { getSQLiteColumnBuilders } from \"./columns/all.js\";\nconst InlineForeignKeys = Symbol.for(\"drizzle:SQLiteInlineForeignKeys\");\nclass SQLiteTable extends Table {\n static [entityKind] = \"SQLiteTable\";\n /** @internal */\n static Symbol = Object.assign({}, Table.Symbol, {\n InlineForeignKeys\n });\n /** @internal */\n [Table.Symbol.Columns];\n /** @internal */\n [InlineForeignKeys] = [];\n /** @internal */\n [Table.Symbol.ExtraConfigBuilder] = void 0;\n}\nfunction sqliteTableBase(name, columns, extraConfig, schema, baseName = name) {\n const rawTable = new SQLiteTable(name, schema, baseName);\n const parsedColumns = typeof columns === \"function\" ? columns(getSQLiteColumnBuilders()) : columns;\n const builtColumns = Object.fromEntries(\n Object.entries(parsedColumns).map(([name2, colBuilderBase]) => {\n const colBuilder = colBuilderBase;\n colBuilder.setName(name2);\n const column = colBuilder.build(rawTable);\n rawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n return [name2, column];\n })\n );\n const table = Object.assign(rawTable, builtColumns);\n table[Table.Symbol.Columns] = builtColumns;\n table[Table.Symbol.ExtraConfigColumns] = builtColumns;\n if (extraConfig) {\n table[SQLiteTable.Symbol.ExtraConfigBuilder] = extraConfig;\n }\n return table;\n}\nconst sqliteTable = (name, columns, extraConfig) => {\n return sqliteTableBase(name, columns, extraConfig);\n};\nfunction sqliteTableCreator(customizeTableName) {\n return (name, columns, extraConfig) => {\n return sqliteTableBase(customizeTableName(name), columns, extraConfig, void 0, name);\n };\n}\nexport {\n InlineForeignKeys,\n SQLiteTable,\n sqliteTable,\n sqliteTableCreator\n};\n//# sourceMappingURL=table.js.map","import { entityKind } from \"../../entity.js\";\nimport { sql } from \"../../sql/sql.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteBaseIntegerBuilder extends SQLiteColumnBuilder {\n static [entityKind] = \"SQLiteBaseIntegerBuilder\";\n constructor(name, dataType, columnType) {\n super(name, dataType, columnType);\n this.config.autoIncrement = false;\n }\n primaryKey(config) {\n if (config?.autoIncrement) {\n this.config.autoIncrement = true;\n }\n this.config.hasDefault = true;\n return super.primaryKey();\n }\n}\nclass SQLiteBaseInteger extends SQLiteColumn {\n static [entityKind] = \"SQLiteBaseInteger\";\n autoIncrement = this.config.autoIncrement;\n getSQLType() {\n return \"integer\";\n }\n}\nclass SQLiteIntegerBuilder extends SQLiteBaseIntegerBuilder {\n static [entityKind] = \"SQLiteIntegerBuilder\";\n constructor(name) {\n super(name, \"number\", \"SQLiteInteger\");\n }\n build(table) {\n return new SQLiteInteger(\n table,\n this.config\n );\n }\n}\nclass SQLiteInteger extends SQLiteBaseInteger {\n static [entityKind] = \"SQLiteInteger\";\n}\nclass SQLiteTimestampBuilder extends SQLiteBaseIntegerBuilder {\n static [entityKind] = \"SQLiteTimestampBuilder\";\n constructor(name, mode) {\n super(name, \"date\", \"SQLiteTimestamp\");\n this.config.mode = mode;\n }\n /**\n * @deprecated Use `default()` with your own expression instead.\n *\n * Adds `DEFAULT (cast((julianday('now') - 2440587.5)*86400000 as integer))` to the column, which is the current epoch timestamp in milliseconds.\n */\n defaultNow() {\n return this.default(sql`(cast((julianday('now') - 2440587.5)*86400000 as integer))`);\n }\n build(table) {\n return new SQLiteTimestamp(\n table,\n this.config\n );\n }\n}\nclass SQLiteTimestamp extends SQLiteBaseInteger {\n static [entityKind] = \"SQLiteTimestamp\";\n mode = this.config.mode;\n mapFromDriverValue(value) {\n if (this.config.mode === \"timestamp\") {\n return new Date(value * 1e3);\n }\n return new Date(value);\n }\n mapToDriverValue(value) {\n const unix = value.getTime();\n if (this.config.mode === \"timestamp\") {\n return Math.floor(unix / 1e3);\n }\n return unix;\n }\n}\nclass SQLiteBooleanBuilder extends SQLiteBaseIntegerBuilder {\n static [entityKind] = \"SQLiteBooleanBuilder\";\n constructor(name, mode) {\n super(name, \"boolean\", \"SQLiteBoolean\");\n this.config.mode = mode;\n }\n build(table) {\n return new SQLiteBoolean(\n table,\n this.config\n );\n }\n}\nclass SQLiteBoolean extends SQLiteBaseInteger {\n static [entityKind] = \"SQLiteBoolean\";\n mode = this.config.mode;\n mapFromDriverValue(value) {\n return Number(value) === 1;\n }\n mapToDriverValue(value) {\n return value ? 1 : 0;\n }\n}\nfunction integer(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (config?.mode === \"timestamp\" || config?.mode === \"timestamp_ms\") {\n return new SQLiteTimestampBuilder(name, config.mode);\n }\n if (config?.mode === \"boolean\") {\n return new SQLiteBooleanBuilder(name, config.mode);\n }\n return new SQLiteIntegerBuilder(name);\n}\nconst int = integer;\nexport {\n SQLiteBaseInteger,\n SQLiteBaseIntegerBuilder,\n SQLiteBoolean,\n SQLiteBooleanBuilder,\n SQLiteInteger,\n SQLiteIntegerBuilder,\n SQLiteTimestamp,\n SQLiteTimestampBuilder,\n int,\n integer\n};\n//# sourceMappingURL=integer.js.map","import { ColumnBuilder } from \"../../column-builder.js\";\nimport { Column } from \"../../column.js\";\nimport { entityKind } from \"../../entity.js\";\nimport { ForeignKeyBuilder } from \"../foreign-keys.js\";\nimport { uniqueKeyName } from \"../unique-constraint.js\";\nclass SQLiteColumnBuilder extends ColumnBuilder {\n static [entityKind] = \"SQLiteColumnBuilder\";\n foreignKeyConfigs = [];\n references(ref, actions = {}) {\n this.foreignKeyConfigs.push({ ref, actions });\n return this;\n }\n unique(name) {\n this.config.isUnique = true;\n this.config.uniqueName = name;\n return this;\n }\n generatedAlwaysAs(as, config) {\n this.config.generated = {\n as,\n type: \"always\",\n mode: config?.mode ?? \"virtual\"\n };\n return this;\n }\n /** @internal */\n buildForeignKeys(column, table) {\n return this.foreignKeyConfigs.map(({ ref, actions }) => {\n return ((ref2, actions2) => {\n const builder = new ForeignKeyBuilder(() => {\n const foreignColumn = ref2();\n return { columns: [column], foreignColumns: [foreignColumn] };\n });\n if (actions2.onUpdate) {\n builder.onUpdate(actions2.onUpdate);\n }\n if (actions2.onDelete) {\n builder.onDelete(actions2.onDelete);\n }\n return builder.build(table);\n })(ref, actions);\n });\n }\n}\nclass SQLiteColumn extends Column {\n constructor(table, config) {\n if (!config.uniqueName) {\n config.uniqueName = uniqueKeyName(table, [config.name]);\n }\n super(table, config);\n this.table = table;\n }\n static [entityKind] = \"SQLiteColumn\";\n}\nexport {\n SQLiteColumn,\n SQLiteColumnBuilder\n};\n//# sourceMappingURL=common.js.map","import { Column } from \"./column.js\";\nimport { is } from \"./entity.js\";\nimport { Param, SQL, View } from \"./sql/sql.js\";\nimport { Subquery } from \"./subquery.js\";\nimport { getTableName, Table } from \"./table.js\";\nimport { ViewBaseConfig } from \"./view-common.js\";\nfunction mapResultRow(columns, row, joinsNotNullableMap) {\n const nullifyMap = {};\n const result = columns.reduce(\n (result2, { path, field }, columnIndex) => {\n let decoder;\n if (is(field, Column)) {\n decoder = field;\n } else if (is(field, SQL)) {\n decoder = field.decoder;\n } else if (is(field, Subquery)) {\n decoder = field._.sql.decoder;\n } else {\n decoder = field.sql.decoder;\n }\n let node = result2;\n for (const [pathChunkIndex, pathChunk] of path.entries()) {\n if (pathChunkIndex < path.length - 1) {\n if (!(pathChunk in node)) {\n node[pathChunk] = {};\n }\n node = node[pathChunk];\n } else {\n const rawValue = row[columnIndex];\n const value = node[pathChunk] = rawValue === null ? null : decoder.mapFromDriverValue(rawValue);\n if (joinsNotNullableMap && is(field, Column) && path.length === 2) {\n const objectName = path[0];\n if (!(objectName in nullifyMap)) {\n nullifyMap[objectName] = value === null ? getTableName(field.table) : false;\n } else if (typeof nullifyMap[objectName] === \"string\" && nullifyMap[objectName] !== getTableName(field.table)) {\n nullifyMap[objectName] = false;\n }\n }\n }\n }\n return result2;\n },\n {}\n );\n if (joinsNotNullableMap && Object.keys(nullifyMap).length > 0) {\n for (const [objectName, tableName] of Object.entries(nullifyMap)) {\n if (typeof tableName === \"string\" && !joinsNotNullableMap[tableName]) {\n result[objectName] = null;\n }\n }\n }\n return result;\n}\nfunction orderSelectedFields(fields, pathPrefix) {\n return Object.entries(fields).reduce((result, [name, field]) => {\n if (typeof name !== \"string\") {\n return result;\n }\n const newPath = pathPrefix ? [...pathPrefix, name] : [name];\n if (is(field, Column) || is(field, SQL) || is(field, SQL.Aliased) || is(field, Subquery)) {\n result.push({ path: newPath, field });\n } else if (is(field, Table)) {\n result.push(...orderSelectedFields(field[Table.Symbol.Columns], newPath));\n } else {\n result.push(...orderSelectedFields(field, newPath));\n }\n return result;\n }, []);\n}\nfunction haveSameKeys(left, right) {\n const leftKeys = Object.keys(left);\n const rightKeys = Object.keys(right);\n if (leftKeys.length !== rightKeys.length) {\n return false;\n }\n for (const [index, key] of leftKeys.entries()) {\n if (key !== rightKeys[index]) {\n return false;\n }\n }\n return true;\n}\nfunction mapUpdateSet(table, values) {\n const entries = Object.entries(values).filter(([, value]) => value !== void 0).map(([key, value]) => {\n if (is(value, SQL) || is(value, Column)) {\n return [key, value];\n } else {\n return [key, new Param(value, table[Table.Symbol.Columns][key])];\n }\n });\n if (entries.length === 0) {\n throw new Error(\"No values to set\");\n }\n return Object.fromEntries(entries);\n}\nfunction applyMixins(baseClass, extendedClasses) {\n for (const extendedClass of extendedClasses) {\n for (const name of Object.getOwnPropertyNames(extendedClass.prototype)) {\n if (name === \"constructor\") continue;\n Object.defineProperty(\n baseClass.prototype,\n name,\n Object.getOwnPropertyDescriptor(extendedClass.prototype, name) || /* @__PURE__ */ Object.create(null)\n );\n }\n }\n}\nfunction getTableColumns(table) {\n return table[Table.Symbol.Columns];\n}\nfunction getViewSelectedFields(view) {\n return view[ViewBaseConfig].selectedFields;\n}\nfunction getTableLikeName(table) {\n return is(table, Subquery) ? table._.alias : is(table, View) ? table[ViewBaseConfig].name : is(table, SQL) ? void 0 : table[Table.Symbol.IsAlias] ? table[Table.Symbol.Name] : table[Table.Symbol.BaseName];\n}\nfunction getColumnNameAndConfig(a, b) {\n return {\n name: typeof a === \"string\" && a.length > 0 ? a : \"\",\n config: typeof a === \"object\" ? a : b\n };\n}\nconst _ = {};\nconst __ = {};\nfunction isConfig(data) {\n if (typeof data !== \"object\" || data === null) return false;\n if (data.constructor.name !== \"Object\") return false;\n if (\"logger\" in data) {\n const type = typeof data[\"logger\"];\n if (type !== \"boolean\" && (type !== \"object\" || typeof data[\"logger\"][\"logQuery\"] !== \"function\") && type !== \"undefined\") return false;\n return true;\n }\n if (\"schema\" in data) {\n const type = typeof data[\"schema\"];\n if (type !== \"object\" && type !== \"undefined\") return false;\n return true;\n }\n if (\"casing\" in data) {\n const type = typeof data[\"casing\"];\n if (type !== \"string\" && type !== \"undefined\") return false;\n return true;\n }\n if (\"mode\" in data) {\n if (data[\"mode\"] !== \"default\" || data[\"mode\"] !== \"planetscale\" || data[\"mode\"] !== void 0) return false;\n return true;\n }\n if (\"connection\" in data) {\n const type = typeof data[\"connection\"];\n if (type !== \"string\" && type !== \"object\" && type !== \"undefined\") return false;\n return true;\n }\n if (\"client\" in data) {\n const type = typeof data[\"client\"];\n if (type !== \"object\" && type !== \"function\" && type !== \"undefined\") return false;\n return true;\n }\n if (Object.keys(data).length === 0) return true;\n return false;\n}\nconst textDecoder = typeof TextDecoder === \"undefined\" ? null : new TextDecoder();\nexport {\n applyMixins,\n getColumnNameAndConfig,\n getTableColumns,\n getTableLikeName,\n getViewSelectedFields,\n haveSameKeys,\n isConfig,\n mapResultRow,\n mapUpdateSet,\n orderSelectedFields,\n textDecoder\n};\n//# sourceMappingURL=utils.js.map","import { blob } from \"./blob.js\";\nimport { customType } from \"./custom.js\";\nimport { integer } from \"./integer.js\";\nimport { numeric } from \"./numeric.js\";\nimport { real } from \"./real.js\";\nimport { text } from \"./text.js\";\nfunction getSQLiteColumnBuilders() {\n return {\n blob,\n customType,\n integer,\n numeric,\n real,\n text\n };\n}\nexport {\n getSQLiteColumnBuilders\n};\n//# sourceMappingURL=all.js.map","import { ColumnBuilder } from \"../../column-builder.js\";\nimport { Column } from \"../../column.js\";\nimport { entityKind, is } from \"../../entity.js\";\nimport { ForeignKeyBuilder } from \"../foreign-keys.js\";\nimport { iife } from \"../../tracing-utils.js\";\nimport { uniqueKeyName } from \"../unique-constraint.js\";\nimport { makePgArray, parsePgArray } from \"../utils/array.js\";\nclass PgColumnBuilder extends ColumnBuilder {\n foreignKeyConfigs = [];\n static [entityKind] = \"PgColumnBuilder\";\n array(size) {\n return new PgArrayBuilder(this.config.name, this, size);\n }\n references(ref, actions = {}) {\n this.foreignKeyConfigs.push({ ref, actions });\n return this;\n }\n unique(name, config) {\n this.config.isUnique = true;\n this.config.uniqueName = name;\n this.config.uniqueType = config?.nulls;\n return this;\n }\n generatedAlwaysAs(as) {\n this.config.generated = {\n as,\n type: \"always\",\n mode: \"stored\"\n };\n return this;\n }\n /** @internal */\n buildForeignKeys(column, table) {\n return this.foreignKeyConfigs.map(({ ref, actions }) => {\n return iife(\n (ref2, actions2) => {\n const builder = new ForeignKeyBuilder(() => {\n const foreignColumn = ref2();\n return { columns: [column], foreignColumns: [foreignColumn] };\n });\n if (actions2.onUpdate) {\n builder.onUpdate(actions2.onUpdate);\n }\n if (actions2.onDelete) {\n builder.onDelete(actions2.onDelete);\n }\n return builder.build(table);\n },\n ref,\n actions\n );\n });\n }\n /** @internal */\n buildExtraConfigColumn(table) {\n return new ExtraConfigColumn(table, this.config);\n }\n}\nclass PgColumn extends Column {\n constructor(table, config) {\n if (!config.uniqueName) {\n config.uniqueName = uniqueKeyName(table, [config.name]);\n }\n super(table, config);\n this.table = table;\n }\n static [entityKind] = \"PgColumn\";\n}\nclass ExtraConfigColumn extends PgColumn {\n static [entityKind] = \"ExtraConfigColumn\";\n getSQLType() {\n return this.getSQLType();\n }\n indexConfig = {\n order: this.config.order ?? \"asc\",\n nulls: this.config.nulls ?? \"last\",\n opClass: this.config.opClass\n };\n defaultConfig = {\n order: \"asc\",\n nulls: \"last\",\n opClass: void 0\n };\n asc() {\n this.indexConfig.order = \"asc\";\n return this;\n }\n desc() {\n this.indexConfig.order = \"desc\";\n return this;\n }\n nullsFirst() {\n this.indexConfig.nulls = \"first\";\n return this;\n }\n nullsLast() {\n this.indexConfig.nulls = \"last\";\n return this;\n }\n /**\n * ### PostgreSQL documentation quote\n *\n * > An operator class with optional parameters can be specified for each column of an index.\n * The operator class identifies the operators to be used by the index for that column.\n * For example, a B-tree index on four-byte integers would use the int4_ops class;\n * this operator class includes comparison functions for four-byte integers.\n * In practice the default operator class for the column's data type is usually sufficient.\n * The main point of having operator classes is that for some data types, there could be more than one meaningful ordering.\n * For example, we might want to sort a complex-number data type either by absolute value or by real part.\n * We could do this by defining two operator classes for the data type and then selecting the proper class when creating an index.\n * More information about operator classes check:\n *\n * ### Useful links\n * https://www.postgresql.org/docs/current/sql-createindex.html\n *\n * https://www.postgresql.org/docs/current/indexes-opclass.html\n *\n * https://www.postgresql.org/docs/current/xindex.html\n *\n * ### Additional types\n * If you have the `pg_vector` extension installed in your database, you can use the\n * `vector_l2_ops`, `vector_ip_ops`, `vector_cosine_ops`, `vector_l1_ops`, `bit_hamming_ops`, `bit_jaccard_ops`, `halfvec_l2_ops`, `sparsevec_l2_ops` options, which are predefined types.\n *\n * **You can always specify any string you want in the operator class, in case Drizzle doesn't have it natively in its types**\n *\n * @param opClass\n * @returns\n */\n op(opClass) {\n this.indexConfig.opClass = opClass;\n return this;\n }\n}\nclass IndexedColumn {\n static [entityKind] = \"IndexedColumn\";\n constructor(name, keyAsName, type, indexConfig) {\n this.name = name;\n this.keyAsName = keyAsName;\n this.type = type;\n this.indexConfig = indexConfig;\n }\n name;\n keyAsName;\n type;\n indexConfig;\n}\nclass PgArrayBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgArrayBuilder\";\n constructor(name, baseBuilder, size) {\n super(name, \"array\", \"PgArray\");\n this.config.baseBuilder = baseBuilder;\n this.config.size = size;\n }\n /** @internal */\n build(table) {\n const baseColumn = this.config.baseBuilder.build(table);\n return new PgArray(\n table,\n this.config,\n baseColumn\n );\n }\n}\nclass PgArray extends PgColumn {\n constructor(table, config, baseColumn, range) {\n super(table, config);\n this.baseColumn = baseColumn;\n this.range = range;\n this.size = config.size;\n }\n size;\n static [entityKind] = \"PgArray\";\n getSQLType() {\n return `${this.baseColumn.getSQLType()}[${typeof this.size === \"number\" ? this.size : \"\"}]`;\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") {\n value = parsePgArray(value);\n }\n return value.map((v) => this.baseColumn.mapFromDriverValue(v));\n }\n mapToDriverValue(value, isNestedArray = false) {\n const a = value.map(\n (v) => v === null ? null : is(this.baseColumn, PgArray) ? this.baseColumn.mapToDriverValue(v, true) : this.baseColumn.mapToDriverValue(v)\n );\n if (isNestedArray) return a;\n return makePgArray(a);\n }\n}\nexport {\n ExtraConfigColumn,\n IndexedColumn,\n PgArray,\n PgArrayBuilder,\n PgColumn,\n PgColumnBuilder\n};\n//# sourceMappingURL=common.js.map","import { entityKind, is } from \"../entity.js\";\nimport { isPgEnum } from \"../pg-core/columns/enum.js\";\nimport { Subquery } from \"../subquery.js\";\nimport { tracer } from \"../tracing.js\";\nimport { ViewBaseConfig } from \"../view-common.js\";\nimport { Column } from \"../column.js\";\nimport { IsAlias, Table } from \"../table.js\";\nclass FakePrimitiveParam {\n static [entityKind] = \"FakePrimitiveParam\";\n}\nfunction isSQLWrapper(value) {\n return value !== null && value !== void 0 && typeof value.getSQL === \"function\";\n}\nfunction mergeQueries(queries) {\n const result = { sql: \"\", params: [] };\n for (const query of queries) {\n result.sql += query.sql;\n result.params.push(...query.params);\n if (query.typings?.length) {\n if (!result.typings) {\n result.typings = [];\n }\n result.typings.push(...query.typings);\n }\n }\n return result;\n}\nclass StringChunk {\n static [entityKind] = \"StringChunk\";\n value;\n constructor(value) {\n this.value = Array.isArray(value) ? value : [value];\n }\n getSQL() {\n return new SQL([this]);\n }\n}\nclass SQL {\n constructor(queryChunks) {\n this.queryChunks = queryChunks;\n for (const chunk of queryChunks) {\n if (is(chunk, Table)) {\n const schemaName = chunk[Table.Symbol.Schema];\n this.usedTables.push(\n schemaName === void 0 ? chunk[Table.Symbol.Name] : schemaName + \".\" + chunk[Table.Symbol.Name]\n );\n }\n }\n }\n static [entityKind] = \"SQL\";\n /** @internal */\n decoder = noopDecoder;\n shouldInlineParams = false;\n /** @internal */\n usedTables = [];\n append(query) {\n this.queryChunks.push(...query.queryChunks);\n return this;\n }\n toQuery(config) {\n return tracer.startActiveSpan(\"drizzle.buildSQL\", (span) => {\n const query = this.buildQueryFromSourceParams(this.queryChunks, config);\n span?.setAttributes({\n \"drizzle.query.text\": query.sql,\n \"drizzle.query.params\": JSON.stringify(query.params)\n });\n return query;\n });\n }\n buildQueryFromSourceParams(chunks, _config) {\n const config = Object.assign({}, _config, {\n inlineParams: _config.inlineParams || this.shouldInlineParams,\n paramStartIndex: _config.paramStartIndex || { value: 0 }\n });\n const {\n casing,\n escapeName,\n escapeParam,\n prepareTyping,\n inlineParams,\n paramStartIndex\n } = config;\n return mergeQueries(chunks.map((chunk) => {\n if (is(chunk, StringChunk)) {\n return { sql: chunk.value.join(\"\"), params: [] };\n }\n if (is(chunk, Name)) {\n return { sql: escapeName(chunk.value), params: [] };\n }\n if (chunk === void 0) {\n return { sql: \"\", params: [] };\n }\n if (Array.isArray(chunk)) {\n const result = [new StringChunk(\"(\")];\n for (const [i, p] of chunk.entries()) {\n result.push(p);\n if (i < chunk.length - 1) {\n result.push(new StringChunk(\", \"));\n }\n }\n result.push(new StringChunk(\")\"));\n return this.buildQueryFromSourceParams(result, config);\n }\n if (is(chunk, SQL)) {\n return this.buildQueryFromSourceParams(chunk.queryChunks, {\n ...config,\n inlineParams: inlineParams || chunk.shouldInlineParams\n });\n }\n if (is(chunk, Table)) {\n const schemaName = chunk[Table.Symbol.Schema];\n const tableName = chunk[Table.Symbol.Name];\n return {\n sql: schemaName === void 0 || chunk[IsAlias] ? escapeName(tableName) : escapeName(schemaName) + \".\" + escapeName(tableName),\n params: []\n };\n }\n if (is(chunk, Column)) {\n const columnName = casing.getColumnCasing(chunk);\n if (_config.invokeSource === \"indexes\") {\n return { sql: escapeName(columnName), params: [] };\n }\n const schemaName = chunk.table[Table.Symbol.Schema];\n return {\n sql: chunk.table[IsAlias] || schemaName === void 0 ? escapeName(chunk.table[Table.Symbol.Name]) + \".\" + escapeName(columnName) : escapeName(schemaName) + \".\" + escapeName(chunk.table[Table.Symbol.Name]) + \".\" + escapeName(columnName),\n params: []\n };\n }\n if (is(chunk, View)) {\n const schemaName = chunk[ViewBaseConfig].schema;\n const viewName = chunk[ViewBaseConfig].name;\n return {\n sql: schemaName === void 0 || chunk[ViewBaseConfig].isAlias ? escapeName(viewName) : escapeName(schemaName) + \".\" + escapeName(viewName),\n params: []\n };\n }\n if (is(chunk, Param)) {\n if (is(chunk.value, Placeholder)) {\n return { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: [\"none\"] };\n }\n const mappedValue = chunk.value === null ? null : chunk.encoder.mapToDriverValue(chunk.value);\n if (is(mappedValue, SQL)) {\n return this.buildQueryFromSourceParams([mappedValue], config);\n }\n if (inlineParams) {\n return { sql: this.mapInlineParam(mappedValue, config), params: [] };\n }\n let typings = [\"none\"];\n if (prepareTyping) {\n typings = [prepareTyping(chunk.encoder)];\n }\n return { sql: escapeParam(paramStartIndex.value++, mappedValue), params: [mappedValue], typings };\n }\n if (is(chunk, Placeholder)) {\n return { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: [\"none\"] };\n }\n if (is(chunk, SQL.Aliased) && chunk.fieldAlias !== void 0) {\n return { sql: escapeName(chunk.fieldAlias), params: [] };\n }\n if (is(chunk, Subquery)) {\n if (chunk._.isWith) {\n return { sql: escapeName(chunk._.alias), params: [] };\n }\n return this.buildQueryFromSourceParams([\n new StringChunk(\"(\"),\n chunk._.sql,\n new StringChunk(\") \"),\n new Name(chunk._.alias)\n ], config);\n }\n if (isPgEnum(chunk)) {\n if (chunk.schema) {\n return { sql: escapeName(chunk.schema) + \".\" + escapeName(chunk.enumName), params: [] };\n }\n return { sql: escapeName(chunk.enumName), params: [] };\n }\n if (isSQLWrapper(chunk)) {\n if (chunk.shouldOmitSQLParens?.()) {\n return this.buildQueryFromSourceParams([chunk.getSQL()], config);\n }\n return this.buildQueryFromSourceParams([\n new StringChunk(\"(\"),\n chunk.getSQL(),\n new StringChunk(\")\")\n ], config);\n }\n if (inlineParams) {\n return { sql: this.mapInlineParam(chunk, config), params: [] };\n }\n return { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: [\"none\"] };\n }));\n }\n mapInlineParam(chunk, { escapeString }) {\n if (chunk === null) {\n return \"null\";\n }\n if (typeof chunk === \"number\" || typeof chunk === \"boolean\") {\n return chunk.toString();\n }\n if (typeof chunk === \"string\") {\n return escapeString(chunk);\n }\n if (typeof chunk === \"object\") {\n const mappedValueAsString = chunk.toString();\n if (mappedValueAsString === \"[object Object]\") {\n return escapeString(JSON.stringify(chunk));\n }\n return escapeString(mappedValueAsString);\n }\n throw new Error(\"Unexpected param value: \" + chunk);\n }\n getSQL() {\n return this;\n }\n as(alias) {\n if (alias === void 0) {\n return this;\n }\n return new SQL.Aliased(this, alias);\n }\n mapWith(decoder) {\n this.decoder = typeof decoder === \"function\" ? { mapFromDriverValue: decoder } : decoder;\n return this;\n }\n inlineParams() {\n this.shouldInlineParams = true;\n return this;\n }\n /**\n * This method is used to conditionally include a part of the query.\n *\n * @param condition - Condition to check\n * @returns itself if the condition is `true`, otherwise `undefined`\n */\n if(condition) {\n return condition ? this : void 0;\n }\n}\nclass Name {\n constructor(value) {\n this.value = value;\n }\n static [entityKind] = \"Name\";\n brand;\n getSQL() {\n return new SQL([this]);\n }\n}\nfunction name(value) {\n return new Name(value);\n}\nfunction isDriverValueEncoder(value) {\n return typeof value === \"object\" && value !== null && \"mapToDriverValue\" in value && typeof value.mapToDriverValue === \"function\";\n}\nconst noopDecoder = {\n mapFromDriverValue: (value) => value\n};\nconst noopEncoder = {\n mapToDriverValue: (value) => value\n};\nconst noopMapper = {\n ...noopDecoder,\n ...noopEncoder\n};\nclass Param {\n /**\n * @param value - Parameter value\n * @param encoder - Encoder to convert the value to a driver parameter\n */\n constructor(value, encoder = noopEncoder) {\n this.value = value;\n this.encoder = encoder;\n }\n static [entityKind] = \"Param\";\n brand;\n getSQL() {\n return new SQL([this]);\n }\n}\nfunction param(value, encoder) {\n return new Param(value, encoder);\n}\nfunction sql(strings, ...params) {\n const queryChunks = [];\n if (params.length > 0 || strings.length > 0 && strings[0] !== \"\") {\n queryChunks.push(new StringChunk(strings[0]));\n }\n for (const [paramIndex, param2] of params.entries()) {\n queryChunks.push(param2, new StringChunk(strings[paramIndex + 1]));\n }\n return new SQL(queryChunks);\n}\n((sql2) => {\n function empty() {\n return new SQL([]);\n }\n sql2.empty = empty;\n function fromList(list) {\n return new SQL(list);\n }\n sql2.fromList = fromList;\n function raw(str) {\n return new SQL([new StringChunk(str)]);\n }\n sql2.raw = raw;\n function join(chunks, separator) {\n const result = [];\n for (const [i, chunk] of chunks.entries()) {\n if (i > 0 && separator !== void 0) {\n result.push(separator);\n }\n result.push(chunk);\n }\n return new SQL(result);\n }\n sql2.join = join;\n function identifier(value) {\n return new Name(value);\n }\n sql2.identifier = identifier;\n function placeholder2(name2) {\n return new Placeholder(name2);\n }\n sql2.placeholder = placeholder2;\n function param2(value, encoder) {\n return new Param(value, encoder);\n }\n sql2.param = param2;\n})(sql || (sql = {}));\n((SQL2) => {\n class Aliased {\n constructor(sql2, fieldAlias) {\n this.sql = sql2;\n this.fieldAlias = fieldAlias;\n }\n static [entityKind] = \"SQL.Aliased\";\n /** @internal */\n isSelectionField = false;\n getSQL() {\n return this.sql;\n }\n /** @internal */\n clone() {\n return new Aliased(this.sql, this.fieldAlias);\n }\n }\n SQL2.Aliased = Aliased;\n})(SQL || (SQL = {}));\nclass Placeholder {\n constructor(name2) {\n this.name = name2;\n }\n static [entityKind] = \"Placeholder\";\n getSQL() {\n return new SQL([this]);\n }\n}\nfunction placeholder(name2) {\n return new Placeholder(name2);\n}\nfunction fillPlaceholders(params, values) {\n return params.map((p) => {\n if (is(p, Placeholder)) {\n if (!(p.name in values)) {\n throw new Error(`No value for placeholder \"${p.name}\" was provided`);\n }\n return values[p.name];\n }\n if (is(p, Param) && is(p.value, Placeholder)) {\n if (!(p.value.name in values)) {\n throw new Error(`No value for placeholder \"${p.value.name}\" was provided`);\n }\n return p.encoder.mapToDriverValue(values[p.value.name]);\n }\n return p;\n });\n}\nconst IsDrizzleView = Symbol.for(\"drizzle:IsDrizzleView\");\nclass View {\n static [entityKind] = \"View\";\n /** @internal */\n [ViewBaseConfig];\n /** @internal */\n [IsDrizzleView] = true;\n constructor({ name: name2, schema, selectedFields, query }) {\n this[ViewBaseConfig] = {\n name: name2,\n originalName: name2,\n schema,\n selectedFields,\n query,\n isExisting: !query,\n isAlias: false\n };\n }\n getSQL() {\n return new SQL([this]);\n }\n}\nfunction isView(view) {\n return typeof view === \"object\" && view !== null && IsDrizzleView in view;\n}\nfunction getViewName(view) {\n return view[ViewBaseConfig].name;\n}\nColumn.prototype.getSQL = function() {\n return new SQL([this]);\n};\nTable.prototype.getSQL = function() {\n return new SQL([this]);\n};\nSubquery.prototype.getSQL = function() {\n return new SQL([this]);\n};\nexport {\n FakePrimitiveParam,\n Name,\n Param,\n Placeholder,\n SQL,\n StringChunk,\n View,\n fillPlaceholders,\n getViewName,\n isDriverValueEncoder,\n isSQLWrapper,\n isView,\n name,\n noopDecoder,\n noopEncoder,\n noopMapper,\n param,\n placeholder,\n sql\n};\n//# sourceMappingURL=sql.js.map","import { Column } from \"../../column.js\";\nimport { is } from \"../../entity.js\";\nimport { Table } from \"../../table.js\";\nimport {\n isDriverValueEncoder,\n isSQLWrapper,\n Param,\n Placeholder,\n SQL,\n sql,\n StringChunk,\n View\n} from \"../sql.js\";\nfunction bindIfParam(value, column) {\n if (isDriverValueEncoder(column) && !isSQLWrapper(value) && !is(value, Param) && !is(value, Placeholder) && !is(value, Column) && !is(value, Table) && !is(value, View)) {\n return new Param(value, column);\n }\n return value;\n}\nconst eq = (left, right) => {\n return sql`${left} = ${bindIfParam(right, left)}`;\n};\nconst ne = (left, right) => {\n return sql`${left} <> ${bindIfParam(right, left)}`;\n};\nfunction and(...unfilteredConditions) {\n const conditions = unfilteredConditions.filter(\n (c) => c !== void 0\n );\n if (conditions.length === 0) {\n return void 0;\n }\n if (conditions.length === 1) {\n return new SQL(conditions);\n }\n return new SQL([\n new StringChunk(\"(\"),\n sql.join(conditions, new StringChunk(\" and \")),\n new StringChunk(\")\")\n ]);\n}\nfunction or(...unfilteredConditions) {\n const conditions = unfilteredConditions.filter(\n (c) => c !== void 0\n );\n if (conditions.length === 0) {\n return void 0;\n }\n if (conditions.length === 1) {\n return new SQL(conditions);\n }\n return new SQL([\n new StringChunk(\"(\"),\n sql.join(conditions, new StringChunk(\" or \")),\n new StringChunk(\")\")\n ]);\n}\nfunction not(condition) {\n return sql`not ${condition}`;\n}\nconst gt = (left, right) => {\n return sql`${left} > ${bindIfParam(right, left)}`;\n};\nconst gte = (left, right) => {\n return sql`${left} >= ${bindIfParam(right, left)}`;\n};\nconst lt = (left, right) => {\n return sql`${left} < ${bindIfParam(right, left)}`;\n};\nconst lte = (left, right) => {\n return sql`${left} <= ${bindIfParam(right, left)}`;\n};\nfunction inArray(column, values) {\n if (Array.isArray(values)) {\n if (values.length === 0) {\n return sql`false`;\n }\n return sql`${column} in ${values.map((v) => bindIfParam(v, column))}`;\n }\n return sql`${column} in ${bindIfParam(values, column)}`;\n}\nfunction notInArray(column, values) {\n if (Array.isArray(values)) {\n if (values.length === 0) {\n return sql`true`;\n }\n return sql`${column} not in ${values.map((v) => bindIfParam(v, column))}`;\n }\n return sql`${column} not in ${bindIfParam(values, column)}`;\n}\nfunction isNull(value) {\n return sql`${value} is null`;\n}\nfunction isNotNull(value) {\n return sql`${value} is not null`;\n}\nfunction exists(subquery) {\n return sql`exists ${subquery}`;\n}\nfunction notExists(subquery) {\n return sql`not exists ${subquery}`;\n}\nfunction between(column, min, max) {\n return sql`${column} between ${bindIfParam(min, column)} and ${bindIfParam(\n max,\n column\n )}`;\n}\nfunction notBetween(column, min, max) {\n return sql`${column} not between ${bindIfParam(\n min,\n column\n )} and ${bindIfParam(max, column)}`;\n}\nfunction like(column, value) {\n return sql`${column} like ${value}`;\n}\nfunction notLike(column, value) {\n return sql`${column} not like ${value}`;\n}\nfunction ilike(column, value) {\n return sql`${column} ilike ${value}`;\n}\nfunction notIlike(column, value) {\n return sql`${column} not ilike ${value}`;\n}\nfunction arrayContains(column, values) {\n if (Array.isArray(values)) {\n if (values.length === 0) {\n throw new Error(\"arrayContains requires at least one value\");\n }\n const array = sql`${bindIfParam(values, column)}`;\n return sql`${column} @> ${array}`;\n }\n return sql`${column} @> ${bindIfParam(values, column)}`;\n}\nfunction arrayContained(column, values) {\n if (Array.isArray(values)) {\n if (values.length === 0) {\n throw new Error(\"arrayContained requires at least one value\");\n }\n const array = sql`${bindIfParam(values, column)}`;\n return sql`${column} <@ ${array}`;\n }\n return sql`${column} <@ ${bindIfParam(values, column)}`;\n}\nfunction arrayOverlaps(column, values) {\n if (Array.isArray(values)) {\n if (values.length === 0) {\n throw new Error(\"arrayOverlaps requires at least one value\");\n }\n const array = sql`${bindIfParam(values, column)}`;\n return sql`${column} && ${array}`;\n }\n return sql`${column} && ${bindIfParam(values, column)}`;\n}\nexport {\n and,\n arrayContained,\n arrayContains,\n arrayOverlaps,\n between,\n bindIfParam,\n eq,\n exists,\n gt,\n gte,\n ilike,\n inArray,\n isNotNull,\n isNull,\n like,\n lt,\n lte,\n ne,\n not,\n notBetween,\n notExists,\n notIlike,\n notInArray,\n notLike,\n or\n};\n//# sourceMappingURL=conditions.js.map"],"names":["value","startFrom","ref","actions","otel","rawTracer","param","sql","placeholder","name","SQL","result","import_utils","relations","import_table","import_sql","table","select","joinOn","field","alias","PreparedQueryBase","Client","instance","drizzle"],"mappings":"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","ignoreList":[13,109,110,111,112,113,114,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138]}
|