mysql where 1u003d0 混淆

问题: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的值,你会得

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

全能资料库

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值