gpt4 book ai didi

sql - 在 postgresQL 中使用 OR 进行 CHECK CONSTRAINT

转载 作者:行者123 更新时间:2023-11-29 11:58:59 24 4
gpt4 key购买 nike

我想知道是否可以先评估 CHECK CONSTRAINT 中的某些条件,然后再与另一个表达式进行 OR。

我的情况:

4 表:\

  • main,它是一个 id,一个类型变量(让它成为 0-2 的 smallint),以及下表的外键:
  • a、b、c,只包含一个id

我想做一个基本上遵循以下逻辑的检查约束:

if main.type = 0:
main.a != NULL
main.b = NULL
main.c = NULL
elif main.type = 2:
main.a = NULL
main.b = NULL
main.c != NULL

如果type=1我不关心填什么

我试过像这样检查约束:

CHECK((main.type = 0 AND main.a != NULL AND main.b = NULL AND main.c = NULL) OR
(main.type = 2 AND main.a = NULL AND main.b = NULL AND main.c != NULL))

问题是在应用此约束后,内部括号会被删除/忽略,这意味着它变得毫无意义并且不起作用。

是否可以使用 CHECK CONSTRAINT 来解决这个问题,还是应该为此使用触发器?

最佳答案

!= NULL!那是行不通的。这似乎是你想要的逻辑:

CHECK ( (type = 0 and a is not null and b is null and c is null) or
(type = 2 and a is null and b is null and c is not null) or
(type = 1)
)

关于sql - 在 postgresQL 中使用 OR 进行 CHECK CONSTRAINT,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41872232/

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