import { type Connection as CallbackConnection, type Pool as CallbackPool, type PoolOptions } from 'mysql2'; import type { Connection, Pool } from 'mysql2/promise'; import { entityKind } from "../entity.js"; import type { Logger } from "../logger.js"; import { MySqlDatabase } from "../mysql-core/db.js"; import { MySqlDialect } from "../mysql-core/dialect.js"; import type { Mode } from "../mysql-core/session.js"; import { type RelationalSchemaConfig, type TablesRelationalConfig } from "../relations.js"; import { type DrizzleConfig } from "../utils.js"; import type { MySql2Client, MySql2PreparedQueryHKT, MySql2QueryResultHKT } from "./session.js"; import { MySql2Session } from "./session.js"; export interface MySqlDriverOptions { logger?: Logger; } export declare class MySql2Driver { private client; private dialect; private options; static readonly [entityKind]: string; constructor(client: MySql2Client, dialect: MySqlDialect, options?: MySqlDriverOptions); createSession(schema: RelationalSchemaConfig | undefined, mode: Mode): MySql2Session, TablesRelationalConfig>; } export { MySqlDatabase } from "../mysql-core/db.js"; export declare class MySql2Database = Record> extends MySqlDatabase { static readonly [entityKind]: string; } export type MySql2DrizzleConfig = Record> = Omit, 'schema'> & ({ schema: TSchema; mode: Mode; } | { schema?: undefined; mode?: Mode; }); export type AnyMySql2Connection = Pool | Connection | CallbackPool | CallbackConnection; export declare function drizzle = Record, TClient extends AnyMySql2Connection = CallbackPool>(...params: [ TClient | string ] | [ TClient | string, MySql2DrizzleConfig ] | [ (MySql2DrizzleConfig & ({ connection: string | PoolOptions; } | { client: TClient; })) ]): MySql2Database & { $client: TClient; }; export declare namespace drizzle { function mock = Record>(config?: MySql2DrizzleConfig): MySql2Database & { $client: '$client is not available on drizzle.mock()'; }; }