SQL Server允许重复空字段不空值解决方法(1/2)

php中文网
发布: 2016-06-07 17:48:01
原创
1477人浏览过

解决方案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在插入数据的时候,先验证下已有数据中是否有现在要插入的这个值。由于这个约束不是简单的一个运算,因此我们先创建一个函数,然后再在约束中调用这个函数。
创建验证逻辑函数:
 代码如下:
create function [dbo].[fn_ck_test_tb_caption]()
returns bit
as
begin
if(exists(
select 1
from test_tb as a
where (caption is not null) and exists
(select 1 as expr1
from test_tb
where (caption is not null) and (caption = a.caption) and (a.testid testid))
))
return 0
return 1
end
go

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号