最近做测试总是遇到ORA-02291错误,经过查资料,对这个错误做了下了解。
请参阅以下
有外键FK约束的字段可以为空
1。创建测试表
SQL> create table lesson(lesson_name varchar2(20), cla***oom varchar2(10));
表已创建。
SQL> create table teacher(name varchar2(20),lesson_name varchar2(20));
表已创建。
SQL> alter table lesson add constraint pk_lesson primary key(lesson_name);
表已更改。
SQL> alter table teacher add constraint fk_lessonname foreign key(lesson_name)
2 references lesson(lesson_name);
表已更改。

2。插入测试数据
SQL> insert into lesson values(’english’,’class 1’);
已创建 1 行。
SQL> insert into lesson values(’music’,’class 2’);
已创建 1 行。

3。测试有外键的字段是否可以为空
SQL> insert into teacher values(’wang’,’hello’);
insert into teacher values(’wang’,’hello’)
*
ERROR 位于第 1 行:
ORA-02291: 违反完整约束条件 (SYSTEM.FK_LESSONNAME) - 未找到父项关键字
SQL> insert into teacher values(’wang’,’music’);
已创建 1 行。
SQL> insert into teacher values(’wang’,null);
已创建 1 行。

结论:有外键约束的字段可以为空。如果不为空的话,则一定要满足外键的约束关系

转载地址:http://www.examda.com/oracle/jishu/20071116/093542298.html