zoukankan      html  css  js  c++  java
  • Mybatis-plus之四种lambda方式

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

    一、LambdaQueryWrapper<>
    二、QueryWrapper<实体>().lambda()
    三、Wrappers.<实体>lambdaQuery()

    具体为:

    LambdaQueryWrapper<User> lambdaQueryWrapper = new LambdaQueryWrapper<>();
    LambdaQueryWrapper<User> lambda = new QueryWrapper<User>().lambda();
            
    LambdaQueryWrapper<User> lambdaQuery = Wrappers.<User>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> lambda1 = new LambdaQueryWrapper<>();      //第一种方法
    //        LambdaQueryWrapper<User> lambda2= 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);
    }

    ref:(20条消息) mybatis-plus之四种lambda方式_掌握月的博客-CSDN博客

  • 相关阅读:
    SpringBoot发送邮箱验证码
    判断一个数是否为2的整数次幂
    [模板] 虚树 && bzoj2286-[Sdoi2011]消耗战
    [模板] K-D Tree
    [模板] 平衡树: Splay, 非旋Treap, 替罪羊树
    对于约数个数上界的估计
    luogu3702-[SDOI2017]序列计数
    [模板] 线性基
    [模板] 区间mex && 区间元素种数
    bzoj4367-[IOI2014]holiday假期
  • 原文地址:https://www.cnblogs.com/cy0628/p/15147593.html
Copyright © 2011-2022 走看看