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 eee8ef5a_a55a_1296_0eb0_8b784d2ecf58["count.ts"] e8dc183d_ef37_2b6f_dec4_127a8dea0aaf["session.ts"] eee8ef5a_a55a_1296_0eb0_8b784d2ecf58 --> e8dc183d_ef37_2b6f_dec4_127a8dea0aaf 62c695d3_7eff_3822_db70_ce6b25ccdb04["table.ts"] eee8ef5a_a55a_1296_0eb0_8b784d2ecf58 --> 62c695d3_7eff_3822_db70_ce6b25ccdb04 a79cf58d_7307_4b51_46d7_0b6063316314["view-base.ts"] eee8ef5a_a55a_1296_0eb0_8b784d2ecf58 --> a79cf58d_7307_4b51_46d7_0b6063316314 27705a9d_afe9_57dd_8c97_e52d8a67d426["entity.ts"] eee8ef5a_a55a_1296_0eb0_8b784d2ecf58 --> 27705a9d_afe9_57dd_8c97_e52d8a67d426 be483a7f_d5d7_7a9b_9a13_44a4a6aafbbd["sql.ts"] eee8ef5a_a55a_1296_0eb0_8b784d2ecf58 --> be483a7f_d5d7_7a9b_9a13_44a4a6aafbbd 55a32696_6538_e52d_9dd2_18695934fe32["db.ts"] 55a32696_6538_e52d_9dd2_18695934fe32 --> eee8ef5a_a55a_1296_0eb0_8b784d2ecf58 style eee8ef5a_a55a_1296_0eb0_8b784d2ecf58 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 { MySqlSession } from '../session.ts';
import type { MySqlTable } from '../table.ts';
import type { MySqlViewBase } from '../view-base.ts';
export class MySqlCountBuilder<
TSession extends MySqlSession<any, any, any>,
> extends SQL<number> implements Promise<number>, SQLWrapper {
private sql: SQL<number>;
static override readonly [entityKind] = 'MySqlCountBuilder';
[Symbol.toStringTag] = 'MySqlCountBuilder';
private session: TSession;
private static buildEmbeddedCount(
source: MySqlTable | MySqlViewBase | SQL | SQLWrapper,
filters?: SQL<unknown>,
): SQL<number> {
return sql<number>`(select count(*) from ${source}${sql.raw(' where ').if(filters)}${filters})`;
}
private static buildCount(
source: MySqlTable | MySqlViewBase | 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: MySqlTable | MySqlViewBase | SQL | SQLWrapper;
filters?: SQL<unknown>;
session: TSession;
},
) {
super(MySqlCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);
this.mapWith(Number);
this.session = params.session;
this.sql = MySqlCountBuilder.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-base.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-base.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/mysql-core/query-builders/count.ts (domain: DrizzleORM, subdomain: SQLDialects, directory: drizzle-orm/src/mysql-core/query-builders).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free