1。创建测试表
SQL> create table lesson(lesson_name varchar2(20), classroom 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 行。
结论:有外键约束的字段可以为空。如果不为空的话,则一定要满足外键的约束关系