SQL 保证评估为 false 的 IN 子句
SQL IN clause which is guaranteed to evaluate to false
我可以在 SQL IN 子句中放置任何值来保证该子句的计算结果为假吗?
SELECT *
FROM Products
WHERE ProductID IN (???)
有什么可以代替的吗???以保证不会返回任何行?
替换为NULL
。没有更好的保证!
因为没有其他值可以等于 NULL
,甚至 NULL
本身。
这对任何类型来说都是通用的值(正如@zohar-peled 提到的)。
输入一些最初无效的 ProductID,例如-1
.
SELECT *
FROM Products
WHERE ProductID IN (-1)
使用NULL
SELECT *
FROM Products
WHERE ProductID IN (NULL)
因为这将return什么都没有
尝试
SELECT *
FROM Products
WHERE ProductID IN (0)
我很确定您没有 ID=0 的产品
那将 return 错误。
SELECT *
FROM Products
WHERE ProductID IN (SELECT '')
另一种可能的方式。
我可以在 SQL IN 子句中放置任何值来保证该子句的计算结果为假吗?
SELECT *
FROM Products
WHERE ProductID IN (???)
有什么可以代替的吗???以保证不会返回任何行?
替换为NULL
。没有更好的保证!
因为没有其他值可以等于 NULL
,甚至 NULL
本身。
这对任何类型来说都是通用的值(正如@zohar-peled 提到的)。
输入一些最初无效的 ProductID,例如-1
.
SELECT *
FROM Products
WHERE ProductID IN (-1)
使用NULL
SELECT *
FROM Products
WHERE ProductID IN (NULL)
因为这将return什么都没有
尝试
SELECT *
FROM Products
WHERE ProductID IN (0)
我很确定您没有 ID=0 的产品
那将 return 错误。
SELECT *
FROM Products
WHERE ProductID IN (SELECT '')
另一种可能的方式。