Mybatis-plus 查询条件为空不生效问题及解决
查询条件为空不生效
-- mybatis-plus eq方法 default Children eq(R column, Object val) { return this.eq(true, column, val); } public Children eq(boolean condition, R column, Object val) { return this.addCondition(condition, column, SqlKeyword.EQ, val); }
以上是mybatis-puls wrapper条件构造器 eq方法源码,由上可见,condition不传递值的时候,条件构造器默认填充的true。
因此,当我们传入的条件,不一定有值时,可以在condition入参位置进行判定,当入参为空或者自定义情况下,条件不生效,否则查询条件都是生效的,即使为空。
例:
wrapper.eq(StringUtil.isNotBlank(infoVO.getMobile()), MsPlatformInfo::getPhone, infoVO.getMobile());
当infoVO.getMobile()为空时,StringUtil.isNotBlank(infoVO.getMobile()) = false,这种情况下,此条件在sql执行时不生效
参数不生效
在使用mybatis-plus 传递参数一直不生效
打印sql 也是不显示该参数
springboot yml文件添加打印sql配置
mybatis-plus: configuration: log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #开启sql日志
最后搜到是del_flag参数类型错误!!!
由于传递的是Integer类型,但是在xml里面判断delFlag!=’’
只需要把 delFlag!=’’ 这个条件去掉就可以了
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Java Lambda表达式与匿名内部类的联系和区别实例分析
这篇文章主要介绍了Java Lambda表达式与匿名内部类的联系和区别,结合实例形式分析了Java Lambda表达式与匿名内部类功能、用法、区别及操作注意事项,需要的朋友可以参考下2019-10-10idea2020.1设置多个spring boot的service启动的实现
这篇文章主要介绍了idea2020.1设置多个spring boot的service启动,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-06-06
最新评论