convert() — drizzle-orm Function Reference
Architecture documentation for the convert() function in sqlgenerator.ts from the drizzle-orm codebase.
Entity Profile
Dependency Diagram
graph TD b8dce68a_f960_6f31_e72e_c412cda25ee3["convert()"] 5a12a936_1565_028f_2abf_979aa155bb2c["SQLiteRecreateTableConvertor"] b8dce68a_f960_6f31_e72e_c412cda25ee3 -->|defined in| 5a12a936_1565_028f_2abf_979aa155bb2c style b8dce68a_f960_6f31_e72e_c412cda25ee3 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
drizzle-kit/src/sqlgenerator.ts lines 3771–3827
convert(statement: JsonRecreateTableStatement): string | string[] {
const { tableName, columns, compositePKs, referenceData, checkConstraints } = statement;
const columnNames = columns.map((it) => `"${it.name}"`).join(', ');
const newTableName = `__new_${tableName}`;
const sqlStatements: string[] = [];
sqlStatements.push(`PRAGMA foreign_keys=OFF;`);
// map all possible variants
const mappedCheckConstraints: string[] = checkConstraints.map((it) =>
it.replaceAll(`"${tableName}".`, `"${newTableName}".`).replaceAll(`\`${tableName}\`.`, `\`${newTableName}\`.`)
.replaceAll(`${tableName}.`, `${newTableName}.`).replaceAll(`'${tableName}'.`, `'${newTableName}'.`)
);
// create new table
sqlStatements.push(
new SQLiteCreateTableConvertor().convert({
type: 'sqlite_create_table',
tableName: newTableName,
columns,
referenceData,
compositePKs,
checkConstraints: mappedCheckConstraints,
}),
);
// migrate data
sqlStatements.push(
`INSERT INTO \`${newTableName}\`(${columnNames}) SELECT ${columnNames} FROM \`${tableName}\`;`,
);
// drop table
sqlStatements.push(
new SQLiteDropTableConvertor().convert({
type: 'drop_table',
tableName: tableName,
schema: '',
}),
);
// rename table
sqlStatements.push(
new SqliteRenameTableConvertor().convert({
fromSchema: '',
tableNameFrom: newTableName,
tableNameTo: tableName,
toSchema: '',
type: 'rename_table',
}),
);
sqlStatements.push(`PRAGMA foreign_keys=ON;`);
return sqlStatements;
}
Domain
Subdomains
Defined In
Source
Frequently Asked Questions
What does convert() do?
convert() is a function in the drizzle-orm codebase, defined in drizzle-kit/src/sqlgenerator.ts.
Where is convert() defined?
convert() is defined in drizzle-kit/src/sqlgenerator.ts at line 3771.
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free