2025-07-03 10:59:17 -04:00
|
|
|
import { compareColumns } from 'src/sql-tools/comparers/column.comparer';
|
|
|
|
|
import { compareConstraints } from 'src/sql-tools/comparers/constraint.comparer';
|
|
|
|
|
import { compareIndexes } from 'src/sql-tools/comparers/index.comparer';
|
|
|
|
|
import { compareTriggers } from 'src/sql-tools/comparers/trigger.comparer';
|
2025-04-07 15:12:12 -04:00
|
|
|
import { compare } from 'src/sql-tools/helpers';
|
|
|
|
|
import { Comparer, DatabaseTable, Reason, SchemaDiff } from 'src/sql-tools/types';
|
|
|
|
|
|
|
|
|
|
export const compareTables: Comparer<DatabaseTable> = {
|
|
|
|
|
onMissing: (source) => [
|
|
|
|
|
{
|
2025-07-03 10:59:17 -04:00
|
|
|
type: 'TableCreate',
|
2025-04-07 15:12:12 -04:00
|
|
|
table: source,
|
|
|
|
|
reason: Reason.MissingInTarget,
|
|
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
onExtra: (target) => [
|
|
|
|
|
{
|
2025-07-03 10:59:17 -04:00
|
|
|
type: 'TableDrop',
|
2025-04-07 15:12:12 -04:00
|
|
|
tableName: target.name,
|
|
|
|
|
reason: Reason.MissingInSource,
|
|
|
|
|
},
|
|
|
|
|
],
|
2025-07-09 09:13:14 -04:00
|
|
|
onCompare: (source, target) => compareTable(source, target),
|
2025-04-07 15:12:12 -04:00
|
|
|
};
|
|
|
|
|
|
2025-07-09 09:13:14 -04:00
|
|
|
const compareTable = (source: DatabaseTable, target: DatabaseTable): SchemaDiff[] => {
|
2025-04-07 15:12:12 -04:00
|
|
|
return [
|
2025-07-09 09:13:14 -04:00
|
|
|
...compare(source.columns, target.columns, {}, compareColumns),
|
2025-04-07 15:12:12 -04:00
|
|
|
...compare(source.indexes, target.indexes, {}, compareIndexes),
|
|
|
|
|
...compare(source.constraints, target.constraints, {}, compareConstraints),
|
|
|
|
|
...compare(source.triggers, target.triggers, {}, compareTriggers),
|
|
|
|
|
];
|
|
|
|
|
};
|