HotTRDealsBackend/prisma/migrations/20260131043221_add_analytics/migration.sql
2026-02-04 06:39:10 +00:00

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;