解析Oracle中多表級聯(lián)刪除的方法
更新時間:2013年07月04日 09:55:18 作者:
創(chuàng)建數(shù)據(jù)庫時為了防止其他人不小心刪除操作錯誤, 所有的外鍵都沒有加級聯(lián)刪除。哪知,不知什么時候自己入了一批錯誤的數(shù)據(jù)進去,入庫使用的是軟件自動的,一下點錯給自己帶來無盡麻煩啊,刪除就不好辦了
表間的關(guān)系比較復(fù)雜,數(shù)據(jù)量又比較多,一個個刪絕對會出大問題。于是實驗了幾種解決的辦法,現(xiàn)小結(jié)一下。
方法一:創(chuàng)建約束時設(shè)定級聯(lián)刪除
(但一般由于各種原因或出于各種考慮在創(chuàng)建數(shù)據(jù)庫時沒有設(shè)定級聯(lián)刪除)
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)
方法二:創(chuàng)建約束時沒有使用級聯(lián)刪除,在需要使用級聯(lián)刪除時,刪除原來的外鍵約束,重建帶級聯(lián)刪除的約束
(實驗證明完全可行,注意需要對已經(jīng)存在的數(shù)據(jù)進行驗證,否則新建的約束對原有數(shù)據(jù)不具備效率,默認(rèn)是驗證的,若強制要求不驗證,使用NOVALIDATE關(guān)鍵詞。還有外鍵引用的只能是唯一主鍵)
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)
(這樣就可以級聯(lián)刪除了,刪除完后,如果不放心這樣的約束條件,并且不嫌麻煩可以再重建為不帶級聯(lián)刪除等外鍵約束,防止誤操作)
方法三:使用觸發(fā)器(創(chuàng)建時沒有級聯(lián)刪除)
(比較靈活,可以根據(jù)自己編寫的程序進行,引用的不是唯一主鍵也可以)
(1)創(chuàng)建表及插入數(shù)據(jù)
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');
結(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)系簡單(就兩張表),涉及到的記錄也很少(總共就幾行記錄),直接刪除子表中的相關(guān)記錄,再刪除父表中的記錄即可。
(前面的方法在涉及數(shù)據(jù)量較大以及表間關(guān)系比較復(fù)雜時才有效率上的優(yōu)勢,簡單的直接刪除來的更快)
如上例中,直接刪除
SQL語句:
DELETE FROM "FG123"."ORDERCOMBINE"
WHERE VIPForm ='1';
DELETE FROM "FG123"."ORDERCOMBINE"
WHERE FormerId ='1'
方法一:創(chuàng)建約束時設(shè)定級聯(lián)刪除
(但一般由于各種原因或出于各種考慮在創(chuàng)建數(shù)據(jù)庫時沒有設(shè)定級聯(lián)刪除)
SQL語句:
復(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)建約束時沒有使用級聯(lián)刪除,在需要使用級聯(lián)刪除時,刪除原來的外鍵約束,重建帶級聯(lián)刪除的約束
(實驗證明完全可行,注意需要對已經(jīng)存在的數(shù)據(jù)進行驗證,否則新建的約束對原有數(shù)據(jù)不具備效率,默認(rèn)是驗證的,若強制要求不驗證,使用NOVALIDATE關(guān)鍵詞。還有外鍵引用的只能是唯一主鍵)
SQL語句:
復(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)
(這樣就可以級聯(lián)刪除了,刪除完后,如果不放心這樣的約束條件,并且不嫌麻煩可以再重建為不帶級聯(lián)刪除等外鍵約束,防止誤操作)
方法三:使用觸發(fā)器(創(chuàng)建時沒有級聯(lián)刪除)
(比較靈活,可以根據(jù)自己編寫的程序進行,引用的不是唯一主鍵也可以)
(1)創(chuàng)建表及插入數(shù)據(jù)
SQL語句:
復(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)系簡單(就兩張表),涉及到的記錄也很少(總共就幾行記錄),直接刪除子表中的相關(guān)記錄,再刪除父表中的記錄即可。
(前面的方法在涉及數(shù)據(jù)量較大以及表間關(guān)系比較復(fù)雜時才有效率上的優(yōu)勢,簡單的直接刪除來的更快)
如上例中,直接刪除
SQL語句:
復(fù)制代碼 代碼如下:
DELETE FROM "FG123"."ORDERCOMBINE"
WHERE VIPForm ='1';
DELETE FROM "FG123"."ORDERCOMBINE"
WHERE FormerId ='1'
相關(guān)文章
Oracle查詢最近幾天每小時歸檔日志產(chǎn)生數(shù)量的腳本寫法
這篇文章主要介紹了Oracle查詢最近幾天每小時歸檔日志產(chǎn)生數(shù)量的腳本寫法,需要的朋友可以參考下2017-07-07
解決maven不能下載oracle jdbc驅(qū)動的問題
這篇文章主要介紹了解決maven不能下載oracle jdbc驅(qū)動的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04
Oracle BULK COLLECT批量取數(shù)據(jù)解決方法
在oracle使用中為了提高取數(shù)據(jù)效率,本文將詳細(xì)介紹Oracle BULK COLLECT批量取數(shù)據(jù),需要了解跟多的朋友可以參考下2012-11-11
Oracle Instant Client環(huán)境配置全過程
本文介紹了如何配置OracleInstantClient以便在沒有安裝Oracle的情況下使用Toad工具連接Oracle數(shù)據(jù)庫,詳細(xì)說明了從Oracle官網(wǎng)下載并選擇適當(dāng)版本的OracleInstantClient,配置環(huán)境變量如ORACLE_HOME、TNS_ADMIN、NLS_LANG2024-09-09
ORACLE 11g從 11.2.0.1升級到11.2.0.4 詳細(xì)實戰(zhàn)教程
這篇文章主要介紹了ORACLE 11g從 11.2.0.1升級到11.2.0.4 詳細(xì)實戰(zhàn)教程,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-03-03
Linux 創(chuàng)建oracle數(shù)據(jù)庫的詳細(xì)過程
這篇文章主要介紹了Linux 創(chuàng)建oracle數(shù)據(jù)庫,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03
oracle下實現(xiàn)恢復(fù)一個丟失的數(shù)據(jù)文件的代碼
2008-01-01
Oracle收購TimesTen 提高數(shù)據(jù)庫軟件性能
Oracle收購TimesTen 提高數(shù)據(jù)庫軟件性能...2007-03-03
一文教會你配置使用Navicat或PLSQL可視化工具遠(yuǎn)程連接Oracle
Navicat是一款數(shù)據(jù)庫管理工具,是一個可多重連線資料庫的管理工具,下面這篇文章主要給大家介紹了關(guān)于配置使用Navicat或PLSQL可視化工具遠(yuǎn)程連接Oracle的相關(guān)資料,需要的朋友可以參考下2023-04-04

