天天看點

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);

}      

自定義分頁

IPage<User> selectUserPage(Page<User> page,@Param(Constants.WRAPPER)Wrapper<User> wrapper);      
<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);
}