• 售前

  • 售后

热门帖子
入门百科

剖析Oracle中多表级联删除的方法

[复制链接]
无奈的剑侠站 显示全部楼层 发表于 2021-10-26 13:49:56 |阅读模式 打印 上一主题 下一主题
表间的关系比力复杂,数据量又比力多,一个个删绝对会出大题目。于是实验了几种办理的办法,现小结一下。

方法一:创建束缚时设定级联删除
(但一般由于各种缘故起因或出于各种考虑在创建数据库时没有设定级联删除)
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'

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作