96 lines
3.2 KiB
MySQL
96 lines
3.2 KiB
MySQL
|
|
-- CreateEnum
|
||
|
|
CREATE TYPE "public"."UPDATE_STATUS" AS ENUM ('IN_PROGRESS', 'LIVE', 'DEPRECATED', 'ARCHIVED');
|
||
|
|
|
||
|
|
-- CreateTable
|
||
|
|
CREATE TABLE "public"."Post" (
|
||
|
|
"id" SERIAL NOT NULL,
|
||
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
||
|
|
"title" VARCHAR(255) NOT NULL,
|
||
|
|
"content" TEXT,
|
||
|
|
"published" BOOLEAN NOT NULL DEFAULT false,
|
||
|
|
"authorId" TEXT NOT NULL,
|
||
|
|
|
||
|
|
CONSTRAINT "Post_pkey" PRIMARY KEY ("id")
|
||
|
|
);
|
||
|
|
|
||
|
|
-- CreateTable
|
||
|
|
CREATE TABLE "public"."User" (
|
||
|
|
"id" TEXT NOT NULL,
|
||
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
||
|
|
"username" TEXT NOT NULL,
|
||
|
|
"password" TEXT NOT NULL,
|
||
|
|
|
||
|
|
CONSTRAINT "User_pkey" PRIMARY KEY ("id")
|
||
|
|
);
|
||
|
|
|
||
|
|
-- CreateTable
|
||
|
|
CREATE TABLE "public"."Product" (
|
||
|
|
"id" TEXT NOT NULL,
|
||
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
|
|
"name" TEXT NOT NULL,
|
||
|
|
"belongsToId" TEXT NOT NULL,
|
||
|
|
|
||
|
|
CONSTRAINT "Product_pkey" PRIMARY KEY ("id")
|
||
|
|
);
|
||
|
|
|
||
|
|
-- CreateTable
|
||
|
|
CREATE TABLE "public"."Update" (
|
||
|
|
"id" TEXT NOT NULL,
|
||
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
||
|
|
"title" VARCHAR(255) NOT NULL,
|
||
|
|
"body" TEXT NOT NULL,
|
||
|
|
"status" "public"."UPDATE_STATUS" NOT NULL DEFAULT 'IN_PROGRESS',
|
||
|
|
"version" TEXT,
|
||
|
|
"asset" TEXT NOT NULL,
|
||
|
|
"productId" TEXT NOT NULL,
|
||
|
|
|
||
|
|
CONSTRAINT "Update_pkey" PRIMARY KEY ("id")
|
||
|
|
);
|
||
|
|
|
||
|
|
-- CreateTable
|
||
|
|
CREATE TABLE "public"."UpdatePoint" (
|
||
|
|
"id" TEXT NOT NULL,
|
||
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
||
|
|
"name" VARCHAR(255) NOT NULL,
|
||
|
|
"description" TEXT NOT NULL,
|
||
|
|
"updateId" TEXT NOT NULL,
|
||
|
|
|
||
|
|
CONSTRAINT "UpdatePoint_pkey" PRIMARY KEY ("id")
|
||
|
|
);
|
||
|
|
|
||
|
|
-- CreateTable
|
||
|
|
CREATE TABLE "public"."_UpdateToUser" (
|
||
|
|
"A" TEXT NOT NULL,
|
||
|
|
"B" TEXT NOT NULL,
|
||
|
|
|
||
|
|
CONSTRAINT "_UpdateToUser_AB_pkey" PRIMARY KEY ("A","B")
|
||
|
|
);
|
||
|
|
|
||
|
|
-- CreateIndex
|
||
|
|
CREATE UNIQUE INDEX "User_username_key" ON "public"."User"("username");
|
||
|
|
|
||
|
|
-- CreateIndex
|
||
|
|
CREATE INDEX "_UpdateToUser_B_index" ON "public"."_UpdateToUser"("B");
|
||
|
|
|
||
|
|
-- AddForeignKey
|
||
|
|
ALTER TABLE "public"."Post" ADD CONSTRAINT "Post_authorId_fkey" FOREIGN KEY ("authorId") REFERENCES "public"."User"("id") ON DELETE RESTRICT ON UPDATE CASCADE;
|
||
|
|
|
||
|
|
-- AddForeignKey
|
||
|
|
ALTER TABLE "public"."Product" ADD CONSTRAINT "Product_belongsToId_fkey" FOREIGN KEY ("belongsToId") REFERENCES "public"."User"("id") ON DELETE RESTRICT ON UPDATE CASCADE;
|
||
|
|
|
||
|
|
-- AddForeignKey
|
||
|
|
ALTER TABLE "public"."Update" ADD CONSTRAINT "Update_productId_fkey" FOREIGN KEY ("productId") REFERENCES "public"."Product"("id") ON DELETE RESTRICT ON UPDATE CASCADE;
|
||
|
|
|
||
|
|
-- AddForeignKey
|
||
|
|
ALTER TABLE "public"."UpdatePoint" ADD CONSTRAINT "UpdatePoint_updateId_fkey" FOREIGN KEY ("updateId") REFERENCES "public"."Update"("id") ON DELETE RESTRICT ON UPDATE CASCADE;
|
||
|
|
|
||
|
|
-- AddForeignKey
|
||
|
|
ALTER TABLE "public"."_UpdateToUser" ADD CONSTRAINT "_UpdateToUser_A_fkey" FOREIGN KEY ("A") REFERENCES "public"."Update"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
||
|
|
|
||
|
|
-- AddForeignKey
|
||
|
|
ALTER TABLE "public"."_UpdateToUser" ADD CONSTRAINT "_UpdateToUser_B_fkey" FOREIGN KEY ("B") REFERENCES "public"."User"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|