mybatis-plus QueryWrapper and or 连用并且实现分页
更新时间:2022年01月11日 11:20:00 作者:Try and try again
这篇文章主要介绍了mybatis-plus QueryWrapper and or 连用并且实现分页,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
QueryWrapper and or 连用并分页
Page<TestEntity> rpage = baseMapper.selectPage( new Page<>(pageBean.getPageSize(), pageBean.getPageNum()), new QueryWrapper<TestEntity>() .eq("siteid", siteid) .and( wrapper -> wrapper .or() .lt("createtime", updatetime) .or() .lt("deletetime", updatetime) .or() .lt("operatetime", updatetime) .or() .lt("updatetime", updatetime)));
and or 拼完后的结果是这样的
new QueryWrapper<TestEntity>() .eq("siteid", siteid) .and( wrapper -> wrapper .or() .lt("createtime", updatetime) .or() .lt("deletetime", updatetime) .or() .lt("operatetime", updatetime) .or() .lt("updatetime", updatetime)))
SELECT * FROM t WHERE useflag = 1 AND ( siteid =? AND ( createtime < ? OR deletetime < ? OR operatetime < ? OR updatetime < ?))
使用or和and的问题
最近在使用MyBatis Plus,发现在拼接条件的时候,and和or会出问题
比如下面这种
QueryWrapper<User> userWrapper = new QueryWrapper<User>(); userWrapper.eq("name", name); userWrapper.eq("pwd", pwd).or().eq("phone", phone);
这种写法拼出来的SQL语句是这样的
select * from user where (name = ? and pwd= ? or phone = ?)
这样子是肯定不行的,于是去官网查询,发现正确的写法是这样的
QueryWrapper<User> userWrapper = new QueryWrapper<User>(); userWrapper.eq("name", name); userWrapper.and(wrapper -> wrapper.eq("pwd", pwd).or().eq("phone", phone)); select * from user where name = ? and ( pwd= ? or phone = ?)
万事大吉!!!
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
- mybatis-plus自带QueryWrapper自定义sql实现复杂查询实例详解
- Mybatis-plus动态条件查询QueryWrapper的使用案例
- MyBatis-Plus QueryWrapper及LambdaQueryWrapper的使用详解
- 基于mybatis-plus QueryWrapper 排序的坑
- mybatis-plus QueryWrapper 添加limit方式
- Mybatis-Plus 条件构造器 QueryWrapper 的基本用法
- MyBatis-Plus实现2种分页方法(QueryWrapper查询分页和SQL查询分页)
- mybatis-plus QueryWrapper自定义查询条件的实现
- Mybatis-plus中QueryWrapper的多种用法小结
相关文章
如何在mapper文件中使用in("str1","str2")
这篇文章主要介绍了如何在mapper文件中使用in("str1","str2"),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-01-01Java实现查找算法的示例代码(二分查找、插值查找、斐波那契查找)
查找就是根据给定的某个值,在查找表中确定一个其关键字等于给定值的数据元素。本文介绍了常见的数据查找算法:顺序查找、二分查找、插值查找和斐波那契查找等以及相应的Java代码实现。需要的可以参考一下2022-01-01java 将 list 字符串用逗号隔开拼接字符串的多种方法
这篇文章主要介绍了java 将 list 字符串用逗号隔开拼接字符串,本文给大家分享四种方法,每种方法通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-12-12一小时迅速入门Mybatis之实体类别名与多参数 动态SQL
这篇文章主要介绍了一小时迅速入门Mybatis之实体类别名与多参数 动态SQL,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-09-09
最新评论