oracle 建立外键 引用条件约束 不能添加,Oracle外键约束

  • Post author:
  • Post category:其他


一、创建外键约束

两种方法

1.创建表时

create table 子表(

id number,

name varchar2(5),

foreign key(id) references 父表(列名)

);

2.随时更改

alter table 子表 drop constraint 约束名;

alter table 子表 add constraint 约束名  foreing key(外键) conferences 父表(列名) ;

二、进一步理解

外键只接受两种值,一是父表中的外键值,二是NULL

创建外键时可以指定级联操作:

在添加外键约束时,还可以指定级联操作的类型,主要用于确定当删除父表中的一条记录时,如何处理子表中的外键字段。

1.CASCADE:删除父表中的被引用列的数据时,级联删除子表中相应的数据行

2.SET NULL:删除父表中的被引用列的数据时,将子表中相应引用列的值设置为NULL。要求子表中相应引用列支持NULL

3.NO ACTION:默认为此操作。删除父表中的被引用列的数据时,如果子表中的引用列中包含该值,则禁止该操作执行。(注意:执行delete 父表也不会报错,子表中的数据不会被删除)

注意:级联操作允许删除/更新多条数据!

三、实际例子

create table a_1 (id number);

create table b_1(id number, id_a_1 number);

alter table a_1 add constraint pk_a_1 primary key(id);

alter table b_1 add constraint fk_b_1 foreing key(id_a_1)  references a_1(id)   on delete cascade;

a_1表中增加数据:1,2

b_1表中增加数据:

11,1

1111,1

22,2

delete from a_1 where id=1;  执行delete语句后:

a_1表中删除一条数据,b_1表中删除两条数据。

说明:无论是cascade或是set null,都允许删除子表中多条相应的数据  或 将子表中多条相应的数据置为NULL

四、相关问题说明

1. 给b_1表中添加主键时,引用的a_1表中的字段必须为主键或唯一键。否则报ORA-02270:此列列表的唯一关键字或主键不匹配

2. 如果外键已经存在,再次添加相同外键的话,报ORA-02275:此表中已经存在这样的引用约束条件

3. 如果主键已经存在,再次添加相同主键的话,报ORA-02260:表只能具有一个主键

另外,即使添加外键的语句中声明级联操作为cascade,truncate语句执行依旧报ORA-02266

《ORA-02266 / 有外键依赖时truncate table》 https://blog.csdn.net/shafatutu/article/details/95898186