当前位置:  数据库>oracle

Oracle约束支持3种Delete的行为

    来源: 互联网  发布时间:2017-04-14

    本文导语: 1 建表 SQL> create table t_p (id number, name varchar2(30)); Table created SQL> alter table t_p add primary key (id); Table altered SQL> create table t_c (id number, fid number, name varchar2(30)); Table created SQL> alter table t_c add constraint fk_t_c foreign key(fid) references t_p(id); Table ...

1 建表

SQL> create table t_p (id number, name varchar2(30));

Table created

SQL> alter table t_p add primary key (id);

Table altered

SQL> create table t_c (id number, fid number, name varchar2(30));

Table created

SQL> alter table t_c add constraint fk_t_c foreign key(fid) references t_p(id);

Table altered

SQL> insert into t_p values (1, 'a');

1 row inserted

SQL> insert into t_p values (2, 'b');

1 row inserted

SQL> insert into t_c values (1, 1, 'a');

1 row inserted

SQL> commit;

Commit complete

 

2 on delete no action

SQL> delete t_p where id = 1;

delete t_p where id = 1

ORA-02292: 违反完整约束条件 (MYHR.FK_T_C) - 已找到子记录

SQL> UPDATE T_P SET ID = 3 WHERE ID = 1;

UPDATE T_P SET ID = 3 WHERE ID = 1

ORA-02292: 违反完整约束条件 (MYHR.FK_T_C) - 已找到子记录

3 on delete set null

SQL> alter table t_c drop constraint fk_t_c;

Table altered

SQL> alter table t_c add constraint fk_t_c foreign key (fid) references t_p (id) on delete set null;

Table altered

SQL> delete t_p where id = 1;

1 row deleted

SQL> commit;

Commit complete

SQL> select * from t_p;

        ID NAME

---------- ------------------------------

         2 b

 

SQL> select * from t_c;

        ID        FID NAME

---------- ---------- ------------------------------

         1            a

方格内为空

4 on delete cascade

SQL> alter table t_c drop constraint fk_t_c;

Table altered

SQL> alter table t_c add constraint fk_t_c foreign key (fid) references t_p (id) on delete cascade;

Table altered

SQL> delete t_p where id = 1;

1 row deleted

SQL> select * from t_p;

        ID NAME

---------- ------------------------------

         2 b

SQL> select * from t_c;

        ID        FID NAME

---------- ---------- ------------------------------

 

记录被级联删除


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle支持Linux的哪些发布版本
  • Oracle终于涉入支持Linux操作系统了
  • Oracle自动存储管理支持库 ASMLib
  • Oracle该支持NetBeans还是JDeveloper
  • Oracle 9i DataBase 支持 P4 吗?
  • oracle对debian的支持怎么样?
  • 红帽Linux表示Oracle提供Linux支持是不完美的
  • oracle8.1.7在RedHat7.2下安装后,怎么不支持中文?
  • 听ORACLE网站上说8.1.6有支持jdbc2.0的JAVA2驱动
  • 初用Linux,请问各位大侠,哪一款Linux支持Oracle9i
  • Oracle数据库EXP/IMP版本的支持列表集合[图文]
  • Oracle数据库表名支持的最大长度是多少
  • !!超级郁闷!!为什么我的Oracle 8.1.7安装完后没有Pro*C等支持?
  • 如何从Oracle技术支持获得更多
  • Oracle承诺继续支持Sparc和Solaris Sun老用户倍感鼓舞
  • php服务器环境搭建与oracle支持
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • Oracle 10g和Oracle 11g网格技术介绍
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍 iis7站长之家


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3