为了账号安全,请及时绑定邮箱和手机立即绑定

The INSERT

标签:
SQL Server

出现这个错误,是因为插入一个长度为0的值至有外键约束的字段内。

我们来做个实验,并尝试解决它。

首先创建两个表,[dbo].[T1]是主表,[dbo].[T2]是子表,而子表的[c2]是一个有外键约束的字段。

View Code

CREATE TABLE [dbo].[T1](    col1 NVARCHAR(20) PRIMARY KEY NOT NULL,    col2 NVARCHAR(30) NULL,    col3 NVARCHAR(30) NULL)GOCREATE TABLE [dbo].[T2](    c1 NVARCHAR(20) NOT NULL PRIMARY KEY,    c2 NVARCHAR(20) NULL FOREIGN KEY REFERENCES [dbo].[T1] ([col1]),    c3 NVARCHAR(30) NULL)GO


下面我们做实验,

我们再做一个实验:

 

什么情况?因为SQL有三值运算,TURE,FALSE 和UNKNOWN。约束其实是对满足条件,即条件表达式返回TRUE的一律通过。NULL在SQL SERVER里的类型是UNKNOWN,可以成理解为任何类型,可能为TRUE。而长度为 0的''空值,返回的将是False。

因此,我们在开SQL程序时,如果你的带有外键约束的字段,可以存储NULL值时,需要在插入的SQL语句做一些判断,就可以解决异常的出现。

 

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

举报

0/150
提交
取消