111 lines
4.3 KiB
SQL
111 lines
4.3 KiB
SQL
-- CreateTable
|
|
CREATE TABLE "org_financial_profiles" (
|
|
"org_id" TEXT NOT NULL,
|
|
"default_currency" TEXT NOT NULL DEFAULT 'USD',
|
|
"machine_cost_per_min" DOUBLE PRECISION,
|
|
"operator_cost_per_min" DOUBLE PRECISION,
|
|
"rated_running_kw" DOUBLE PRECISION,
|
|
"idle_kw" DOUBLE PRECISION,
|
|
"kwh_rate" DOUBLE PRECISION,
|
|
"energy_multiplier" DOUBLE PRECISION NOT NULL DEFAULT 1.0,
|
|
"energy_cost_per_min" DOUBLE PRECISION,
|
|
"scrap_cost_per_unit" DOUBLE PRECISION,
|
|
"raw_material_cost_per_unit" DOUBLE PRECISION,
|
|
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" TIMESTAMP(3) NOT NULL,
|
|
"updated_by" TEXT,
|
|
|
|
CONSTRAINT "org_financial_profiles_pkey" PRIMARY KEY ("org_id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "location_financial_overrides" (
|
|
"id" TEXT NOT NULL,
|
|
"org_id" TEXT NOT NULL,
|
|
"location" TEXT NOT NULL,
|
|
"currency" TEXT,
|
|
"machine_cost_per_min" DOUBLE PRECISION,
|
|
"operator_cost_per_min" DOUBLE PRECISION,
|
|
"rated_running_kw" DOUBLE PRECISION,
|
|
"idle_kw" DOUBLE PRECISION,
|
|
"kwh_rate" DOUBLE PRECISION,
|
|
"energy_multiplier" DOUBLE PRECISION,
|
|
"energy_cost_per_min" DOUBLE PRECISION,
|
|
"scrap_cost_per_unit" DOUBLE PRECISION,
|
|
"raw_material_cost_per_unit" DOUBLE PRECISION,
|
|
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" TIMESTAMP(3) NOT NULL,
|
|
"updated_by" TEXT,
|
|
|
|
CONSTRAINT "location_financial_overrides_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "machine_financial_overrides" (
|
|
"id" TEXT NOT NULL,
|
|
"org_id" TEXT NOT NULL,
|
|
"machine_id" TEXT NOT NULL,
|
|
"currency" TEXT,
|
|
"machine_cost_per_min" DOUBLE PRECISION,
|
|
"operator_cost_per_min" DOUBLE PRECISION,
|
|
"rated_running_kw" DOUBLE PRECISION,
|
|
"idle_kw" DOUBLE PRECISION,
|
|
"kwh_rate" DOUBLE PRECISION,
|
|
"energy_multiplier" DOUBLE PRECISION,
|
|
"energy_cost_per_min" DOUBLE PRECISION,
|
|
"scrap_cost_per_unit" DOUBLE PRECISION,
|
|
"raw_material_cost_per_unit" DOUBLE PRECISION,
|
|
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" TIMESTAMP(3) NOT NULL,
|
|
"updated_by" TEXT,
|
|
|
|
CONSTRAINT "machine_financial_overrides_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateTable
|
|
CREATE TABLE "product_cost_overrides" (
|
|
"id" TEXT NOT NULL,
|
|
"org_id" TEXT NOT NULL,
|
|
"sku" TEXT NOT NULL,
|
|
"currency" TEXT,
|
|
"raw_material_cost_per_unit" DOUBLE PRECISION,
|
|
"created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updated_at" TIMESTAMP(3) NOT NULL,
|
|
"updated_by" TEXT,
|
|
|
|
CONSTRAINT "product_cost_overrides_pkey" PRIMARY KEY ("id")
|
|
);
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "location_financial_overrides_org_id_location_key" ON "location_financial_overrides"("org_id", "location");
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "machine_financial_overrides_org_id_machine_id_key" ON "machine_financial_overrides"("org_id", "machine_id");
|
|
|
|
-- CreateIndex
|
|
CREATE UNIQUE INDEX "product_cost_overrides_org_id_sku_key" ON "product_cost_overrides"("org_id", "sku");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "location_financial_overrides_org_id_idx" ON "location_financial_overrides"("org_id");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "machine_financial_overrides_org_id_idx" ON "machine_financial_overrides"("org_id");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "product_cost_overrides_org_id_idx" ON "product_cost_overrides"("org_id");
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "org_financial_profiles" ADD CONSTRAINT "org_financial_profiles_org_id_fkey" FOREIGN KEY ("org_id") REFERENCES "Org"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "location_financial_overrides" ADD CONSTRAINT "location_financial_overrides_org_id_fkey" FOREIGN KEY ("org_id") REFERENCES "Org"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "machine_financial_overrides" ADD CONSTRAINT "machine_financial_overrides_org_id_fkey" FOREIGN KEY ("org_id") REFERENCES "Org"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "machine_financial_overrides" ADD CONSTRAINT "machine_financial_overrides_machine_id_fkey" FOREIGN KEY ("machine_id") REFERENCES "Machine"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|
|
|
|
-- AddForeignKey
|
|
ALTER TABLE "product_cost_overrides" ADD CONSTRAINT "product_cost_overrides_org_id_fkey" FOREIGN KEY ("org_id") REFERENCES "Org"("id") ON DELETE CASCADE ON UPDATE CASCADE;
|