|
| 1 | +import { MigrationInterface, QueryRunner } from 'typeorm' |
| 2 | + |
| 3 | +export class AddChatHistory1694657778173 implements MigrationInterface { |
| 4 | + public async up(queryRunner: QueryRunner): Promise<void> { |
| 5 | + await queryRunner.query(`ALTER TABLE "chat_message" ADD COLUMN "chatId" VARCHAR;`) |
| 6 | + const results: { id: string; chatflowid: string }[] = await queryRunner.query(`WITH RankedMessages AS ( |
| 7 | + SELECT |
| 8 | + "chatflowid", |
| 9 | + "id", |
| 10 | + "createdDate", |
| 11 | + ROW_NUMBER() OVER (PARTITION BY "chatflowid" ORDER BY "createdDate") AS row_num |
| 12 | + FROM "chat_message" |
| 13 | + ) |
| 14 | + SELECT "chatflowid", "id" |
| 15 | + FROM RankedMessages |
| 16 | + WHERE row_num = 1;`) |
| 17 | + for (const chatMessage of results) { |
| 18 | + await queryRunner.query( |
| 19 | + `UPDATE "chat_message" SET "chatId" = '${chatMessage.id}' WHERE "chatflowid" = '${chatMessage.chatflowid}'` |
| 20 | + ) |
| 21 | + } |
| 22 | + await queryRunner.query( |
| 23 | + `CREATE TABLE "temp_chat_message" ("id" varchar PRIMARY KEY NOT NULL, "role" varchar NOT NULL, "chatflowid" varchar NOT NULL, "content" text NOT NULL, "sourceDocuments" text, "createdDate" datetime NOT NULL DEFAULT (datetime('now')), "chatType" VARCHAR NOT NULL DEFAULT 'INTERNAL', "chatId" VARCHAR NOT NULL, "memoryType" VARCHAR, "sessionId" VARCHAR);` |
| 24 | + ) |
| 25 | + await queryRunner.query( |
| 26 | + `INSERT INTO "temp_chat_message" ("id", "role", "chatflowid", "content", "sourceDocuments", "createdDate", "chatId") SELECT "id", "role", "chatflowid", "content", "sourceDocuments", "createdDate", "chatId" FROM "chat_message";` |
| 27 | + ) |
| 28 | + await queryRunner.query(`DROP TABLE "chat_message";`) |
| 29 | + await queryRunner.query(`ALTER TABLE "temp_chat_message" RENAME TO "chat_message";`) |
| 30 | + await queryRunner.query(`CREATE INDEX "IDX_e574527322272fd838f4f0f3d3" ON "chat_message" ("chatflowid") ;`) |
| 31 | + } |
| 32 | + |
| 33 | + public async down(queryRunner: QueryRunner): Promise<void> { |
| 34 | + await queryRunner.query(`DROP TABLE IF EXISTS "temp_chat_message";`) |
| 35 | + await queryRunner.query(`ALTER TABLE "chat_message" DROP COLUMN "chatType";`) |
| 36 | + await queryRunner.query(`ALTER TABLE "chat_message" DROP COLUMN "chatId";`) |
| 37 | + await queryRunner.query(`ALTER TABLE "chat_message" DROP COLUMN "memoryType";`) |
| 38 | + await queryRunner.query(`ALTER TABLE "chat_message" DROP COLUMN "sessionId";`) |
| 39 | + } |
| 40 | +} |
0 commit comments