MyBatis-Plus 基础:LambdaQueryWrapper详解与实例

2024-01-01 15:52

本文主要是介绍MyBatis-Plus 基础:LambdaQueryWrapper详解与实例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

LambdaQueryWrapper 是 MyBatis-Plus(一个 MyBatis 的增强工具)中用于构造 SQL 查询条件的一个非常强大的工具。它允许你以 Lambda 表达式的方式构建查询条件,从而避免了硬编码字段名,提供了类型安全,并且使得代码更加清晰和易于维护。

以下是 LambdaQueryWrapper 的一些基本操作和使用示例:

  1. 初始化

首先,你需要初始化一个 LambdaQueryWrapper 对象:

LambdaQueryWrapper<User> queryWrapper = new LambdaQueryWrapper<>();

其中,User 是你的实体类。
2. 等于查询

使用 eq 方法进行等于查询:

queryWrapper.eq(User::getName, "John");

这将会生成 SQL 语句中的 name = 'John' 部分。
3. 模糊查询

使用 like 方法进行模糊查询:

queryWrapper.like(User::getName, "Jo");

这将会生成 SQL 语句中的 name LIKE '%Jo%' 部分。
4. 不等于查询

使用 ne 方法进行不等于查询:

queryWrapper.ne(User::getAge, 25);

这将会生成 SQL 语句中的 age <> 25 部分。
5. 大于、小于、大于等于、小于等于查询

使用 gt, lt, ge, le 方法进行范围查询:

queryWrapper.gt(User::getAge, 18);  // age > 18
queryWrapper.lt(User::getAge, 60);  // age < 60
queryWrapper.ge(User::getAge, 20);  // age >= 20
queryWrapper.le(User::getAge, 50);  // age <= 50
  1. 排序

使用 orderByAscorderByDesc 方法进行排序:

queryWrapper.orderByAsc(User::getAge);  // 按 age 升序排列
queryWrapper.orderByDesc(User::getName);  // 按 name 降序排列
  1. 自定义SQL

如果你需要自定义 SQL 片段,可以使用 apply 方法:

queryWrapper.apply("date_format(create_time, '%Y-%m-%d') = {0}", "2023-10-23");
  1. 选择字段

使用 select 方法选择需要查询的字段:

queryWrapper.select(User::getId, User::getName);  // 只查询 id 和 name 字段
  1. 逻辑操作
  • 使用 andor 进行逻辑与和逻辑或操作:
queryWrapper.eq(User::getType, 1).and(wrapper -> wrapper.gt(User::getAge, 18).lt(User::getAge, 60));  // type = 1 AND age > 18 AND age < 60
queryWrapper.eq(User::getType, 1).or().eq(User::getStatus, 1);  // type = 1 OR status = 1
  1. 查询
  • 最后,你可以将构造好的 LambdaQueryWrapper 对象传递给 MyBatis-Plus 的 Mapper 或 Service 方法进行查询:
List<User> users = userMapper.selectList(queryWrapper);  // 查询满足条件的用户列表

注意:以上代码示例是基于 MyBatis-Plus 的常见用法,但具体版本可能会有所不同,建议查阅你所使用的 MyBatis-Plus 版本的官方文档以获取最准确的信息。

这篇关于MyBatis-Plus 基础:LambdaQueryWrapper详解与实例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa

MySQL8 密码强度评估与配置详解

《MySQL8密码强度评估与配置详解》MySQL8默认启用密码强度插件,实施MEDIUM策略(长度8、含数字/字母/特殊字符),支持动态调整与配置文件设置,推荐使用STRONG策略并定期更新密码以提... 目录一、mysql 8 密码强度评估机制1.核心插件:validate_password2.密码策略级

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

从入门到精通详解Python虚拟环境完全指南

《从入门到精通详解Python虚拟环境完全指南》Python虚拟环境是一个独立的Python运行环境,它允许你为不同的项目创建隔离的Python环境,下面小编就来和大家详细介绍一下吧... 目录什么是python虚拟环境一、使用venv创建和管理虚拟环境1.1 创建虚拟环境1.2 激活虚拟环境1.3 验证虚

详解python pycharm与cmd中制表符不一样

《详解pythonpycharm与cmd中制表符不一样》本文主要介绍了pythonpycharm与cmd中制表符不一样,这个问题通常是因为PyCharm和命令行(CMD)使用的制表符(tab)的宽... 这个问题通常是因为PyCharm和命令行(CMD)使用的制表符(tab)的宽度不同导致的。在PyChar

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

SpringBoot请求参数传递与接收示例详解

《SpringBoot请求参数传递与接收示例详解》本文给大家介绍SpringBoot请求参数传递与接收示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录I. 基础参数传递i.查询参数(Query Parameters)ii.路径参数(Path Va

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队