问题:mysql where 1u003d0 混淆
在简单的 sql 书中,有部分代码提到如果我使用where 1 = 0,我可以安全地添加 OR 条件,例如:
WHERE 1=0 OR name LIKE '%Toledo%' OR billaddr LIKE '%Toledo%' OR shipaddr LIKE '%Toledo%'
我不明白为什么当我使用where 1 = 0时我可以安全地添加 OR 语句
我可以使用类似下面的东西吗?
WHERE 1=1 OR name LIKE '%Toledo%' OR billaddr LIKE '%Toledo%' OR shipaddr LIKE '%Toledo%'
我了解where 1=1是添加 And 语句的快捷方式。
我明白,因为where 1 =1将返回 true。我也可以将它用于Or语句吗?
我仍然没有得到零件where 1 = 0
任何解释都会很棒。
解答
这取决于您正在处理的布尔运算的类型。如果要添加可变数量的AND语句,则使用始终评估为 true 的语句,例如1 = 1。另一方面,如果你想对OR语句做同样的事情,那么你应该使用一个评估为假的语句,例如1 = 0。
假设您有一个布尔变量x,其真值不确定(它可能是真的,也可能是假的。你不知道。)现在,如果你找到x AND false的值,你会得到false,不管它是什么x的值为。
另一方面,如果你查看x OR true,你会得到true。同样,这与x的真值无关。
在您的语句中,您希望硬编码的值对查询的逻辑没有影响。由于false OR a OR b OR c在逻辑上等价于a OR b OR c,所以硬编码语句没有作用。在另一种情况下,true AND a AND b AND c等价于a AND b AND c。
本文探讨了MySQL查询中WHERE 1=0条件的使用,解释了为何在添加OR条件时可以安全使用,以及它与AND条件的区别。通过示例展示了1=0如何在布尔运算中作为恒真表达式,并解释了在不同情况下的逻辑效果。

被折叠的 条评论
为什么被折叠?



