gpt4 book ai didi

sql - SQL "IS"和 "="运算符有何不同?

转载 作者:IT王子 更新时间:2023-10-29 06:18:41 36 4
gpt4 key购买 nike

我正在构建一些使用参数化值的准备好的语句。例如:

SELECT * FROM "Foo" WHERE "Bar"=@param

有时 @param 可能是 NULL。在这种情况下,我希望查询返回 BarNULL 的记录,但上面的查询不会这样做。我了解到我可以为此使用 IS 运算符。换句话说:

SELECT * FROM "Foo" WHERE "Bar" IS @param

除了 NULL 的不同处理之外,上述两个语句的行为是否还有其他不同之处?如果 @param 不是 NULL,而是 5 怎么办?在那种情况下使用 IS 运算符是安全(和理智)的事情吗?我应该采取其他方法吗?

最佳答案

您需要来自 Foo 的记录,其中 Bar = @param,或者如果 @param 为空,则 Bar 为空。一些建议的解决方案将为您提供带有非空 @param 的空记录,这听起来不像您的要求。

Select * from Foo where (@param is null and Bar is null) or (Bar = @param)

这并没有说明这是 Oracle 还是 SQL Server 还是其他 RDBMS,因为它们各自实现的辅助函数略有不同。 SQL 的 ISNULL(first, second) 类似于 NVL(first, second)。我喜欢 SQL Server 的 COALESCE() 的普遍适用性。

IS 比较仅用于空值比较。

如果您使用的是 SQL Server 并且您确实需要一个不同的 3VL 逻辑真值表来解决您的问题(也就是说,如果您有特定的需要将“NULL=NULL”设为“true"在某个时间点,并且还认识到这已被弃用并且除非你有理由,一般来说这不是一个好主意),在你的代码块中你可以使用指令

关闭 ANSI_NULLS

这是上面的 BOL: http://msdn.microsoft.com/en-us/library/ms188048.aspx

关于sql - SQL "IS"和 "="运算符有何不同?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5423751/

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