mybatis-plus实现四种lambda表达式方式

 更新时间:2024年06月23日 11:18:13   作者:掌握月  
使用了lambda表达式 可以通过方法引用的方式来使用实体字段名的操作,本文主要介绍了mybatis-plus实现四种lambda表达式方式,具有一定的参考价值,感兴趣的可以了解一下

前言

使用了lambda表达式 可以通过方法引用的方式来使用实体字段名的操作,避免直接写数据库表字段名时的错写名字;

一、LambdaQueryWrapper<>

https://www.jb51.net/program/30498424p.htm

二、QueryWrapper<实体>().lambda()

 /**
  * 名字为王姓并且(年龄小于40并且邮箱不为空)
  * name like '王%' and (age <40 or email in not null)
  * 生成的sql语句 SELECT id,name,age,email,manager_id,create_time FROM user WHERE name LIKE ? AND age < ?
  */
 @Test
 public void selectLambda2() {
     LambdaQueryWrapper<User> lambda3 = Wrappers.<User>lambdaQuery();
     lambda3.likeRight(User::getName, "王").and(qw -> qw.lt(User::getAge, 40).or().isNotNull(User::getEmail));
 
     List<User> users = userMapper.selectList(lambda3);
     users.forEach(System.out::println);
 }

三、Wrappers.<实体>lambdaQuery()

/**
     * lambda 条件构造器
     * 生成的sql语句 SELECT id,name,age,email,manager_id,create_time FROM user WHERE name LIKE ? AND age < ?
     */
    @Test
    public void selectLambda() {
        //创建lambda 条件构造器 的三种方法
//        LambdaQueryWrapper<User> lambda2 = new LambdaQueryWrapper<>();
//        LambdaQueryWrapper<User> lambda = new QueryWrapper<User>().lambda();
        LambdaQueryWrapper<User> lambda3 = Wrappers.<User>lambdaQuery();
        lambda3.like(User::getName, "雨").lt(User::getAge, 40);
        List<User> users = userMapper.selectList(lambda3);
        users.forEach(System.out::println);


    }
/**
 * 名字为王姓并且(年龄小于40并且邮箱不为空)
 * name like '王%' and (age <40 or email in not null)
 * 生成的sql语句 SELECT id,name,age,email,manager_id,create_time FROM user WHERE name LIKE ? AND age < ?
 */
@Test
public void selectLambda2() {
    LambdaQueryWrapper<User> lambda3 = Wrappers.<User>lambdaQuery();
    lambda3.likeRight(User::getName, "王").and(qw -> qw.lt(User::getAge, 40).or().isNotNull(User::getEmail));

    List<User> users = userMapper.selectList(lambda3);
    users.forEach(System.out::println);


}
/**
 * 自定义sql 使用
 * Dao层  代码:
 *
 * @Select("select * from ${ew.customSqlSegment}")
 * List<User> selectAll(@Param(Constants.WRAPPER)Wrapper<User> wrapper);
 */
@Test
public void selectLambda4my() {
    LambdaQueryWrapper<User> lambda3 = Wrappers.<User>lambdaQuery();
    lambda3.likeRight(User::getName, "王").and(qw -> qw.lt(User::getAge, 40).or().isNotNull(User::getEmail));

    List<User> users = userMapper.selectAll(lambda3);
    users.forEach(System.out::println);


}

xml方式自定义sql 这里只是个单表演示application.yml 添加

mybatis-plus:  mapper-locations:    - com/mp/mapper/*

UserMapper 接口 添加方法

List<User> selectAll(@Param(Constants.WRAPPER) Wrapper<User> wrapper);IPage<User> selectUserPage(Page<User> page,@Param(Constants.WRAPPER)Wrapper<User> wrapper);

UserMpper.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.mp.dao.UserMapper">
    <select id="selectAll" resultType="com.mp.entity.User">
        select * from user ${ew.customSqlSegment}
    </select>

    <select id="selectUserPage" resultType="com.mp.entity.User">
        select * from user ${ew.customSqlSegment}
    </select>
</mapper>

四、LambdaQueryChainWrapper<实体>(xxxxMapper)

/**
 * lambda 条件构造器第四种创建方式 MP 3.0.7 新增的方式
 * 生成的sql语句 SELECT id,name,age,email,manager_id,create_time FROM user WHERE name LIKE ? AND age >= ?
 * 这个例子可以看出  代码更简洁了
 * 生成的sql语句 SELECT id,name,age,email,manager_id,create_time FROM user WHERE name LIKE ? AND age >= ?
 */
@Test
public void selectLambda3() {
    List<User> users = new LambdaQueryChainWrapper<User>(userMapper)
            .like(User::getName, "雨").ge(User::getAge, 20).list();

    users.forEach(System.out::println);
}

五、lambda在分页中的应用

MP的分页操作

baseMapper接口提供两种分页方法来实现物理分页(注:导包时导MP的包)第一个返回实体对象 允许null 第二个人返回map 对象多用于在指定放回字段时使用,避免为指定字段null值出现

IPage<T> selectPage(IPage<T> page, @Param("ew") Wrapper<T> queryWrapper);
IPage<Map<String, Object>> selectMapsPage(IPage<T> page, @Param("ew") Wrapper<T> queryWrapper);

使用MP的分页需要配置 类

package com.mp.configuration;

import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class MybatisPlusConfig {


    @Bean
    public PaginationInterceptor paginationInterceptor() {
        return new PaginationInterceptor();
    }
}
/**
 * 分页MP 分页插件 
 */
@Test
public void selectPage() {
    QueryWrapper<User> queryWrapper = new QueryWrapper<User>();
    queryWrapper.ge("age", 26);
    //后面参数false  表示不查询总记录数
    Page<User> userPage = new Page<>(1, 2, false);
  /*  IPage<User> iPage = userMapper.selectPage(userPage, queryWrapper);
    System.out.println("总页数"+iPage.getPages());
    System.out.println("总记录数"+iPage.getTotal());
    List<User> records = iPage.getRecords();
    records.forEach(System.out::println);
    */
    IPage<Map<String, Object>> iPage = userMapper.selectMapsPage(userPage, queryWrapper);
    System.out.println("总页数" + iPage.getPages());
    System.out.println("总记录数" + iPage.getTotal());
    List<Map<String, Object>> records = iPage.getRecords();

    records.forEach(System.out::println);

}

自定义分页

UserMapper接口

IPage<User> selectUserPage(Page<User> page,@Param(Constants.WRAPPER)Wrapper<User> wrapper);

UserMpper.xml 添加

<select id="selectUserPage" resultType="com.mp.entity.User">
    select * from user ${ew.customSqlSegment}
</select>
/**
 * 自定义分页方法
 */
@Test
public void selectMyPage() {
    QueryWrapper<User> queryWrapper = new QueryWrapper<User>();
    queryWrapper.ge("age", 26);
    //后面参数false  表示不查询总记录数
    Page<User> page = new Page<>(1, 2);

    IPage<User> iPage = userMapper.selectUserPage(page, queryWrapper);
    System.out.println("总页数" + iPage.getPages());
    System.out.println("总记录数" + iPage.getTotal());
    List<User> records = iPage.getRecords();
    records.forEach(System.out::println);
}

到此这篇关于mybatis-plus实现四种lambda表达式方式的文章就介绍到这了,更多相关mybatisplus lambda表达式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • Java静态方法不能调用非静态成员的原因分析

    Java静态方法不能调用非静态成员的原因分析

    在Java中,静态方法是属于类的方法,而不是属于对象的方法,它可以通过类名直接调用,无需创建对象实例,非静态成员指的是类的实例变量和实例方法,它们需要通过对象实例才能访问和调用,本文小编将和大家一起探讨Java静态方法为什么不能调用非静态成员
    2023-10-10
  • Java如何设置PDF文档背景色详解

    Java如何设置PDF文档背景色详解

    这篇文章主要介绍了Java如何设置PDF文档背景色详解,一般生成的PDF文档默认的文档底色为白色,我们可以通过一定方法来更改文档的背景色,以达到文档美化以及保护双眼的作用。 以下内容提供了Java编程来设置PDF背景色的方法,需要的朋友可以参考下
    2019-07-07
  • Java实现Word/Pdf/TXT转html的示例

    Java实现Word/Pdf/TXT转html的示例

    这篇文章主要介绍了Java实现Word/Pdf/TXT转html的示例,帮助大家方便的进行文件格式转换,完成需求,感兴趣的朋友可以了解下
    2020-11-11
  • SpringCloud @FeignClient注入Spring容器原理分析

    SpringCloud @FeignClient注入Spring容器原理分析

    本文详细分析了Spring Boot中@FeignClient注解的扫描和注入过程,重点探讨了@EnableFeignClients注解的工作原理,通过源码分析,揭示了@EnableFeignClients如何通过@Import注解和FeignClientsRegistrar类实现bean定义的加载
    2024-12-12
  • 将Java项目提交到云服务器的流程步骤

    将Java项目提交到云服务器的流程步骤

    所谓将项目提交到云服务器即将你的项目打成一个 jar 包然后提交到云服务器即可,因此我们需要准备服务器环境为:Linux + JDK + MariDB(MySQL)+ Git + Maven,文中通过图文讲解的非常详细,需要的朋友可以参考下
    2025-04-04
  • 详解如何在Java中创建Excel迷你图

    详解如何在Java中创建Excel迷你图

    迷你图是一种简洁而有效的数据可视化方式,常用于展示趋势和变化,通常被用于数据仪表盘、报告和展示中,以便在有限的空间内展示多个数据集的趋势,今天小编为大家介绍如何在Java中创建Excel迷你图,需要的朋友可以参考下
    2023-10-10
  • dubbo新手学习之事件通知实践教程

    dubbo新手学习之事件通知实践教程

    这篇文章主要给大家介绍了关于dubbo新手学习之事件通知实践的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • JAVA找不到符号的三种解决方案

    JAVA找不到符号的三种解决方案

    这篇文章主要给大家介绍了关于JAVA找不到符号的三种解决方案, 找不到符号错误主要发生在我们试图引用一个未在我们正在编译的程序中声明的变量时,这意味着编译器不知道我们所引用的Java变量,需要的朋友可以参考下
    2024-03-03
  • 新手初学Java对象内存构成

    新手初学Java对象内存构成

    这篇文章主要介绍了深入理解JVM之Java对象的创建、内存布局、访问定位,结合实例形式详细分析了Java对象的创建、内存布局、访问定位相关概念、原理、操作技巧与注意事项,需要的朋友可以参考下
    2021-07-07
  • TransactionSynchronization的invokeAfterCompletion事务源码解析

    TransactionSynchronization的invokeAfterCompletion事务源码解析

    这篇文章主要为大家介绍了TransactionSynchronization的invokeAfterCompletion事务源码解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09

最新评论