Files
micro-service-api/@knowleadge/dbchange/alter new.txt
x2Skyz 351e348af1
All checks were successful
Build Docker Image / Build Docker Image (push) Successful in 1m19s
Build Docker Image / Restart Docker Compose (push) Successful in 1s
ระบบ uploads
2025-11-30 19:28:24 +07:00

63 lines
2.9 KiB
Plaintext

-- ⚠️ IMPORTANT: คำสั่ง ROLLBACK จะช่วยเคลียร์สถานะ "current transaction is aborted"
ROLLBACK;
BEGIN;
-- 1. ส่วนจัดการเปลี่ยนชื่อตารางและ Key (แบบปลอดภัย เช็คก่อนทำ)
DO $$
BEGIN
-- เช็ค: ถ้ามีตาราง 'prjmst' อยู่ และยังไม่มี 'prjmst_backup' ให้ทำการเปลี่ยนชื่อ (กรณีรันครั้งแรก)
IF EXISTS (SELECT FROM pg_tables WHERE schemaname = 'dbo' AND tablename = 'prjmst') THEN
IF NOT EXISTS (SELECT FROM pg_tables WHERE schemaname = 'dbo' AND tablename = 'prjmst_backup') THEN
ALTER TABLE dbo.prjmst RENAME TO prjmst_backup;
END IF;
END IF;
-- เช็ค: แก้ชื่อ Primary Key ในตาราง Backup ถ้ามันยังชื่อเดิม (แก้ปัญหา duplicate key name)
IF EXISTS (
SELECT 1 FROM pg_constraint con
JOIN pg_class rel ON rel.oid = con.conrelid
JOIN pg_namespace nsp ON nsp.oid = rel.relnamespace
WHERE nsp.nspname = 'dbo' AND rel.relname = 'prjmst_backup' AND con.conname = 'prjmst_pkey'
) THEN
ALTER TABLE dbo.prjmst_backup RENAME CONSTRAINT prjmst_pkey TO prjmst_backup_pkey;
END IF;
END $$;
-- 2. สร้างตารางใหม่ (New Structure)
-- ใช้ IF NOT EXISTS กัน Error ถ้ารันซ้ำ
CREATE TABLE IF NOT EXISTS dbo.prjmst
(
prjseq integer NOT NULL,
prjnam character varying(150) COLLATE pg_catalog."default" NOT NULL,
prjusrseq integer,
prjwntbdg numeric(14,2),
prjacpbdg numeric(14,2),
prjbdgcod character varying(3) COLLATE pg_catalog."default",
prjcomstt character varying(3) COLLATE pg_catalog."default",
-- ✅ แทรก Column ใหม่ตรงนี้
prjdoc character varying(255) COLLATE pg_catalog."default",
prjacpdtm character(12) COLLATE pg_catalog."default",
CONSTRAINT prjmst_pkey PRIMARY KEY (prjseq, prjnam)
)
TABLESPACE pg_default;
ALTER TABLE dbo.prjmst OWNER to postgres;
-- 3. ย้ายข้อมูลกลับมา (Data Migration)
-- เช็คก่อนว่าตารางใหม่ว่างอยู่ไหม ค่อย Insert
INSERT INTO dbo.prjmst (
prjseq, prjnam, prjusrseq, prjwntbdg, prjacpbdg, prjbdgcod, prjcomstt, prjacpdtm
)
SELECT
prjseq, prjnam, prjusrseq, prjwntbdg, prjacpbdg, prjbdgcod, prjcomstt, prjacpdtm
FROM dbo.prjmst_backup
WHERE NOT EXISTS (SELECT 1 FROM dbo.prjmst);
COMMIT;
-- หมายเหตุ: เมื่อตรวจสอบข้อมูลครบถ้วนแล้ว สามารถสั่งลบตาราง backup ได้:
-- DROP TABLE dbo.prjmst_backup;