From 5e3b75a36b2ed0cd1b35e7e93c9ef19869efdf6e Mon Sep 17 00:00:00 2001 From: cfngc4594 Date: Thu, 10 Apr 2025 22:26:45 +0800 Subject: [PATCH] feat(prisma): add submission table and related relations --- .../migration.sql | 37 +++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 prisma/migrations/20250410142543_add_submission_and_relations/migration.sql diff --git a/prisma/migrations/20250410142543_add_submission_and_relations/migration.sql b/prisma/migrations/20250410142543_add_submission_and_relations/migration.sql new file mode 100644 index 0000000..9cc665f --- /dev/null +++ b/prisma/migrations/20250410142543_add_submission_and_relations/migration.sql @@ -0,0 +1,37 @@ +/* + Warnings: + + - You are about to drop the `JudgeResult` table. If the table is not empty, all the data it contains will be lost. + +*/ +-- CreateEnum +CREATE TYPE "Status" AS ENUM ('PD', 'QD', 'CP', 'CE', 'CS', 'RU', 'TLE', 'MLE', 'RE', 'AC', 'WA', 'SE'); + +-- DropTable +DROP TABLE "JudgeResult"; + +-- DropEnum +DROP TYPE "ExitCode"; + +-- CreateTable +CREATE TABLE "Submission" ( + "id" TEXT NOT NULL, + "language" "EditorLanguage" NOT NULL, + "code" TEXT NOT NULL, + "status" "Status" NOT NULL, + "message" TEXT, + "executionTime" INTEGER, + "memoryUsage" INTEGER, + "userId" TEXT NOT NULL, + "problemId" TEXT NOT NULL, + "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, + "updatedAt" TIMESTAMP(3) NOT NULL, + + CONSTRAINT "Submission_pkey" PRIMARY KEY ("id") +); + +-- AddForeignKey +ALTER TABLE "Submission" ADD CONSTRAINT "Submission_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE CASCADE ON UPDATE CASCADE; + +-- AddForeignKey +ALTER TABLE "Submission" ADD CONSTRAINT "Submission_problemId_fkey" FOREIGN KEY ("problemId") REFERENCES "Problem"("id") ON DELETE CASCADE ON UPDATE CASCADE;