解析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ǔ)句:
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ǔ)句:
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ǔ)句:
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:
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:
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ǔ)句:
DELETE FROM "FG123"."ORDERCOMBINE"
WHERE VIPForm ='1';
DELETE FROM "FG123"."ORDERCOMBINE"
WHERE FormerId ='1'
方法一:創(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)文章
oracle中對(duì)JSON數(shù)據(jù)處理的詳細(xì)指南
很多人對(duì)JSON不陌生,JSON(JavaScript Object Notation)是一種輕量級(jí)的數(shù)據(jù)交換格式,下面這篇文章主要給大家介紹了關(guān)于oracle中對(duì)JSON數(shù)據(jù)處理的詳細(xì)指南,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05
詳解Oracle調(diào)試存儲(chǔ)過(guò)程
這篇文章主要介紹了詳解Oracle調(diào)試存儲(chǔ)過(guò)程的相關(guān)資料,這里提供實(shí)例幫助大家學(xué)習(xí)理解這部分內(nèi)容,需要的朋友可以參考下2017-08-08
使用MySQL語(yǔ)句來(lái)查詢(xún)Apache服務(wù)器日志的方法
這篇文章主要介紹了使用MySQL語(yǔ)句來(lái)查詢(xún)Apache服務(wù)器日志的方法,五個(gè)實(shí)例均基于Linux系統(tǒng)進(jìn)行演示,需要的朋友可以參考下2015-06-06
Oracle中的Connect/session和process的區(qū)別及關(guān)系介紹
本文將詳細(xì)探討下Oracle中的Connect/session和process的區(qū)別及關(guān)系,感興趣的你可以參考下,希望可以幫助到你2013-03-03
Oracle查詢(xún)表空間大小及每個(gè)表所占空間的大小語(yǔ)句示例
Oracle表空間大小的查看方法應(yīng)該是我們都需要掌握的知識(shí),下面這篇文章主要給大家介紹了關(guān)于Oracle查詢(xún)表空間大小及每個(gè)表所占空間的大小語(yǔ)句的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-12-12
項(xiàng)目適?Oracle改造及SSL安全性配置問(wèn)題匯總詳解
這篇文章主要為大家介紹了項(xiàng)目適?Oracle改造及SSL安全性配置問(wèn)題匯總詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09

