SQL IN 子句保证评估为假

Posted

技术标签:

【中文标题】SQL IN 子句保证评估为假【英文标题】:SQL IN clause which is guaranteed to evaluate to false 【发布时间】:2015-09-02 10:40:44 【问题描述】:

我可以在 SQL IN 子句中放置任何值来保证该子句的计算结果为假吗?

SELECT *
FROM Products
WHERE ProductID IN (???)

有什么可以代替的吗??? with 保证不会返回任何行?

【问题讨论】:

ProductID 是什么数据类型? 一个数值但不是整数,1.23? @Matt 假设它是一个整数 【参考方案1】:

替换为NULL。没有更好的保证!

因为没有其他值可以等于NULL,即使是NULL 本身。

这对于任何类型来说都是一种普遍的价值(正如@zohar-peled 提到的那样)。

【讨论】:

也有同样的想法。打败我 :) + 1 打败我! IN (NULL) 永远不会匹配,甚至不会匹配 NULL 比我快 1 秒 :-) 啊,为我禁食 :)! 感谢您的回答,NOT IN 也安全吗?【参考方案2】:

使用NULL

SELECT *
FROM Products
WHERE ProductID IN (NULL)

因为这不会返回任何内容

【讨论】:

【参考方案3】:
SELECT *
FROM Products
WHERE ProductID IN (SELECT '')

另一种可能的方式。

【讨论】:

SELECT '' 将被隐式转换为 0,我无法接受。【参考方案4】:

试试

SELECT *
FROM Products
WHERE ProductID IN (0)

我很确定您没有 ID=0 的产品

这将返回 false。

【讨论】:

【参考方案5】:

放入一些最初无效的 ProductID,例如-1.

SELECT *
FROM Products
WHERE ProductID IN (-1)

【讨论】:

以上是关于SQL IN 子句保证评估为假的主要内容,如果未能解决你的问题,请参考以下文章

评估 Oracle IN 子句中的多个范围

SQL 查询的 SELECT 子句中 Oracle PL/SQL 语句的延迟评估

SQL 编译错误:无法评估不受支持的子查询类型 - SELECT 子句中的函数调用

根据 WHERE IN 子句数据排序结果集

IN子句中的Spark sql限制

我们应该在检索数据时避免 DB2 SQL 中的 IN 子句吗?