ระบบ uploads
This commit is contained in:
59
@knowleadge/dbchange/202511300710.txt
Normal file
59
@knowleadge/dbchange/202511300710.txt
Normal file
@@ -0,0 +1,59 @@
|
||||
-- ⚠️ PostgreSQL ไม่รองรับคำสั่ง AFTER ในการเพิ่ม Column
|
||||
-- จำเป็นต้องสร้างตารางใหม่เพื่อจัดเรียงลำดับ Column
|
||||
|
||||
BEGIN; -- เริ่ม Transaction (ถ้า Error ข้อมูลจะไม่เสียหาย)
|
||||
|
||||
-- 1. เปลี่ยนชื่อตารางเดิมเป็น Backup
|
||||
ALTER TABLE dbo.prjmst RENAME TO prjmst_backup;
|
||||
|
||||
-- 2. สร้างตารางใหม่โดยมี prjdoc อยู่ในตำแหน่งที่ต้องการ
|
||||
CREATE TABLE 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;
|
||||
|
||||
-- 3. กำหนด Owner (ถ้าจำเป็น)
|
||||
ALTER TABLE dbo.prjmst OWNER to postgres;
|
||||
|
||||
-- 4. ย้ายข้อมูลจากตาราง Backup มาใส่ตารางใหม่ (Map ข้อมูลให้ตรง Column)
|
||||
INSERT INTO dbo.prjmst (
|
||||
prjseq,
|
||||
prjnam,
|
||||
prjusrseq,
|
||||
prjwntbdg,
|
||||
prjacpbdg,
|
||||
prjbdgcod,
|
||||
prjcomstt,
|
||||
prjacpdtm
|
||||
-- prjdoc จะเป็น NULL อัตโนมัติสำหรับข้อมูลเก่า
|
||||
)
|
||||
SELECT
|
||||
prjseq,
|
||||
prjnam,
|
||||
prjusrseq,
|
||||
prjwntbdg,
|
||||
prjacpbdg,
|
||||
prjbdgcod,
|
||||
prjcomstt,
|
||||
prjacpdtm
|
||||
FROM prjmst_backup;
|
||||
|
||||
-- 5. ยืนยันการทำงาน
|
||||
COMMIT;
|
||||
|
||||
-- หมายเหตุ: หลังจากตรวจสอบข้อมูลแล้ว สามารถลบตาราง Backup ได้ด้วยคำสั่ง:
|
||||
-- DROP TABLE dbo.prjmst_backup;
|
||||
63
@knowleadge/dbchange/alter new.txt
Normal file
63
@knowleadge/dbchange/alter new.txt
Normal file
@@ -0,0 +1,63 @@
|
||||
-- ⚠️ 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;
|
||||
Reference in New Issue
Block a user