sql语句中where 1=1的作用

参考:https://blog.csdn.net/xcliang9418/article/details/79146114

where 1=1;有什么用?在SQL语言中,这个条件始终为True,写这一句话就跟没写一样。select * from table where 1=1与select * from table完全没有区别,其目的就是使 where 的条件永远为true,得到的结果就是未加约束条件的结果。

在查询条件数量不确定的条件情况下,使用 where 1=1可以很方便的规范语句。例如一个查询中可能有name,age,height,weight等不确定数量的约束条件,那么使用

<sql id="whereSQL">
    WHERE 1 = 1
    AND b = #{a.b}
    <if test="a.startDate != null">
      <![CDATA[
            AND `date` >= #{a.startDate}
            ]]>
    </if>
    <if test="a.endDate != null">
      <![CDATA[
            AND `date` <= #{a.endDate}
            ]]>
    </if>
  </sql>

总结:

  • 如果不写1=1,那么在每一个不为空的查询条件面前,都必须判断有没有where字句哪里该加where,哪里该加and/or
  • 如果用上 where 1=1 之后,就不存在这样的问题,条件是 and 就直接and,是or就直接接 or
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值