mirror of
https://github.com/DeNNiiInc/dbgate.git
synced 2026-04-29 07:36:01 +00:00
table restore script WIP
This commit is contained in:
45
packages/web/src/utility/tableRestoreScript.ts
Normal file
45
packages/web/src/utility/tableRestoreScript.ts
Normal file
@@ -0,0 +1,45 @@
|
||||
import _ from 'lodash';
|
||||
import { dumpSqlInsert, Insert } from 'dbgate-sqltree';
|
||||
import { TableInfo, SqlDumper } from 'dbgate-types';
|
||||
|
||||
export function createTableRestoreScript(backupTable: TableInfo, originalTable: TableInfo, dmp: SqlDumper) {
|
||||
const bothColumns = _.intersection(
|
||||
backupTable.columns.map(x => x.columnName),
|
||||
originalTable.columns.map(x => x.columnName)
|
||||
);
|
||||
const keyColumns = _.intersection(
|
||||
originalTable.primaryKey?.columns?.map(x => x.columnName) || [],
|
||||
backupTable.columns.map(x => x.columnName)
|
||||
);
|
||||
const insert: Insert = {
|
||||
commandType: 'insert',
|
||||
targetTable: originalTable,
|
||||
fields: bothColumns.map(colName => ({
|
||||
targetColumn: colName,
|
||||
exprType: 'column',
|
||||
columnName: colName,
|
||||
source: { alias: 'bak' },
|
||||
})),
|
||||
whereNotExistsSource: { name: backupTable, alias: 'bak' },
|
||||
insertWhereNotExistsCondition: {
|
||||
conditionType: 'and',
|
||||
conditions: keyColumns.map(colName => ({
|
||||
conditionType: 'binary',
|
||||
operator: '=',
|
||||
left: {
|
||||
exprType: 'column',
|
||||
columnName: colName,
|
||||
source: { name: originalTable },
|
||||
},
|
||||
right: {
|
||||
exprType: 'column',
|
||||
columnName: colName,
|
||||
source: { alias: 'bak' },
|
||||
},
|
||||
})),
|
||||
},
|
||||
};
|
||||
|
||||
dumpSqlInsert(dmp, insert);
|
||||
dmp.endCommand();
|
||||
}
|
||||
Reference in New Issue
Block a user