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 586c8fc7_bdd1_953c_6b2a_30ada9e0b861["count.ts"] 0246584b_d63a_06ad_4a46_dd97d5212ea8["session.ts"] 586c8fc7_bdd1_953c_6b2a_30ada9e0b861 --> 0246584b_d63a_06ad_4a46_dd97d5212ea8 64ae061d_ed9a_c5f9_235a_3f31995a8d54["table.ts"] 586c8fc7_bdd1_953c_6b2a_30ada9e0b861 --> 64ae061d_ed9a_c5f9_235a_3f31995a8d54 d25d55b4_d8a4_6f19_2b5c_2ef3a5375746["view.ts"] 586c8fc7_bdd1_953c_6b2a_30ada9e0b861 --> d25d55b4_d8a4_6f19_2b5c_2ef3a5375746 27705a9d_afe9_57dd_8c97_e52d8a67d426["entity.ts"] 586c8fc7_bdd1_953c_6b2a_30ada9e0b861 --> 27705a9d_afe9_57dd_8c97_e52d8a67d426 be483a7f_d5d7_7a9b_9a13_44a4a6aafbbd["sql.ts"] 586c8fc7_bdd1_953c_6b2a_30ada9e0b861 --> be483a7f_d5d7_7a9b_9a13_44a4a6aafbbd e9188303_2815_1371_46b3_eb6061e52537["db.ts"] e9188303_2815_1371_46b3_eb6061e52537 --> 586c8fc7_bdd1_953c_6b2a_30ada9e0b861 style 586c8fc7_bdd1_953c_6b2a_30ada9e0b861 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 { SQLiteSession } from '../session.ts';
import type { SQLiteTable } from '../table.ts';
import type { SQLiteView } from '../view.ts';
export class SQLiteCountBuilder<
TSession extends SQLiteSession<any, any, any, any>,
> extends SQL<number> implements Promise<number>, SQLWrapper {
private sql: SQL<number>;
static override readonly [entityKind] = 'SQLiteCountBuilderAsync';
[Symbol.toStringTag] = 'SQLiteCountBuilderAsync';
private session: TSession;
private static buildEmbeddedCount(
source: SQLiteTable | SQLiteView | SQL | SQLWrapper,
filters?: SQL<unknown>,
): SQL<number> {
return sql<number>`(select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters})`;
}
private static buildCount(
source: SQLiteTable | SQLiteView | SQL | SQLWrapper,
filters?: SQL<unknown>,
): SQL<number> {
return sql<number>`select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters}`;
}
constructor(
readonly params: {
source: SQLiteTable | SQLiteView | SQL | SQLWrapper;
filters?: SQL<unknown>;
session: TSession;
},
) {
super(SQLiteCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);
this.session = params.session;
this.sql = SQLiteCountBuilder.buildCount(
params.source,
params.filters,
);
}
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)).then(
onfulfilled,
onrejected,
);
}
catch(
onRejected?: ((reason: any) => never | PromiseLike<never>) | 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
- view.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, SQLDialects subdomain.
What does count.ts depend on?
count.ts imports 5 module(s): entity.ts, session.ts, sql.ts, table.ts, view.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/sqlite-core/query-builders/count.ts (domain: DrizzleORM, subdomain: SQLDialects, directory: drizzle-orm/src/sqlite-core/query-builders).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free