解析Oracle中多表串聯刪除的方法

來源:互聯網
上載者:User

表間的關係比較複雜,資料量又比較多,一個個刪絕對會出大問題。於是實驗了幾種解決的辦法,現小結一下。

方法一:建立約束時設定串聯刪除
(但一般由於各種原因或出於各種考慮在建立資料庫時沒有設定串聯刪除)
SQL語句:
複製代碼 代碼如下:CREATE TABLE "U_WEN_BOOK"."FARTAB" ("FAR_ID" NUMBER(10) NOT NULL,
"FAR_NAME" VARCHAR2(10), "OTHER_NAME" VARCHAR2(10),
CONSTRAINT "PK_FER" PRIMARY KEY("FAR_ID"))

CREATE TABLE "U_WEN_BOOK"."CHILTAB" ("CHIL_ID" NUMBER(10) NOT
    NULL, "CHIL_NAME" VARCHAR2(10), "CHIL_OTHER" VARCHAR2(10),
    "FAR_ID" NUMBER(10) NOT NULL,
    CONSTRAINT "PK_CHIL" PRIMARY KEY("CHIL_ID"),
    CONSTRAINT "FK_CHIL" FOREIGN KEY("FAR_ID")
REFERENCES "U_WEN_BOOK"."FARTAB"("FAR_ID") ON DELETE CASCADE)

方法二:建立約束時沒有使用串聯刪除,在需要使用串聯刪除時,刪除原來的外鍵約束,重建帶串聯刪除的約束
(實驗證明完全可行,注意需要對已經存在的資料進行驗證,否則建立的約束對原有資料不具備效率,預設是驗證的,若強制要求不驗證,使用NOVALIDATE關鍵詞。還有外鍵引用的只能是唯一主鍵)
SQL語句:
複製代碼 代碼如下:ALTER TABLE "U_WEN_BOOK"."GCHILTAB1"
    DROP CONSTRAINT "FK_G1"
ALTER TABLE "U_WEN_BOOK"."GCHILTAB1"
  ADD (CONSTRAINT "FK_G1" FOREIGN KEY()
    REFERENCES "U_WEN_BOOK"."CHILTAB"()
    ON DELETE CASCADE)
(這樣就可以串聯刪除了,刪除完後,如果不放心這樣的約束條件,並且不嫌麻煩可以再重建為不帶串聯刪除等外鍵約束,防止誤操作)

方法三:使用觸發器(建立時沒有串聯刪除)
(比較靈活,可以根據自己編寫的程式進行,引用的不是唯一主鍵也可以)
(1)建立表及插入資料
SQL語句:
複製代碼 代碼如下:create   table orderCombine   (  
O_Id                     VARCHAR2(16)     not   null,  
OrderId           VARCHAR2(15)     not   null,                        
FormerId         VARCHAR2(16)     not   null,  
constraint   PK_ORDERCOMBINE   primary   key   (FormerId) );
   create   table   VIPForm     (  
V_Id                     VARCHAR2(16)       not   null,              
IsValid           CHAR(1)   default   '0'     not   null     ,                  
Constraint fk_vipform foreign key(V_id)   references   ordercombine(formerid) );  
insert into orderCombine values('1','1','1'); insert into orderCombine values('2','2','2'); insert into vipform values('1','5'); insert into vipform values('2','4'); insert into vipform values('1','2');

結果:
(2)建立觸發器:
SQL:
複製代碼 代碼如下:CREATE OR REPLACE TRIGGER "FG123"."TER_OV"
BEFORE
DELETE ON "ORDERCOMBINE" FOR EACH ROW
BEGIN
DELETE   FROM   VIPForm
WHERE   VIPForm.V_Id=:OLD.FormerId;
END;

(3)刪除及結果:
SQL:
複製代碼 代碼如下:DELETE FROM "FG123"."ORDERCOMBINE"
WHERE FormerId ='1'

方法四:若表間關係簡單(就兩張表),涉及到的記錄也很少(總共就幾行記錄),直接刪除子表中的相關記錄,再刪除父表中的記錄即可。
(前面的方法在涉及資料量較大以及表間關係比較複雜時才有效率上的優勢,簡單的直接刪除來的更快)
如上例中,直接刪除
SQL語句:
複製代碼 代碼如下:DELETE FROM "FG123"."ORDERCOMBINE"
WHERE VIPForm ='1';

DELETE FROM "FG123"."ORDERCOMBINE"
WHERE FormerId ='1'

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.