外键可以为空

一、

关于数据库的外键,以前我一直以为不允许为空的,今天看到一个项目中使用了空的数据库外键,很惊讶,后来才发现是自己以前错误了。数据库外键是可以为空的。

不过为空的数据跟与之相关联的表就没有关系了。一般不采用。

二、

   按照数据库理论上说的应该是外键可以为空,为空表示其值还没有确定;如果不为空,刚必须为主键相同。举个例子:有两张表,系信息表,学生信息表,学生信息表中的系号为外键,此时外键可以为空,表示该学生还没有确定所在的系;如果系号不为空则系号必须在系信息表中存在!
外键不能为空只是SQLSERVER等一些数据库系统的特殊规则而已!

三、

外键可以为空的,一个表的关键的标识是主键,外键是否为空不影响表的结构及数据库设计概念的.外键只起个关联表的作用.
至于书上提到的外键不能为空是对的,但实践中在数据库里没有创建关联时,好像是外键,实则不是外键.

   虽然定义了关系
但是属于未强制关系,这种关系的外键约束被禁用。所以楼主定义无实际意义。所以可以插入null数据

   外键的值不允许参照相应主表中不存在的主键值,或者外键为空值.
不知道楼主怎么理解的这句话,我理解为外键可以为空
外键的值或者参照相应主表中存在的主键值,或者外键为空值

四、

联机丛书中准确的解释是

如果在 FOREIGN KEY 约束的列中输入非 NULL 值,则此值必须在被引用的列中存在,否则将返回违反外键约束的错误信息。

也就是说外键中可以有null,除非外键列定义了not null

五、

外键当然可以为空了
看看你引用的书上的话
"外键的值不允许参照相应主表中不存在的主键值,或者外键为空值. "
后面不是说了 "或者外键为空值 ",不就是说外键可以为空的吗
外键要有值的话必须是主表中存在的主键值,可不就是空值

外键可以为空值,但如果有值的话一定是你参照的那个主表中的主键值.
  • 6
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值