mybatis-plus如何使用QueryWrapper和LambdaQueryWrapper的and方法?

2024-05-16 12:52

本文主要是介绍mybatis-plus如何使用QueryWrapper和LambdaQueryWrapper的and方法?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

构造器去构造条件的时候,我们都知道eq方法去链式的时候是自动添加and的,那如果需要and的那个条件需要加括号呢?

环境

Jdk 1.8、mybatis-plus 3.5.3.2、mysql 5.7.11

示例

sql:

select * from user where openid = 1 and (phone is not null or phone = '')

QueryWrapper:

QueryWrapper<user> wrapper = new QueryWrapper<>();
wrapper.eq("openid", openid.toString());
wrapper.and(tempWrapper -> tempWrapper.isNull("phone").or().eq("phone",""));
baseDao.selectList(wrapper);

LambdaQueryWrapper:

LambdaQueryWrapper<user> wrapper = new LambdaQueryWrapper<>();
wrapper.eq(user::getOpenId, openid.toString());
wrapper.and(tempWrapper ->tempWrapper.isNull(user::getPhone).or().eq(user::getPhone,""));
baseDao.selectList(wrapper);

总结

LambdaQueryWrapper 是 QueryWrapper 的一个变种,它使用 Java 的 lambda 表达式和实体类的属性名,而不是字段名的字符串,来指定条件。这样做的好处是类型安全,并且避免了因为字段名写错导致的错误。

上面例子中QueryWrapper 和LambdaQueryWrapper 的and方法分别是接收Consumer<QueryWrapper<User>> 类型和Consumer<LambdaQueryWrapper<User>> 类型的参数,实际上是一个lambda表达式,这个 lambda 表达式内部使用了 tempWrapper这个参数其实相当于是临时构造器来进行添加条件。

这篇关于mybatis-plus如何使用QueryWrapper和LambdaQueryWrapper的and方法?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/994967

相关文章

springboot3.4和mybatis plus的版本问题的解决

《springboot3.4和mybatisplus的版本问题的解决》本文主要介绍了springboot3.4和mybatisplus的版本问题的解决,主要由于SpringBoot3.4与MyBat... 报错1:spring-boot-starter/3.4.0/spring-boot-starter-

MySQL InnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据

《MySQLInnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据》mysql的ibdata文件被误删、被恶意修改,没有从库和备份数据的情况下的数据恢复,不能保证数据库所有表数据... 参考:mysql Innodb表空间卸载、迁移、装载的使用方法注意!此方法只适用于innodb_fi

mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespace id不一致处理

《mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespaceid不一致处理》文章描述了公司服务器断电后数据库故障的过程,作者通过查看错误日志、重新初始化数据目录、恢复备... 周末突然接到一位一年多没联系的妹妹打来电话,“刘哥,快来救救我”,我脑海瞬间冒出妙瓦底,电信火苲马扁.

Python中conda虚拟环境创建及使用小结

《Python中conda虚拟环境创建及使用小结》本文主要介绍了Python中conda虚拟环境创建及使用小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录0.前言1.Miniconda安装2.conda本地基本操作3.创建conda虚拟环境4.激活c

Spring中@Lazy注解的使用技巧与实例解析

《Spring中@Lazy注解的使用技巧与实例解析》@Lazy注解在Spring框架中用于延迟Bean的初始化,优化应用启动性能,它不仅适用于@Bean和@Component,还可以用于注入点,通过将... 目录一、@Lazy注解的作用(一)延迟Bean的初始化(二)与@Autowired结合使用二、实例解

SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)

《SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)》本文介绍了如何在SpringBoot项目中使用Jasypt对application.yml文件中的敏感信息(如数... 目录SpringBoot使用Jasypt对YML文件配置内容进行加密(例:数据库密码加密)前言一、J

Spring Boot 中正确地在异步线程中使用 HttpServletRequest的方法

《SpringBoot中正确地在异步线程中使用HttpServletRequest的方法》文章讨论了在SpringBoot中如何在异步线程中正确使用HttpServletRequest的问题,... 目录前言一、问题的来源:为什么异步线程中无法访问 HttpServletRequest?1. 请求上下文与线

在 Spring Boot 中使用异步线程时的 HttpServletRequest 复用问题记录

《在SpringBoot中使用异步线程时的HttpServletRequest复用问题记录》文章讨论了在SpringBoot中使用异步线程时,由于HttpServletRequest复用导致... 目录一、问题描述:异步线程操作导致请求复用时 Cookie 解析失败1. 场景背景2. 问题根源二、问题详细分

从零教你安装pytorch并在pycharm中使用

《从零教你安装pytorch并在pycharm中使用》本文详细介绍了如何使用Anaconda包管理工具创建虚拟环境,并安装CUDA加速平台和PyTorch库,同时在PyCharm中配置和使用PyTor... 目录背景介绍安装Anaconda安装CUDA安装pytorch报错解决——fbgemm.dll连接p

解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题

《解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题》在Spring开发中,@Autowired注解常用于实现依赖注入,它可以应用于类的属性、构造器或setter方法上,然... 目录1. 为什么 @Autowired 在属性上被警告?1.1 隐式依赖注入1.2 IDE 的警告: