欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解析Oracle中多表級(jí)聯(lián)刪除的方法

 更新時(shí)間:2013年07月04日 09:55:18   作者:  
創(chuàng)建數(shù)據(jù)庫(kù)時(shí)為了防止其他人不小心刪除操作錯(cuò)誤, 所有的外鍵都沒(méi)有加級(jí)聯(lián)刪除。哪知,不知什么時(shí)候自己入了一批錯(cuò)誤的數(shù)據(jù)進(jìn)去,入庫(kù)使用的是軟件自動(dòng)的,一下點(diǎn)錯(cuò)給自己帶來(lái)無(wú)盡麻煩啊,刪除就不好辦了
表間的關(guān)系比較復(fù)雜,數(shù)據(jù)量又比較多,一個(gè)個(gè)刪絕對(duì)會(huì)出大問(wèn)題。于是實(shí)驗(yàn)了幾種解決的辦法,現(xiàn)小結(jié)一下。

方法一:創(chuàng)建約束時(shí)設(shè)定級(jí)聯(lián)刪除
(但一般由于各種原因或出于各種考慮在創(chuàng)建數(shù)據(jù)庫(kù)時(shí)沒(méi)有設(shè)定級(jí)聯(lián)刪除)
SQL語(yǔ)句:
復(fù)制代碼 代碼如下:

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)

方法二:創(chuàng)建約束時(shí)沒(méi)有使用級(jí)聯(lián)刪除,在需要使用級(jí)聯(lián)刪除時(shí),刪除原來(lái)的外鍵約束,重建帶級(jí)聯(lián)刪除的約束
(實(shí)驗(yàn)證明完全可行,注意需要對(duì)已經(jīng)存在的數(shù)據(jù)進(jìn)行驗(yàn)證,否則新建的約束對(duì)原有數(shù)據(jù)不具備效率,默認(rèn)是驗(yàn)證的,若強(qiáng)制要求不驗(yàn)證,使用NOVALIDATE關(guān)鍵詞。還有外鍵引用的只能是唯一主鍵)
SQL語(yǔ)句:
復(fù)制代碼 代碼如下:

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)
(這樣就可以級(jí)聯(lián)刪除了,刪除完后,如果不放心這樣的約束條件,并且不嫌麻煩可以再重建為不帶級(jí)聯(lián)刪除等外鍵約束,防止誤操作)

方法三:使用觸發(fā)器(創(chuàng)建時(shí)沒(méi)有級(jí)聯(lián)刪除)
(比較靈活,可以根據(jù)自己編寫(xiě)的程序進(jìn)行,引用的不是唯一主鍵也可以)
(1)創(chuàng)建表及插入數(shù)據(jù)
SQL語(yǔ)句:
復(fù)制代碼 代碼如下:

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');

結(jié)果:
(2)創(chuàng)建觸發(fā)器:
SQL:
復(fù)制代碼 代碼如下:

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)刪除及結(jié)果:
SQL:
復(fù)制代碼 代碼如下:

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

方法四:若表間關(guān)系簡(jiǎn)單(就兩張表),涉及到的記錄也很少(總共就幾行記錄),直接刪除子表中的相關(guān)記錄,再刪除父表中的記錄即可。
(前面的方法在涉及數(shù)據(jù)量較大以及表間關(guān)系比較復(fù)雜時(shí)才有效率上的優(yōu)勢(shì),簡(jiǎn)單的直接刪除來(lái)的更快)
如上例中,直接刪除
SQL語(yǔ)句:
復(fù)制代碼 代碼如下:

DELETE FROM "FG123"."ORDERCOMBINE"
WHERE VIPForm ='1';

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

相關(guān)文章

最新評(píng)論