mybatis-plus QueryWrapper and or 连用并且实现分页
作者: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的多种用法小结