28 lines
1.4 KiB
SQL
28 lines
1.4 KiB
SQL
-- CreateTable
|
|
CREATE TABLE "InventoryTransaction" (
|
|
"id" TEXT NOT NULL PRIMARY KEY,
|
|
"itemId" TEXT NOT NULL,
|
|
"warehouseId" TEXT NOT NULL,
|
|
"locationId" TEXT NOT NULL,
|
|
"transactionType" TEXT NOT NULL,
|
|
"quantity" INTEGER NOT NULL,
|
|
"reference" TEXT NOT NULL,
|
|
"notes" TEXT NOT NULL,
|
|
"createdById" TEXT,
|
|
"createdAt" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
"updatedAt" DATETIME NOT NULL,
|
|
CONSTRAINT "InventoryTransaction_itemId_fkey" FOREIGN KEY ("itemId") REFERENCES "InventoryItem" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
|
CONSTRAINT "InventoryTransaction_warehouseId_fkey" FOREIGN KEY ("warehouseId") REFERENCES "Warehouse" ("id") ON DELETE RESTRICT ON UPDATE CASCADE,
|
|
CONSTRAINT "InventoryTransaction_locationId_fkey" FOREIGN KEY ("locationId") REFERENCES "WarehouseLocation" ("id") ON DELETE RESTRICT ON UPDATE CASCADE,
|
|
CONSTRAINT "InventoryTransaction_createdById_fkey" FOREIGN KEY ("createdById") REFERENCES "User" ("id") ON DELETE SET NULL ON UPDATE CASCADE
|
|
);
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "InventoryTransaction_itemId_createdAt_idx" ON "InventoryTransaction"("itemId", "createdAt");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "InventoryTransaction_warehouseId_createdAt_idx" ON "InventoryTransaction"("warehouseId", "createdAt");
|
|
|
|
-- CreateIndex
|
|
CREATE INDEX "InventoryTransaction_locationId_createdAt_idx" ON "InventoryTransaction"("locationId", "createdAt");
|