今天同学向我提了一个问题,我觉得蛮有意思,现记录下来大家探讨下。问题是:在一个表里面,有一个允许为空的字段,空是可以重复的,但是不为空的值需要唯一。
表结构如下面代码创建
以下为引用的内容: CREATE TABLE test_tb
( TestId int not null identity(1,1) primary key, Caption nvarchar(100) null ); GO |
解决方案1:
对于这个问题,大家的第一个想法可能是:在Caption这个字段上面加一个唯一键不就可以了吗?好,我们按着这个思路做下去,先创建唯一索引。
以下为引用的内容: CREATE UNIQUE NONCLUSTERED INDEX un_test_tb
ON test_tb(Caption) GO |
索引创建好了,我们来测试下效果
以下为引用的内容: INSERT INTO test_tb (Caption)
VALUES (null) GO INSERT INTO test_tb (Caption) VALUES (null) GO |
运行之后我们会收到下面的错误信息:
以下为引用的内容: 消息 2601,级别 14,状态 1,第 1 行
不能在具有唯一索引 'un_test_tb' 的对象 'dbo.test_tb' 中插入重复键的行。 语句已终止。 |
所以该解决方案是不行的。
解决方案2:
添加约束,让sql server在插入数据的时候,先验证下已有数据中是否有现在要插入的这个值。由于这个约束不是简单的一个运算,因此我们先创建一个函数,然后再在约束中调用这个函数。
创建验证逻辑函数:
查看所有0条评论>>