gpt4 book ai didi

mysql - 带 OR 和 AND < 1 的 SQL 语句

转载 作者:行者123 更新时间:2023-12-01 00:48:32 26 4
gpt4 key购买 nike

我正在尝试选择包含不完整数据的列的行。在这种情况下,不完整列的值小于 1。我试图找到至少有一个不完整列的行,但我不确定如何将其组合到 SQL 语句中。这是我一直在尝试但未成功的:

SELECT 
id
FROM
eval
WHERE
(month = :month) and (uid=:uid)
OR (rotation < 1)
OR (mr < 1)
OR (nc < 1)
OR (clinic_days < 1)
OR (clinic_pts < 1)
OR (mksap < 1)

此语句返回多行数据,因此语义一定不正确。没有括号我得到同样的东西。

最佳答案

在 SQL 中,AND 优先于 OR,就像乘法优先于加法一样,因此您需要使用括号来强制执行您想要的优先级:

SELECT id
FROM eval
WHERE (month = :month)
AND
(uid=:uid)
AND (
(rotation < 1)
OR (mr < 1)
OR (nc < 1)
OR (clinic_days < 1)
OR (clinic_pts < 1)
OR (mksap < 1)
)

您的原始语句将采用长长的 OR 链,并返回与其任何单独条件匹配的所有内容,以及具有需求的行 :uid:month

关于mysql - 带 OR 和 AND < 1 的 SQL 语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18500781/

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