mysql外键可以是空吗_外键可以为空吗?

展开全部

外键可以为空,但只允32313133353236313431303231363533e78988e69d8331333337613261许主键所包含的值和空值。

举例:

创建三张表:create table student

(sno char(5) primary key,

sname char(20) not null,

ssex char(3) not null,

sage integer not null,

sdept char(15));

create table course

(cno char(5) primary key,

cname char(20) not null unique,

cpno char(5),

ccredit integer);

create table sc

(sno char(5) constraint fk_student references student(sno),

cno char(5) constraint fk_course  references course(cno),

grade integer);

其中student和course都是主表,sc是副表,其中sno和cno分别为student中的sno和course中的cno的外键。

在主表中添加数据:insert into student values ('001','zs','男',11,'计算机系')

insert into course values ('001','C语言',null,3)

此时在副表中添加sno、cno为空的数据:insert into sc values (null,null,10)

结果是可以成功的:

382a6c5a76b882c01636ef06a5faa885.png

此时表中数据为:

21aecaae67b087e75b9b5d88f68e71d6.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值