-- ⚠️ 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;