濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫 > 解析Oracle中多表級(jí)聯(lián)刪除的方法

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

熱門標(biāo)簽:美圖秀秀地圖標(biāo)注 外呼線路外顯本地號(hào)碼 百度地圖標(biāo)注素材 word地圖標(biāo)注方向 征服眼公司地圖標(biāo)注 人工智能地圖標(biāo)注自己能做嗎 開封智能外呼系統(tǒng)廠家 征服者火車站地圖標(biāo)注 阿爾巴尼亞地圖標(biāo)注app
表間的關(guān)系比較復(fù)雜,數(shù)據(jù)量又比較多,一個(gè)個(gè)刪絕對(duì)會(huì)出大問題。于是實(shí)驗(yàn)了幾種解決的辦法,現(xiàn)小結(jié)一下。

方法一:創(chuàng)建約束時(shí)設(shè)定級(jí)聯(lián)刪除
(但一般由于各種原因或出于各種考慮在創(chuàng)建數(shù)據(jù)庫時(shí)沒有設(shè)定級(jí)聯(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)建約束時(shí)沒有使用級(jí)聯(lián)刪除,在需要使用級(jí)聯(lián)刪除時(shí),刪除原來的外鍵約束,重建帶級(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語句:
復(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í)沒有級(jí)聯(lián)刪除)
(比較靈活,可以根據(jù)自己編寫的程序進(jìn)行,引用的不是唯一主鍵也可以)
(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ù)雜時(shí)才有效率上的優(yōu)勢,簡單的直接刪除來的更快)
如上例中,直接刪除
SQL語句:
復(fù)制代碼 代碼如下:

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

DELETE FROM "FG123"."ORDERCOMBINE"
WHERE FormerId ='1'
您可能感興趣的文章:
  • Oracle多表級(jí)聯(lián)更新詳解
  • Oracle中多表關(guān)聯(lián)批量插入批量更新與批量刪除操作
  • 關(guān)于Oracle多表連接,提高效率,性能優(yōu)化操作
  • Mysql、Oracle中常用的多表修改語句總結(jié)
  • Oracle多表查詢中間表的創(chuàng)建實(shí)例教程

標(biāo)簽:淮南 六安 泰安 孝感 海北 葫蘆島 酒泉 宜春

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《解析Oracle中多表級(jí)聯(lián)刪除的方法》,本文關(guān)鍵詞  解析,Oracle,中多,表級(jí),聯(lián),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《解析Oracle中多表級(jí)聯(lián)刪除的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于解析Oracle中多表級(jí)聯(lián)刪除的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    本溪市| 杭州市| 咸阳市| 富锦市| 鹤岗市| 庆安县| 吉林市| 财经| 隆昌县| 上蔡县| 大庆市| 来凤县| 铁岭县| 年辖:市辖区| 邵阳县| 宜兰县| 巨野县| 青铜峡市| 建德市| 神农架林区| 东城区| 张家口市| 海安县| 南安市| 和林格尔县| 鄂托克前旗| 泌阳县| 丹阳市| 巩留县| 田林县| 正阳县| 饶河县| 天柱县| 淅川县| 哈巴河县| 墨竹工卡县| 三穗县| 怀来县| 交城县| 临海市| 塔河县|