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

count.ts — drizzle-orm Source File

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

File typescript DrizzleORM QueryBuilders 5 imports 1 dependents 1 classes

Entity Profile

Dependency Diagram

graph LR
  fa6a01b7_6d1f_e5fb_2daa_b614b6687cb0["count.ts"]
  ed278e34_87d5_45ca_9ac1_16137c36228f["session.ts"]
  fa6a01b7_6d1f_e5fb_2daa_b614b6687cb0 --> ed278e34_87d5_45ca_9ac1_16137c36228f
  2d5c8884_973c_561c_def6_5e394ea36d1a["table.ts"]
  fa6a01b7_6d1f_e5fb_2daa_b614b6687cb0 --> 2d5c8884_973c_561c_def6_5e394ea36d1a
  27705a9d_afe9_57dd_8c97_e52d8a67d426["entity.ts"]
  fa6a01b7_6d1f_e5fb_2daa_b614b6687cb0 --> 27705a9d_afe9_57dd_8c97_e52d8a67d426
  be483a7f_d5d7_7a9b_9a13_44a4a6aafbbd["sql.ts"]
  fa6a01b7_6d1f_e5fb_2daa_b614b6687cb0 --> be483a7f_d5d7_7a9b_9a13_44a4a6aafbbd
  ecce3253_1e75_a87f_27b3_ca87e81a3024["utils.ts"]
  fa6a01b7_6d1f_e5fb_2daa_b614b6687cb0 --> ecce3253_1e75_a87f_27b3_ca87e81a3024
  99d4b8a7_e046_2f16_afff_9a25e87a12c1["db.ts"]
  99d4b8a7_e046_2f16_afff_9a25e87a12c1 --> fa6a01b7_6d1f_e5fb_2daa_b614b6687cb0
  style fa6a01b7_6d1f_e5fb_2daa_b614b6687cb0 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import { entityKind } from '~/entity.ts';
import { SQL, sql, type SQLWrapper } from '~/sql/sql.ts';
import type { NeonAuthToken } from '~/utils.ts';
import type { PgSession } from '../session.ts';
import type { PgTable } from '../table.ts';

export class PgCountBuilder<
	TSession extends PgSession<any, any, any>,
> extends SQL<number> implements Promise<number>, SQLWrapper {
	private sql: SQL<number>;
	private token?: NeonAuthToken;

	static override readonly [entityKind] = 'PgCountBuilder';
	[Symbol.toStringTag] = 'PgCountBuilder';

	private session: TSession;

	private static buildEmbeddedCount(
		source: PgTable | SQL | SQLWrapper,
		filters?: SQL<unknown>,
	): SQL<number> {
		return sql<number>`(select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters})`;
	}

	private static buildCount(
		source: PgTable | SQL | SQLWrapper,
		filters?: SQL<unknown>,
	): SQL<number> {
		return sql<number>`select count(*) as count from ${source}${sql.raw(' where ').if(filters)}${filters};`;
	}

	constructor(
		readonly params: {
			source: PgTable | SQL | SQLWrapper;
			filters?: SQL<unknown>;
			session: TSession;
		},
	) {
		super(PgCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);

		this.mapWith(Number);

		this.session = params.session;

		this.sql = PgCountBuilder.buildCount(
			params.source,
			params.filters,
		);
	}

	/** @intrnal */
	setToken(token?: NeonAuthToken) {
		this.token = token;
		return this;
	}

	then<TResult1 = number, TResult2 = never>(
		onfulfilled?: ((value: number) => TResult1 | PromiseLike<TResult1>) | null | undefined,
		onrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null | undefined,
	): Promise<TResult1 | TResult2> {
		return Promise.resolve(this.session.count(this.sql, this.token))
			.then(
				onfulfilled,
				onrejected,
			);
	}

	catch(
		onRejected?: ((reason: any) => any) | null | undefined,
	): Promise<number> {
		return this.then(undefined, onRejected);
	}

	finally(onFinally?: (() => void) | null | undefined): Promise<number> {
		return this.then(
			(value) => {
				onFinally?.();
				return value;
			},
			(reason) => {
				onFinally?.();
				throw reason;
			},
		);
	}
}

Domain

Subdomains

Classes

Dependencies

Frequently Asked Questions

What does count.ts do?
count.ts is a source file in the drizzle-orm codebase, written in typescript. It belongs to the DrizzleORM domain, QueryBuilders subdomain.
What does count.ts depend on?
count.ts imports 5 module(s): entity.ts, session.ts, sql.ts, table.ts, utils.ts.
What files import count.ts?
count.ts is imported by 1 file(s): db.ts.
Where is count.ts in the architecture?
count.ts is located at drizzle-orm/src/pg-core/query-builders/count.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