Mybatis动态语句,if test字符串不用进行null判断

3 月,跳不动了?>>> hot3.png

描述:根据creator列进行过滤获取image表的数据。

代码如下:

@Select("<script>" +
      " select * from image " +
      "  <where>" +
      "     <if test='isAllCreator != 1'> " +
      "        creator = 1 " +
      "     </if>" +
      "  </where>" +
      "</script>")
List<ImageVo> testDynamicSql(@Param("isAllCreator") String isAllCreator);

    想实现一个效果,针对参数isAllCreator参数,如果传递1则不过滤creator列,即获取所有creator的数据,如果不传或传其他值,则只获取creator=1的数据。
    经过测试发现,不用对creator参数进行null判断,直接判断是否等于1即可,这样做也不会报错。

@Test
public void testDynamicSql() {
   List<ImageVo> imageList = new ArrayList<>();
   imageList = mybatisTestMapper.testDynamicSql("0");
   imageList = mybatisTestMapper.testDynamicSql(null);
   imageList = mybatisTestMapper.testDynamicSql("1");
   Assert.assertNotNull(imageList);
}

打印的sql如下:

70f8d53e2535a9736af44228be8b080bb89.jpg

 

看网上的文章,都是先进行null判断,再进行相等判断,如果不是亲自试一下,我都怀疑自己写错了。

 

PS:源码找到了,如果isAllCreator参数传递null,在org.apache.ibatis.ognl.OgnlOps#equal方法中会返回false,表示if判断条件为false。

 

Refer:Mybatis官方文档 http://www.mybatis.org/mybatis-3/zh/dynamic-sql.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值