最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Oracle级联操作

来源:动视网 责编:小采 时间:2020-11-09 10:50:53
文档

Oracle级联操作

Oracle级联操作:Oracle的级联操作是为了处理,在删除主表数据时,从表外键数据该怎么处理,有如下三种情况:SET NULL,CASCADE,NO ACTION。 Oracle的级联操作是为了处理,在删除主表数据时,从表外键数据该怎么处理,有如下三种情况: 1、SET NULL: 此关键字
推荐度:
导读Oracle级联操作:Oracle的级联操作是为了处理,在删除主表数据时,从表外键数据该怎么处理,有如下三种情况:SET NULL,CASCADE,NO ACTION。 Oracle的级联操作是为了处理,在删除主表数据时,从表外键数据该怎么处理,有如下三种情况: 1、SET NULL: 此关键字


Oracle的级联操作是为了处理,在删除主表数据时,从表外键数据该怎么处理,有如下三种情况:SET NULL,CASCADE,NO ACTION。

Oracle的级联操作是为了处理,在删除主表数据时,从表外键数据该怎么处理,有如下三种情况:

1、SET NULL:

此关键字用于表示当删除主表中被引用列的数据时,将子表中相应引用列的值设置为NULL值。这种情况要求子表中的引用列支持NULL值。

2、CASCADE:

此关键字用于表示当删除主表中被引用列的数据时,级联删除子表中相应的数据行。

3、NO ACTION:

约束后面省略ON DELETE的情况,,此关键字用于表示当删除主表中被引用列的数据时,如果子表的引用列中包含该值,则禁止该操作执行。

下面通过例子展示:

第一种情况:

--创建主表

SQL> create table father(

2 f_id number(10) primary key,

3 f_name varchar2(20)

4 );

表已创建。

--创建从表

SQL> create table child(
2 c_id number(10) primary key,
3 f_id number(10),
4 c_name varchar2(20),
5 constraint ch_fa foreign key (f_id) references father(f_id)
6 on delete set null
7 );

--插入数据

SQL> insert into father values (1,'cupid');

已创建 1 行。

SQL> insert into father values (2,'dorria');

已创建 1 行。

SQL> insert into child values (1,1,'jack');

已创建 1 行。

SQL> insert into child values (2,2,'rose');

已创建 1 行。

commit;

提交完成。

SQL> delete from father where f_id=1;

已删除 1 行。

SQL> commit;

提交完成。

SQL> select * from father;

F_ID F_NAME
---------- -------------------------------
2 dorria
SQL> select * from child;

C_ID F_ID C_NAME
---------- ---------- --------------------
1 jack
2 2 rose

第二种情况:

--创建主表

SQL> create table father_1(

2 f_id number(10) primary key,

3 f_name varchar2(20)

4 );

表已创建。

--创建从表

SQL> create table child_1(
2 c_id number(10) primary key,
3 f_id number(10),
4 c_name varchar2(20),
5 constraint ch_fa_1 foreign key (f_id) references father(f_id)
6 on delete cascade
7 );

--插入数据

SQL> insert into father_1 values (1,'cupid');

已创建 1 行。

SQL> insert into father_1 values (2,'dorria');

已创建 1 行。

SQL> insert into child_1 values (1,1,'jack');

已创建 1 行。

SQL> insert into child_1 values (2,2,'rose');

已创建 1 行。

commit;

提交完成。

SQL> delete from father where f_id=1;

已删除 1 行。

SQL> commit;

提交完成。

SQL> select * from father;

F_ID F_NAME
---------- -------------------------------
2 dorria
SQL> select * from child_1;

C_ID F_ID C_NAME
---------- ---------- --------------------
2 2 rose


第三种情况:

--创建主表

SQL> create table father_2(

2 f_id number(10) primary key,

3 f_name varchar2(20)

4 );

表已创建。

--创建从表

SQL> create table child_2(
2 c_id number(10) primary key,
3 f_id number(10),
4 c_name varchar2(20),
5 constraint ch_fa_2 foreign key (f_id) references father(f_id)
6 );

--插入数据

SQL> insert into father_2 values (1,'cupid');

已创建 1 行。

SQL> insert into father_2 values (2,'dorria');

已创建 1 行。

SQL> insert into child_2 values (1,1,'jack');

已创建 1 行。

SQL> insert into child_2 values (2,2,'rose');

已创建 1 行。

commit;

提交完成。

SQL> delete from father_2 where f_id=1;
delete from father_2 where f_id=1
*
第 1 行出现错误:
ORA-02292: 违反完整约束条件 (SCOTT.CH_FA_2) - 已找到子记录

文档

Oracle级联操作

Oracle级联操作:Oracle的级联操作是为了处理,在删除主表数据时,从表外键数据该怎么处理,有如下三种情况:SET NULL,CASCADE,NO ACTION。 Oracle的级联操作是为了处理,在删除主表数据时,从表外键数据该怎么处理,有如下三种情况: 1、SET NULL: 此关键字
推荐度:
标签: 操作 数据库 oracle
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top