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 = ?)

万事大吉!!!

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 浅析Spring基于注解的AOP

    浅析Spring基于注解的AOP

    Spring是一个广泛应用的框架,SpringAOP则是Spring提供的一个标准易用的aop框架,依托Spring的IOC容器,提供了极强的AOP扩展增强能力,对项目开发提供了极大地便利
    2022-11-11
  • Scala求和示例代码

    Scala求和示例代码

    这篇文章主要介绍了Scala求和示例代码,需要的朋友可以参考下
    2019-06-06
  • 如何在mapper文件中使用in("str1","str2")

    如何在mapper文件中使用in("str1","str2")

    这篇文章主要介绍了如何在mapper文件中使用in("str1","str2"),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • Java实现查找算法的示例代码(二分查找、插值查找、斐波那契查找)

    Java实现查找算法的示例代码(二分查找、插值查找、斐波那契查找)

    查找就是根据给定的某个值,在查找表中确定一个其关键字等于给定值的数据元素。本文介绍了常见的数据查找算法:顺序查找、二分查找、插值查找和斐波那契查找等以及相应的Java代码实现。需要的可以参考一下
    2022-01-01
  • Java利用随机分钱模拟财富变化

    Java利用随机分钱模拟财富变化

    这篇文章主要为大家详细介绍了Java如何利用随机分钱思想模拟财富的变化,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2022-12-12
  • Java Session会话追踪原理深入分析

    Java Session会话追踪原理深入分析

    web开发阶段我们主要是浏览器和服务器之间来进行交互。浏览器和服务器之间的交互就像人和人之间进行交流一样,但是对于机器来说,在一次请求之间只是会携带着本次请求的数据的,但是可能多次请求之间是会有联系的,所以提供了会话机制
    2022-11-11
  • java 将 list 字符串用逗号隔开拼接字符串的多种方法

    java 将 list 字符串用逗号隔开拼接字符串的多种方法

    这篇文章主要介绍了java 将 list 字符串用逗号隔开拼接字符串,本文给大家分享四种方法,每种方法通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-12-12
  • 一小时迅速入门Mybatis之实体类别名与多参数 动态SQL

    一小时迅速入门Mybatis之实体类别名与多参数 动态SQL

    这篇文章主要介绍了一小时迅速入门Mybatis之实体类别名与多参数 动态SQL,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-09-09
  • springboot 启动时初始化数据库的步骤

    springboot 启动时初始化数据库的步骤

    这篇文章主要介绍了springboot 启动时初始化数据库的步骤,帮助大家更好的理解和使用springboot框架,感兴趣的朋友可以了解下
    2021-01-01
  • Java对象的内存布局全流程

    Java对象的内存布局全流程

    这篇文章主要介绍了Java对象的内存布局全流程,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05

最新评论