mirror of
https://gitlab.com/mbugroup/lti-api.git
synced 2026-05-20 13:31:56 +00:00
40 lines
1.6 KiB
SQL
40 lines
1.6 KiB
SQL
CREATE TABLE IF NOT EXISTS laying_kandang_transfers (
|
|
id BIGSERIAL PRIMARY KEY,
|
|
kandang_id BIGINT,
|
|
product_warehouse_id BIGINT,
|
|
qty NUMERIC(15,3),
|
|
laying_transfer_id BIGINT NOT NULL
|
|
);
|
|
|
|
-- FOREIGN KEYS (dijalankan setelah semua tabel parent ada)
|
|
DO $$
|
|
BEGIN
|
|
IF EXISTS (SELECT 1 FROM pg_tables WHERE tablename = 'kandangs') THEN
|
|
ALTER TABLE laying_kandang_transfers
|
|
ADD CONSTRAINT fk_laying_kandang_transfers_kandang
|
|
FOREIGN KEY (kandang_id)
|
|
REFERENCES kandangs(id)
|
|
ON DELETE RESTRICT ON UPDATE CASCADE;
|
|
END IF;
|
|
|
|
IF EXISTS (SELECT 1 FROM pg_tables WHERE tablename = 'product_warehouses') THEN
|
|
ALTER TABLE laying_kandang_transfers
|
|
ADD CONSTRAINT fk_laying_kandang_transfers_product_warehouse
|
|
FOREIGN KEY (product_warehouse_id)
|
|
REFERENCES product_warehouses(id)
|
|
ON DELETE RESTRICT ON UPDATE CASCADE;
|
|
END IF;
|
|
|
|
IF EXISTS (SELECT 1 FROM pg_tables WHERE tablename = 'laying_transfers') THEN
|
|
ALTER TABLE laying_kandang_transfers
|
|
ADD CONSTRAINT fk_laying_kandang_transfers_laying_transfer
|
|
FOREIGN KEY (laying_transfer_id)
|
|
REFERENCES laying_transfers(id)
|
|
ON DELETE RESTRICT ON UPDATE CASCADE;
|
|
END IF;
|
|
END $$;
|
|
|
|
-- INDEXES
|
|
CREATE INDEX IF NOT EXISTS idx_laying_kandang_transfers_kandang_id ON laying_kandang_transfers(kandang_id);
|
|
CREATE INDEX IF NOT EXISTS idx_laying_kandang_transfers_product_warehouse_id ON laying_kandang_transfers(product_warehouse_id);
|
|
CREATE INDEX IF NOT EXISTS idx_laying_kandang_transfers_laying_transfer_id ON laying_kandang_transfers(laying_transfer_id); |