86 lines
2.7 KiB
SQL

-- CreateExtension
CREATE EXTENSION IF NOT EXISTS "postgis";
-- CreateTable
CREATE TABLE "grid_regions" (
"id" UUID NOT NULL,
"name" TEXT NOT NULL,
"code" TEXT NOT NULL,
"iso" TEXT NOT NULL,
"boundary" geography(MultiPolygon, 4326) NOT NULL,
"created_at" TIMESTAMPTZ NOT NULL DEFAULT CURRENT_TIMESTAMP,
CONSTRAINT "grid_regions_pkey" PRIMARY KEY ("id")
);
-- CreateTable
CREATE TABLE "datacenters" (
"id" UUID NOT NULL,
"name" TEXT NOT NULL,
"operator" TEXT NOT NULL,
"location" geography(Point, 4326) NOT NULL,
"capacity_mw" DOUBLE PRECISION NOT NULL,
"status" TEXT NOT NULL,
"year_opened" INTEGER NOT NULL,
"region_id" UUID NOT NULL,
"created_at" TIMESTAMPTZ NOT NULL DEFAULT CURRENT_TIMESTAMP,
CONSTRAINT "datacenters_pkey" PRIMARY KEY ("id")
);
-- CreateTable
CREATE TABLE "electricity_prices" (
"id" UUID NOT NULL,
"region_id" UUID NOT NULL,
"price_mwh" DOUBLE PRECISION NOT NULL,
"demand_mw" DOUBLE PRECISION NOT NULL,
"timestamp" TIMESTAMPTZ NOT NULL,
"source" TEXT NOT NULL,
CONSTRAINT "electricity_prices_pkey" PRIMARY KEY ("id")
);
-- CreateTable
CREATE TABLE "commodity_prices" (
"id" UUID NOT NULL,
"commodity" TEXT NOT NULL,
"price" DOUBLE PRECISION NOT NULL,
"unit" TEXT NOT NULL,
"timestamp" TIMESTAMPTZ NOT NULL,
"source" TEXT NOT NULL,
CONSTRAINT "commodity_prices_pkey" PRIMARY KEY ("id")
);
-- CreateTable
CREATE TABLE "generation_mix" (
"id" UUID NOT NULL,
"region_id" UUID NOT NULL,
"fuel_type" TEXT NOT NULL,
"generation_mw" DOUBLE PRECISION NOT NULL,
"timestamp" TIMESTAMPTZ NOT NULL,
CONSTRAINT "generation_mix_pkey" PRIMARY KEY ("id")
);
-- CreateIndex
CREATE UNIQUE INDEX "grid_regions_code_key" ON "grid_regions"("code");
-- CreateIndex
CREATE INDEX "electricity_prices_region_id_timestamp_idx" ON "electricity_prices"("region_id", "timestamp");
-- CreateIndex
CREATE INDEX "commodity_prices_commodity_timestamp_idx" ON "commodity_prices"("commodity", "timestamp");
-- CreateIndex
CREATE INDEX "generation_mix_region_id_timestamp_idx" ON "generation_mix"("region_id", "timestamp");
-- AddForeignKey
ALTER TABLE "datacenters" ADD CONSTRAINT "datacenters_region_id_fkey" FOREIGN KEY ("region_id") REFERENCES "grid_regions"("id") ON DELETE RESTRICT ON UPDATE CASCADE;
-- AddForeignKey
ALTER TABLE "electricity_prices" ADD CONSTRAINT "electricity_prices_region_id_fkey" FOREIGN KEY ("region_id") REFERENCES "grid_regions"("id") ON DELETE RESTRICT ON UPDATE CASCADE;
-- AddForeignKey
ALTER TABLE "generation_mix" ADD CONSTRAINT "generation_mix_region_id_fkey" FOREIGN KEY ("region_id") REFERENCES "grid_regions"("id") ON DELETE RESTRICT ON UPDATE CASCADE;