mybatis-plus實(shí)現(xiàn)四種lambda表達(dá)式方式
前言
使用了lambda表達(dá)式 可以通過(guò)方法引用的方式來(lái)使用實(shí)體字段名的操作,避免直接寫(xiě)數(shù)據(jù)庫(kù)表字段名時(shí)的錯(cuò)寫(xiě)名字;
一、LambdaQueryWrapper<>
http://www.dbjr.com.cn/program/30498424p.htm
二、QueryWrapper<實(shí)體>().lambda()
/**
* 名字為王姓并且(年齡小于40并且郵箱不為空)
* name like '王%' and (age <40 or email in not null)
* 生成的sql語(yǔ)句 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.<實(shí)體>lambdaQuery()
/**
* lambda 條件構(gòu)造器
* 生成的sql語(yǔ)句 SELECT id,name,age,email,manager_id,create_time FROM user WHERE name LIKE ? AND age < ?
*/
@Test
public void selectLambda() {
//創(chuàng)建lambda 條件構(gòu)造器 的三種方法
// 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語(yǔ)句 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 這里只是個(gè)單表演示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<實(shí)體>(xxxxMapper)
/**
* lambda 條件構(gòu)造器第四種創(chuàng)建方式 MP 3.0.7 新增的方式
* 生成的sql語(yǔ)句 SELECT id,name,age,email,manager_id,create_time FROM user WHERE name LIKE ? AND age >= ?
* 這個(gè)例子可以看出 代碼更簡(jiǎn)潔了
* 生成的sql語(yǔ)句 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在分頁(yè)中的應(yīng)用
MP的分頁(yè)操作
baseMapper接口提供兩種分頁(yè)方法來(lái)實(shí)現(xiàn)物理分頁(yè)(注:導(dǎo)包時(shí)導(dǎo)MP的包)第一個(gè)返回實(shí)體對(duì)象 允許null 第二個(gè)人返回map 對(duì)象多用于在指定放回字段時(shí)使用,避免為指定字段null值出現(xiàn)
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的分頁(yè)需要配置 類(lèi)
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();
}
}
/**
* 分頁(yè)MP 分頁(yè)插件
*/
@Test
public void selectPage() {
QueryWrapper<User> queryWrapper = new QueryWrapper<User>();
queryWrapper.ge("age", 26);
//后面參數(shù)false 表示不查詢總記錄數(shù)
Page<User> userPage = new Page<>(1, 2, false);
/* IPage<User> iPage = userMapper.selectPage(userPage, queryWrapper);
System.out.println("總頁(yè)數(shù)"+iPage.getPages());
System.out.println("總記錄數(shù)"+iPage.getTotal());
List<User> records = iPage.getRecords();
records.forEach(System.out::println);
*/
IPage<Map<String, Object>> iPage = userMapper.selectMapsPage(userPage, queryWrapper);
System.out.println("總頁(yè)數(shù)" + iPage.getPages());
System.out.println("總記錄數(shù)" + iPage.getTotal());
List<Map<String, Object>> records = iPage.getRecords();
records.forEach(System.out::println);
}
自定義分頁(yè)
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>
/**
* 自定義分頁(yè)方法
*/
@Test
public void selectMyPage() {
QueryWrapper<User> queryWrapper = new QueryWrapper<User>();
queryWrapper.ge("age", 26);
//后面參數(shù)false 表示不查詢總記錄數(shù)
Page<User> page = new Page<>(1, 2);
IPage<User> iPage = userMapper.selectUserPage(page, queryWrapper);
System.out.println("總頁(yè)數(shù)" + iPage.getPages());
System.out.println("總記錄數(shù)" + iPage.getTotal());
List<User> records = iPage.getRecords();
records.forEach(System.out::println);
}
到此這篇關(guān)于mybatis-plus實(shí)現(xiàn)四種lambda表達(dá)式方式的文章就介紹到這了,更多相關(guān)mybatisplus lambda表達(dá)式內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java靜態(tài)方法不能調(diào)用非靜態(tài)成員的原因分析
在Java中,靜態(tài)方法是屬于類(lèi)的方法,而不是屬于對(duì)象的方法,它可以通過(guò)類(lèi)名直接調(diào)用,無(wú)需創(chuàng)建對(duì)象實(shí)例,非靜態(tài)成員指的是類(lèi)的實(shí)例變量和實(shí)例方法,它們需要通過(guò)對(duì)象實(shí)例才能訪問(wèn)和調(diào)用,本文小編將和大家一起探討Java靜態(tài)方法為什么不能調(diào)用非靜態(tài)成員2023-10-10
Java實(shí)現(xiàn)Word/Pdf/TXT轉(zhuǎn)html的示例
這篇文章主要介紹了Java實(shí)現(xiàn)Word/Pdf/TXT轉(zhuǎn)html的示例,幫助大家方便的進(jìn)行文件格式轉(zhuǎn)換,完成需求,感興趣的朋友可以了解下2020-11-11
SpringCloud @FeignClient注入Spring容器原理分析
本文詳細(xì)分析了Spring Boot中@FeignClient注解的掃描和注入過(guò)程,重點(diǎn)探討了@EnableFeignClients注解的工作原理,通過(guò)源碼分析,揭示了@EnableFeignClients如何通過(guò)@Import注解和FeignClientsRegistrar類(lèi)實(shí)現(xiàn)bean定義的加載2024-12-12
將Java項(xiàng)目提交到云服務(wù)器的流程步驟
所謂將項(xiàng)目提交到云服務(wù)器即將你的項(xiàng)目打成一個(gè) jar 包然后提交到云服務(wù)器即可,因此我們需要準(zhǔn)備服務(wù)器環(huán)境為:Linux + JDK + MariDB(MySQL)+ Git + Maven,文中通過(guò)圖文講解的非常詳細(xì),需要的朋友可以參考下2025-04-04
dubbo新手學(xué)習(xí)之事件通知實(shí)踐教程
這篇文章主要給大家介紹了關(guān)于dubbo新手學(xué)習(xí)之事件通知實(shí)踐的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
新手初學(xué)Java對(duì)象內(nèi)存構(gòu)成
這篇文章主要介紹了深入理解JVM之Java對(duì)象的創(chuàng)建、內(nèi)存布局、訪問(wèn)定位,結(jié)合實(shí)例形式詳細(xì)分析了Java對(duì)象的創(chuàng)建、內(nèi)存布局、訪問(wèn)定位相關(guān)概念、原理、操作技巧與注意事項(xiàng),需要的朋友可以參考下2021-07-07
TransactionSynchronization的invokeAfterCompletion事務(wù)源碼解析
這篇文章主要為大家介紹了TransactionSynchronization的invokeAfterCompletion事務(wù)源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09

