45 lines
1.6 KiB
SQL
45 lines
1.6 KiB
SQL
-- CreateEnum
|
|
CREATE TYPE "DealEventType" AS ENUM ('IMPRESSION', 'VIEW', 'CLICK');
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "DealAnalyticsTotal" (
|
|
"dealId" INTEGER NOT NULL,
|
|
"impressions" INTEGER NOT NULL DEFAULT 0,
|
|
"views" INTEGER NOT NULL DEFAULT 0,
|
|
"clicks" INTEGER NOT NULL DEFAULT 0,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" TIMESTAMP(3) NOT NULL,
|
|
|
|
CONSTRAINT "DealAnalyticsTotal_pkey" PRIMARY KEY ("dealId")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "DealEvent" (
|
|
"id" SERIAL NOT NULL,
|
|
"dealId" INTEGER NOT NULL,
|
|
"type" "DealEventType" NOT NULL,
|
|
"userId" INTEGER,
|
|
"ip" TEXT,
|
|
"createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
|
|
CONSTRAINT "DealEvent_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "DealAnalyticsTotal_updatedAt_idx" ON "DealAnalyticsTotal"("updatedAt");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "DealEvent_dealId_type_createdAt_idx" ON "DealEvent"("dealId", "type", "createdAt");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "DealEvent_userId_createdAt_idx" ON "DealEvent"("userId", "createdAt");
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "DealAnalyticsTotal" ADD CONSTRAINT "DealAnalyticsTotal_dealId_fkey" FOREIGN KEY ("dealId") REFERENCES "Deal"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "DealEvent" ADD CONSTRAINT "DealEvent_dealId_fkey" FOREIGN KEY ("dealId") REFERENCES "Deal"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "DealEvent" ADD CONSTRAINT "DealEvent_userId_fkey" FOREIGN KEY ("userId") REFERENCES "User"("id") ON DELETE SET NULL ON UPDATE CASCADE;
|