LambdaQueryWrapper与QueryWrapper的使用方式

 更新时间:2024年05月06日 16:20:46   作者:沙漠真有鱼  
这篇文章主要介绍了LambdaQueryWrapper与QueryWrapper的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

介绍

在Mybatis-plus框架中,LambdaQueryWrapper和QueryWrapper是两个非常常用的类。它们用于快速简便地查询数据库。

LambdaQueryWrapper是Mybatis-plus 3.0.7版本之后推出的一个查询工具类,它采用lambda表达式构建SQL查询语句,可以快速、简便地完成CRUD等操作。

QueryWrapper是Mybatis-plus 3.0.7版本之前推出的查询工具类,它的语法与LambdaQueryWrapper有所不同,如果你还停留在Mybatis-plus 3.0.7版本以前的版本中,那么你需要使用QueryWrapper。

在本篇文章中,将介绍LambdaQueryWrapper和QueryWrapper的使用方法,并提供详细的开发流程思路以及代码。

前置条件

在使用LambdaQueryWrapper和QueryWrapper之前,我们需要先引入Mybatis-plus框架。

你可以在pom.xml文件中添加以下依赖:

<!-- Mybatis-plus依赖 -->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.3.2</version>
</dependency>

如何使用

接下来,我们将分别介绍LambdaQueryWrapper与QueryWrapper的使用方法。

LambdaQueryWrapper的使用方法

LambdaQueryWrapper可以使用lambda表达式构建SQL查询语句,这让我们可以在不使用繁琐的SQL语句的情况下快速地进行数据库操作。

首先,我们需要在实体类中注解@Table和@Id,以指定表名和主键:

@Data
@TableName("user")
public class UserEntity {

    @TableId(type = IdType.AUTO)
    private Long id;

    private String name;

    private Integer age;

}

接下来,我们可以使用LambdaQueryWrapper来进行查询操作。

例如,我们希望查询年龄大于18岁且姓名为“张三”的用户信息:

LambdaQueryWrapper<UserEntity> qw = new LambdaQueryWrapper<UserEntity>()
        .eq(UserEntity::getName, "张三") // 姓名 = 张三
        .gt(UserEntity::getAge, 18); // 年龄 > 18

List<UserEntity> userList = userMapper.selectList(qw);

以上代码使用了LambdaQueryWrapper的eq和gt方法,它们分别表示等于和大于操作。

QueryWrapper的使用方法

QueryWrapper是Mybatis-plus 3.0.7版本之前推出的查询工具类。和LambdaQueryWrapper的使用方法不同,QueryWrapper需要使用SQL语句来构建查询条件。

如果你使用的是Mybatis-plus 3.0.7版本以前的版本,那么你需要使用QueryWrapper。

使用QueryWrapper进行查询操作的代码示例:

QueryWrapper<UserEntity> qw = new QueryWrapper<UserEntity>()
        .eq("name", "张三") // 姓名 = 张三
        .gt("age", 18); // 年龄 > 18

List<UserEntity> userList = userMapper.selectList(qw);

以上代码使用了QueryWrapper的eq和gt方法,它们分别表示等于和大于操作。

实践应用

在实际应用中,LambdaQueryWrapper和QueryWrapper常常被用于复杂的查询操作,甚至可以用于分页查询。

例如,我们可以使用LambdaQueryWrapper来实现带分页的查询操作:

IPage<UserEntity> page = new Page<>(1, 10); // 分页查询
LambdaQueryWrapper<UserEntity> qw = new LambdaQueryWrapper<UserEntity>()
        .eq(UserEntity::getName, "张三") // 姓名 = 张三
        .gt(UserEntity::getAge, 18); // 年龄 > 18

IPage<UserEntity> userPage = userMapper.selectPage(page, qw);

System.out.println(userPage.getRecords()); // 输出查询结果

以上代码中,我们使用了分页查询,并通过LambdaQueryWrapper实现了复杂的查询操作。

在实际应用中,我们还可以使用LambdaQueryWrapper和QueryWrapper实现更多复杂的查询操作,以满足不同的业务需求。

例如,我们可以使用LambdaQueryWrapper和QueryWrapper进行动态查询,通过判断前端传入的参数,来组合SQL语句,实现灵活的查询操作。

以下是代码示例:

public List<UserEntity> getUserList(String name, Integer age) {
    LambdaQueryWrapper<UserEntity> qw = new LambdaQueryWrapper<UserEntity>()
            .eq(StringUtils.isNotEmpty(name), UserEntity::getName, name) // 姓名 = name
            .gt(age != null, UserEntity::getAge, age); // 年龄 > age

    return userMapper.selectList(qw);
}

以上代码中,我们通过LambdaQueryWrapper实现了动态的查询操作。

如果传入的name参数不为空,那么就会添加一个等于查询条件;如果传入的age参数不为空,那么就会添加一个大于查询条件。

这样的查询操作,可以根据前端传入的参数,灵活地组合SQL语句,实现更多的业务需求。

总结

LambdaQueryWrapper和QueryWrapper是Mybatis-plus框架中常用的查询工具类,通过它们,我们可以在不使用繁琐的SQL语句的情况下,快速地进行数据库操作。

LambdaQueryWrapper使用lambda表达式构建SQL查询语句,QueryWrapper需要使用SQL语句来构建查询条件。

它们可以被用于复杂的查询操作,包括分页查询、动态查询等,在实际应用中具有非常广泛的应用场景。

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

相关文章

  • 使用idea开发Servlet详细图文教程

    使用idea开发Servlet详细图文教程

    这篇文章主要给大家介绍了关于使用idea开发Servlet的相关资料,将idea添加servlet的过程其实非常简单,只需要按照以下几个步骤即可完成,需要的朋友可以参考下
    2023-10-10
  • shiro拦截认证的全过程记录

    shiro拦截认证的全过程记录

    Apache Shiro是一个强大且易用的Java安全框架,执行身份验证、授权、密码和会话管理,下面这篇文章主要给大家介绍了关于shiro拦截认证的相关资料,需要的朋友可以参考下
    2021-11-11
  • 解析Java中如何获取Spring中配置的bean

    解析Java中如何获取Spring中配置的bean

    本篇文章是对在Java中如何获取Spring中配置的bean进行了详细的分析介绍,需要的朋友参考下
    2013-07-07
  • Java编写中容易搞错的一些东西

    Java编写中容易搞错的一些东西

    Java编写中容易搞错的一些东西...
    2006-12-12
  • Java中使用Socket发送Java对象实例

    Java中使用Socket发送Java对象实例

    这篇文章主要介绍了Java中使用Socket发送Java对象实例,本文使用对象流直接发送对象,本文同时给出代码实例,需要的朋友可以参考下
    2015-05-05
  • Java程序中Doc文档注释示例教程

    Java程序中Doc文档注释示例教程

    这篇文章主要为大家介绍了Java程序中Doc文档注释的示例教程,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2021-10-10
  • 教你怎么用Java开发扫雷游戏

    教你怎么用Java开发扫雷游戏

    我们那时候上机经常玩扫雷,试想如果我当年可以用 java 写个扫雷出来,那场面不用我多说了吧,大家让开,我要开始装逼了,之前用JavaScript写过了一个扫雷,这次我用java再写了一遍,权当是复习咯.文中有非常详细的代码示例,需要的朋友可以参考下
    2021-05-05
  • Java之Spring注解配置bean实例代码解析

    Java之Spring注解配置bean实例代码解析

    这篇文章主要介绍了Java之Spring注解配置bean实例代码解析,具有一定参考价值,文中还有有关Spring学习的资料下载链接及相关内容推荐,需要的朋友可以了解下。
    2017-09-09
  • SpringMVC HttpMessageConverter报文信息转换器

    SpringMVC HttpMessageConverter报文信息转换器

    ​​HttpMessageConverter​​​,报文信息转换器,将请求报文转换为Java对象,或将Java对象转换为响应报文。​​​HttpMessageConverter​​​提供了两个注解和两个类型:​​@RequestBody,@ResponseBody​​​,​​RequestEntity,ResponseEntity​​
    2023-01-01
  • Java实现SM3加密和验证的示例代码

    Java实现SM3加密和验证的示例代码

    在商用密码体系中,SM3主要用于数字签名及验证、消息认证码生成及验证、随机数生成等,其算法公开,本文给大家详细介绍了使用Java实现SM3加密和验证,文中有详细的代码示例供大家参考,需要的朋友可以参考下
    2023-12-12

最新评论