让mysql忽略where条件

2024-04-01

如果未设置变量,是否可以使 mysql 忽略条件,例如

SELECT *
FROM foo
WHERE id = $id
AND bar = $baz

如果 $baz 设置为正常运行查询,否则运行减去 AND 子句的查询?

Thanks


SELECT *
FROM foo
WHERE id = $id
AND ( bar = $baz OR $baz [equals null, empty string, zero, whatever] )

不知道MySQL有没有用过短路评估 http://en.wikipedia.org/wiki/Short-circuit_evaluation在其执行计划中,但将更便宜的比较放在第一位可能是有益的,例如:

SELECT *
FROM foo
WHERE id = $id
AND ( $baz [equals null, empty string, zero, whatever] OR bar = $baz )

您可以将此方法与多个参数结合使用。

SELECT *
FROM foo
WHERE id = $id
AND ( $baz [equals null, empty string, zero, whatever] OR bar = $baz )
AND ( $x = 0 or x = $x )
AND ( $y IS NULL OR y = $y )

-- etc.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

让mysql忽略where条件 的相关文章

随机推荐