Home / Class/ SQLiteAsyncDialect Class — drizzle-orm Architecture

SQLiteAsyncDialect Class — drizzle-orm Architecture

Architecture documentation for the SQLiteAsyncDialect class in dialect.ts from the drizzle-orm codebase.

Entity Profile

Dependency Diagram

graph TD
  29247d4f_c72d_29d8_1020_4e820195e212["SQLiteAsyncDialect"]
  209e34fa_8ae1_5a1a_23cb_e4720fd5b915["dialect.ts"]
  29247d4f_c72d_29d8_1020_4e820195e212 -->|defined in| 209e34fa_8ae1_5a1a_23cb_e4720fd5b915
  54ccb907_d126_1ea5_56ab_12847340fd47["migrate()"]
  29247d4f_c72d_29d8_1020_4e820195e212 -->|method| 54ccb907_d126_1ea5_56ab_12847340fd47

Relationship Graph

Source Code

drizzle-orm/src/sqlite-core/dialect.ts lines 882–926

export class SQLiteAsyncDialect extends SQLiteDialect {
	static override readonly [entityKind]: string = 'SQLiteAsyncDialect';

	async migrate(
		migrations: MigrationMeta[],
		session: SQLiteSession<'async', any, any, any>,
		config?: string | MigrationConfig,
	): Promise<void> {
		const migrationsTable = config === undefined
			? '__drizzle_migrations'
			: typeof config === 'string'
			? '__drizzle_migrations'
			: config.migrationsTable ?? '__drizzle_migrations';

		const migrationTableCreate = sql`
			CREATE TABLE IF NOT EXISTS ${sql.identifier(migrationsTable)} (
				id SERIAL PRIMARY KEY,
				hash text NOT NULL,
				created_at numeric
			)
		`;
		await session.run(migrationTableCreate);

		const dbMigrations = await session.values<[number, string, string]>(
			sql`SELECT id, hash, created_at FROM ${sql.identifier(migrationsTable)} ORDER BY created_at DESC LIMIT 1`,
		);

		const lastDbMigration = dbMigrations[0] ?? undefined;

		await session.transaction(async (tx) => {
			for (const migration of migrations) {
				if (!lastDbMigration || Number(lastDbMigration[2])! < migration.folderMillis) {
					for (const stmt of migration.sql) {
						await tx.run(sql.raw(stmt));
					}
					await tx.run(
						sql`INSERT INTO ${
							sql.identifier(migrationsTable)
						} ("hash", "created_at") VALUES(${migration.hash}, ${migration.folderMillis})`,
					);
				}
			}
		});
	}
}

Domain

Frequently Asked Questions

What is the SQLiteAsyncDialect class?
SQLiteAsyncDialect is a class in the drizzle-orm codebase, defined in drizzle-orm/src/sqlite-core/dialect.ts.
Where is SQLiteAsyncDialect defined?
SQLiteAsyncDialect is defined in drizzle-orm/src/sqlite-core/dialect.ts at line 882.

Analyze Your Own Codebase

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

Try Supermodel Free