Oracle数据库中外键的相关操作整理

 更新时间:2016年01月15日 17:41:00   作者:hbhe0316  
这篇文章主要介绍了Oracle数据库中外键的相关操作整理,包括对外键参照的主表记录进行删除的操作方法等,需要的朋友可以参考下

racle使用外键来限制子表中参考的字段值,要求子表中的数据必须在主表中存在。当主表的记录发生变化时导致外键参考唯一约束值发生了变化时,Oracle指定了三种动作:默认值(类似于restrict)、delete cascade和delete set null。(
1.创建父表并初始化数据

SQL> create table t_parent (parent_id int primary key, name varchar2(10));
Table created.
SQL> insert into t_parent values (1,'record1');
1 row created.
SQL> insert into t_parent values (2,'record2');
1 row created.
SQL> insert into t_parent values (3,'record3');
1 row created.
SQL> commit;
Commit complete.

2.创建三种类型的子表t_child1、t_child2和t_child3
(1)no action类别

SQL> create table t_child1 (child1_id int primary key, parent_id int);
Table created.
SQL> alter table t_child1 add constraint FK_t_child1 foreign key (parent_id) references t_parent (parent_id);
Table altered.
SQL> insert into t_child1 values (1,1);
1 row created.
SQL> commit;
Commit complete.

(2)cascade类型

SQL> create table t_child2 (child2_id int primary key, parent_id int);
Table created.
SQL> alter table t_child2 add constraint FK_t_child2 foreign key (parent_id) references t_parent (parent_id) on delete cascade;
Table altered.
SQL> insert into t_child2 values (2,2);
1 row created.
SQL> commit;
Commit complete.

(3)SET NULL类型

SQL> create table t_child3 (child2_id int primary key, parent_id int);
Table created.
SQL> alter table t_child3 add constraint FK_t_child3 foreign key (parent_id) references t_parent (parent_id) on delete set null;
Table altered.
SQL> insert into t_child3 values (3,3);
1 row created.
SQL> commit;
Commit complete.

3.确认主表和子表中的数据

SQL> select * from T_PARENT;
PARENT_ID NAME
---------- ----------
     1 record1
     2 record2
     3 record3
SQL> select * from T_CHILD1;
CHILD1_ID PARENT_ID
---------- ----------
     1     1
SQL> select * from T_CHILD2;
 CHILD2_ID PARENT_ID
---------- ----------
     2     2
SQL> select * from T_CHILD3;
 CHILD2_ID PARENT_ID
---------- ----------
     3     3



4.尝试对具有默认类型外键参照的主表记录进行删除

SQL> delete from T_PARENT where parent_id = 1;
delete from T_PARENT where parent_id = 1
*
ERROR at line 1:
ORA-02292: integrity constraint (HBHE.FK_T_CHILD1) violated - child record
found
SQL> select * from T_CHILD1;


 CHILD1_ID PARENT_ID
---------- ----------
     1     1

在此类型下,不允许删除操作

5.尝试对具有delete cascade类型外键参照的主表记录进行删除

SQL> delete from T_PARENT where parent_id = 2;
1 row deleted.
SQL> select * from T_CHILD2;
no rows selected

级联删除成功


6.尝试对具有delete set null类型外键参照的主表记录进行删除

SQL> delete from T_PARENT where parent_id = 3;


1 row deleted.

SQL> select * from T_CHILD3;


 CHILD2_ID PARENT_ID
---------- ----------
     3

  主表记录可以完成删除,子表中对应的内容被设置为NULL。

相关文章

  • Oracle merge合并更新函数实例详解

    Oracle merge合并更新函数实例详解

    这篇文章主要给大家介绍了关于Oracle merge合并更新函数的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-02-02
  • Oracle 生成未来三天的整点时间(步骤详解)

    Oracle 生成未来三天的整点时间(步骤详解)

    这篇文章主要介绍了Oracle 生成未来三天的整点时间,本文通过实例代码分步骤给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • oracle net manager 数据传输安全步骤详解

    oracle net manager 数据传输安全步骤详解

    oracle net manager来加密客户端与数据库之间或中间件与 数据库之间的网络传输数据。这篇文章主要介绍了oracle net manager 数据传输安全 ,需要的朋友可以参考下
    2018-09-09
  • Oracle RAC环境下的阻塞(blocking blocked)介绍和实例演示

    Oracle RAC环境下的阻塞(blocking blocked)介绍和实例演示

    这篇文章主要介绍了Oracle RAC环境下的阻塞(blocking blocked)介绍和实例演示本文提供了2个查询脚本,并给出实例演示那些session为阻塞者,哪些为被阻塞者,需要的朋友可以参考下
    2014-09-09
  • oracle临时表WITH AS用法详解

    oracle临时表WITH AS用法详解

    文章介绍了Oracle数据库中的临时表,包括会话级临时表和事务级临时表的区别,以及它们的创建和使用方法,会话级临时表数据仅在当前会话存在,而事务级临时表数据仅在当前事务有效,文中还提供了创建和插入数据的示例,并简要介绍了实际应用中的案例
    2024-11-11
  • oracle复习笔记之PL/SQL程序所要了解的知识点

    oracle复习笔记之PL/SQL程序所要了解的知识点

    本文主要是前篇文章的续篇,主要来复习PL/SQL的基本语法、记录类型、流程控制、游标的使用、异常处理机制、存储函数/存储过程、触发器。好记性不如烂笔头,古人诚不欺我~
    2014-08-08
  • Oracle表空间与权限的深入讲解

    Oracle表空间与权限的深入讲解

    Oracle表空间(tablespaces)是一个逻辑的概念,真正存放数据的是数据文件(data files),下面这篇文章主要给大家介绍了关于Oracle表空间与权限的相关资料,需要的朋友可以参考下
    2021-11-11
  • oracle误drop/update操作后的数据恢复测试

    oracle误drop/update操作后的数据恢复测试

    本人主要是对drop/update数据后,在允许有时间内进行数据恢复,操作性强,比较实用。不对理论进行讲诉,需要的朋友可以参考下
    2015-08-08
  • win10下oracle 11g安装图文教程

    win10下oracle 11g安装图文教程

    这篇文章主要为大家详细介绍了win10下oracle11g安装图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-10-10
  • oracle如何修改Blob类型数据,批量更新数据做字符替换

    oracle如何修改Blob类型数据,批量更新数据做字符替换

    这篇文章主要介绍了oracle如何修改Blob类型数据,批量更新数据做字符替换问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07

最新评论