好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 解析Oracle中多表級聯刪除的方法

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

熱門標簽:美圖秀秀地圖標注 外呼線路外顯本地號碼 百度地圖標注素材 word地圖標注方向 征服眼公司地圖標注 人工智能地圖標注自己能做嗎 開封智能外呼系統廠家 征服者火車站地圖標注 阿爾巴尼亞地圖標注app
表間的關系比較復雜,數據量又比較多,一個個刪絕對會出大問題。于是實驗了幾種解決的辦法,現小結一下。

方法一:創建約束時設定級聯刪除
(但一般由于各種原因或出于各種考慮在創建數據庫時沒有設定級聯刪除)
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'
您可能感興趣的文章:
  • Oracle多表級聯更新詳解
  • Oracle中多表關聯批量插入批量更新與批量刪除操作
  • 關于Oracle多表連接,提高效率,性能優化操作
  • Mysql、Oracle中常用的多表修改語句總結
  • Oracle多表查詢中間表的創建實例教程

標簽:淮南 六安 泰安 孝感 海北 葫蘆島 酒泉 宜春

巨人網絡通訊聲明:本文標題《解析Oracle中多表級聯刪除的方法》,本文關鍵詞  解析,Oracle,中多,表級,聯,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《解析Oracle中多表級聯刪除的方法》相關的同類信息!
  • 本頁收集關于解析Oracle中多表級聯刪除的方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 新郎逃婚后我和他的死对头闪婚了| 美女露出胸让男人亲| Chinese男男GayFuCK激情酒店| 成色视频| 我是看守专用宠物2| 国产chinese在线视频| 99久久伊人精品综合观看| 成人做爰黄70片免费| 肉屋十八里禁全本免费阅读| 国产日韩一区二区三区| 欧美一卡2卡三卡4卡国产免费| 欧美激情国产日韩精品一区18| 国产一级a毛一级a看免费视频黑人| 成人免费视频???我要手| 国产伦一区二区三区免费| 和田县| 一级毛片不卡免费看老司机| 欧美蜜桃臀XXOO色涩色| 国产精品欧美亚洲日本久久| 沉睡的泳装厨房篇cc漫画| 久久久这里有精品| 无遮挡吸奶头呻吟视频| 亚洲国产精品激情在线观看 | 巜交换做爰2H无删减金鱼妻| 日本暖暖视频在线播放| 涩综合| ?国产精品嫩草88影院17c| 成人午夜免费A片极品盛宴| 伦韩国理伦片在线现观看 | 91高清视频在线| 性欧美长视频免费观看不卡| 七月丁香婷婷| 国产精品1区2区3区在线观看| 777奇米狠狠色综合久色AⅤ网黑| 男女嘿咻嘿咻x0x0视频| 好吊色青青青国产欧美日韩| 激情性生活视频在线播放| 久久xx| 大尺度床戏无遮观看免费软件 | 又黄又湿无遮挡爆乳动漫视频| 中文在线无码高潮潮喷小说视频|