count.ts — drizzle-orm Source File
Architecture documentation for count.ts, a typescript file in the drizzle-orm codebase. 5 imports, 1 dependents.
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
- entity.ts
- session.ts
- sql.ts
- table.ts
- utils.ts
Imported By
Source
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