gpt4 book ai didi

sql - 结合 UNIQUE 和 CHECK 约束

转载 作者:行者123 更新时间:2023-12-04 22:01:39 26 4
gpt4 key购买 nike

我有一个包含 a b 和 c 列的表,如果 c 为假,那么我只想在 a 和 b 列是唯一的情况下允许插入,但如果 c 为真,则 a 和 b 不需要是唯一的。

例子:
表中只能有一个 (foo, bar, false),但对有多少 (foo, bar, true) 没有限制。

我尝试了类似 CONSTRAINT blah UNIQUE (a,b) AND CHECK (C is TRUE) 之类的东西,但我无法弄清楚正确的语法。

最佳答案

  • 创建一个带过滤器的返回 a 和 b 的索引 View WHERE C = false ,然后在 View 上创建唯一索引。这是一般方法
  • 如果您有 SQL Server 2008,则 create a unique filtered index相反
  • 存储过程
  • 触发(之前或之后)
  • 关于sql - 结合 UNIQUE 和 CHECK 约束,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2587151/

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