Home / File/ query.ts — drizzle-orm Source File

query.ts — drizzle-orm Source File

Architecture documentation for query.ts, a typescript file in the drizzle-orm codebase. 10 imports, 1 dependents.

File typescript DrizzleORM QueryBuilders 10 imports 1 dependents 2 classes

Entity Profile

Dependency Diagram

graph LR
  cb792d01_598c_043a_5de1_379e203f46ee["query.ts"]
  f5d8a5f9_df11_57a8_8f3f_88924e501a7c["dialect.ts"]
  cb792d01_598c_043a_5de1_379e203f46ee --> f5d8a5f9_df11_57a8_8f3f_88924e501a7c
  ed278e34_87d5_45ca_9ac1_16137c36228f["session.ts"]
  cb792d01_598c_043a_5de1_379e203f46ee --> ed278e34_87d5_45ca_9ac1_16137c36228f
  2d5c8884_973c_561c_def6_5e394ea36d1a["table.ts"]
  cb792d01_598c_043a_5de1_379e203f46ee --> 2d5c8884_973c_561c_def6_5e394ea36d1a
  27705a9d_afe9_57dd_8c97_e52d8a67d426["entity.ts"]
  cb792d01_598c_043a_5de1_379e203f46ee --> 27705a9d_afe9_57dd_8c97_e52d8a67d426
  6acf5c54_62a7_1da1_984a_7374cbb9983e["query-promise.ts"]
  cb792d01_598c_043a_5de1_379e203f46ee --> 6acf5c54_62a7_1da1_984a_7374cbb9983e
  e4d6a0ab_9aa2_13a6_a2f1_58d94314c3f2["relations.ts"]
  cb792d01_598c_043a_5de1_379e203f46ee --> e4d6a0ab_9aa2_13a6_a2f1_58d94314c3f2
  05d1039e_d7d0_0fa1_6f52_956655638080["runnable-query.ts"]
  cb792d01_598c_043a_5de1_379e203f46ee --> 05d1039e_d7d0_0fa1_6f52_956655638080
  be483a7f_d5d7_7a9b_9a13_44a4a6aafbbd["sql.ts"]
  cb792d01_598c_043a_5de1_379e203f46ee --> be483a7f_d5d7_7a9b_9a13_44a4a6aafbbd
  051cc2d2_fe6f_16df_aaec_3b341d2c2576["tracing.ts"]
  cb792d01_598c_043a_5de1_379e203f46ee --> 051cc2d2_fe6f_16df_aaec_3b341d2c2576
  ecce3253_1e75_a87f_27b3_ca87e81a3024["utils.ts"]
  cb792d01_598c_043a_5de1_379e203f46ee --> ecce3253_1e75_a87f_27b3_ca87e81a3024
  99d4b8a7_e046_2f16_afff_9a25e87a12c1["db.ts"]
  99d4b8a7_e046_2f16_afff_9a25e87a12c1 --> cb792d01_598c_043a_5de1_379e203f46ee
  style cb792d01_598c_043a_5de1_379e203f46ee fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import { entityKind } from '~/entity.ts';
import { QueryPromise } from '~/query-promise.ts';
import {
	type BuildQueryResult,
	type BuildRelationalQueryResult,
	type DBQueryConfig,
	mapRelationalRow,
	type TableRelationalConfig,
	type TablesRelationalConfig,
} from '~/relations.ts';
import type { RunnableQuery } from '~/runnable-query.ts';
import type { Query, QueryWithTypings, SQL, SQLWrapper } from '~/sql/sql.ts';
import { tracer } from '~/tracing.ts';
import type { KnownKeysOnly, NeonAuthToken } from '~/utils.ts';
import type { PgDialect } from '../dialect.ts';
import type { PgPreparedQuery, PgSession, PreparedQueryConfig } from '../session.ts';
import type { PgTable } from '../table.ts';

export class RelationalQueryBuilder<TSchema extends TablesRelationalConfig, TFields extends TableRelationalConfig> {
	static readonly [entityKind]: string = 'PgRelationalQueryBuilder';

	constructor(
		private fullSchema: Record<string, unknown>,
		private schema: TSchema,
		private tableNamesMap: Record<string, string>,
		private table: PgTable,
		private tableConfig: TableRelationalConfig,
		private dialect: PgDialect,
		private session: PgSession,
	) {}

	findMany<TConfig extends DBQueryConfig<'many', true, TSchema, TFields>>(
		config?: KnownKeysOnly<TConfig, DBQueryConfig<'many', true, TSchema, TFields>>,
	): PgRelationalQuery<BuildQueryResult<TSchema, TFields, TConfig>[]> {
		return new PgRelationalQuery(
			this.fullSchema,
			this.schema,
			this.tableNamesMap,
			this.table,
			this.tableConfig,
			this.dialect,
			this.session,
			config ? (config as DBQueryConfig<'many', true>) : {},
			'many',
		);
	}

	findFirst<TSelection extends Omit<DBQueryConfig<'many', true, TSchema, TFields>, 'limit'>>(
		config?: KnownKeysOnly<TSelection, Omit<DBQueryConfig<'many', true, TSchema, TFields>, 'limit'>>,
	): PgRelationalQuery<BuildQueryResult<TSchema, TFields, TSelection> | undefined> {
		return new PgRelationalQuery(
			this.fullSchema,
			this.schema,
			this.tableNamesMap,
			this.table,
			this.tableConfig,
			this.dialect,
			this.session,
			config ? { ...(config as DBQueryConfig<'many', true> | undefined), limit: 1 } : { limit: 1 },
			'first',
// ... (98 more lines)

Domain

Subdomains

Dependencies

Frequently Asked Questions

What does query.ts do?
query.ts is a source file in the drizzle-orm codebase, written in typescript. It belongs to the DrizzleORM domain, QueryBuilders subdomain.
What does query.ts depend on?
query.ts imports 10 module(s): dialect.ts, entity.ts, query-promise.ts, relations.ts, runnable-query.ts, session.ts, sql.ts, table.ts, and 2 more.
What files import query.ts?
query.ts is imported by 1 file(s): db.ts.
Where is query.ts in the architecture?
query.ts is located at drizzle-orm/src/pg-core/query-builders/query.ts (domain: DrizzleORM, subdomain: QueryBuilders, directory: drizzle-orm/src/pg-core/query-builders).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free