gpt4 book ai didi

sql-server - 有没有办法确保字段的内容是 NULL 或 UNIQUE

转载 作者:行者123 更新时间:2023-12-04 19:17:49 25 4
gpt4 key购买 nike

我有一个 SQL Server 2012 数据库。我的名为 REFERENCE 的表有一个名为 LOCATOR 的列。

我的用户正在输入数据,但有时他们会输入具有相同 LOCATOR 的两个不同行。如果 LOCATOR 不为 null ,有没有办法让我创建一个错误,出现?

最佳答案

这就是 UNIQUE 约束的作用(在大多数 DBMS 中),不允许 2 行在一列中具有相同的值 - 同时忽略 NULL 值。

问题在于,SQL-Server 实现的唯一约束与其他 DBMS 不同,并且当在列上定义唯一约束或索引时,不允许多行具有 NULL

解决方案是使用部分索引:

CREATE UNIQUE INDEX Locator_UQ                -- name of the index
ON Reference (Locator)
WHERE Locator IS NOT NULL ;

最小测试:SQL-Fiddle

关于sql-server - 有没有办法确保字段的内容是 NULL 或 UNIQUE,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19198594/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com