mirror of
https://github.com/n8n-io/n8n.git
synced 2025-03-05 20:50:17 -08:00
52 lines
1.6 KiB
TypeScript
52 lines
1.6 KiB
TypeScript
import { MigrationInterface, QueryRunner } from 'typeorm';
|
|
import { getTablePrefix, logMigrationEnd, logMigrationStart } from '@db/utils/migrationHelpers';
|
|
|
|
export class DeleteExecutionsWithWorkflows1673268682475 implements MigrationInterface {
|
|
name = 'DeleteExecutionsWithWorkflows1673268682475';
|
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
|
logMigrationStart(this.name);
|
|
const tablePrefix = getTablePrefix();
|
|
|
|
await queryRunner.query(
|
|
`ALTER TABLE ${tablePrefix}execution_entity
|
|
ALTER COLUMN "workflowId" TYPE INTEGER USING "workflowId"::integer`,
|
|
);
|
|
|
|
const workflowIds: Array<{ id: number }> = await queryRunner.query(`
|
|
SELECT id FROM ${tablePrefix}workflow_entity
|
|
`);
|
|
|
|
await queryRunner.query(
|
|
`DELETE FROM ${tablePrefix}execution_entity
|
|
WHERE "workflowId" IS NOT NULL
|
|
${
|
|
workflowIds.length
|
|
? `AND "workflowId" NOT IN (${workflowIds.map(({ id }) => id).join()})`
|
|
: ''
|
|
}`,
|
|
);
|
|
|
|
await queryRunner.query(
|
|
`ALTER TABLE ${tablePrefix}execution_entity
|
|
ADD CONSTRAINT "FK_${tablePrefix}execution_entity_workflowId"
|
|
FOREIGN KEY ("workflowId") REFERENCES ${tablePrefix}workflow_entity ("id")
|
|
ON DELETE CASCADE`,
|
|
);
|
|
|
|
logMigrationEnd(this.name);
|
|
}
|
|
|
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
|
const tablePrefix = getTablePrefix();
|
|
await queryRunner.query(
|
|
`ALTER TABLE ${tablePrefix}execution_entity
|
|
DROP CONSTRAINT "FK_${tablePrefix}execution_entity_workflowId"`,
|
|
);
|
|
|
|
await queryRunner.query(
|
|
`ALTER TABLE ${tablePrefix}execution_entity
|
|
ALTER COLUMN "workflowId" TYPE TEXT`,
|
|
);
|
|
}
|
|
}
|