LambdaQueryWrapper與QueryWrapper的使用方式
介紹
在Mybatis-plus框架中,LambdaQueryWrapper和QueryWrapper是兩個(gè)非常常用的類。它們用于快速簡(jiǎn)便地查詢數(shù)據(jù)庫(kù)。
LambdaQueryWrapper是Mybatis-plus 3.0.7版本之后推出的一個(gè)查詢工具類,它采用lambda表達(dá)式構(gòu)建SQL查詢語(yǔ)句,可以快速、簡(jiǎn)便地完成CRUD等操作。
QueryWrapper是Mybatis-plus 3.0.7版本之前推出的查詢工具類,它的語(yǔ)法與LambdaQueryWrapper有所不同,如果你還停留在Mybatis-plus 3.0.7版本以前的版本中,那么你需要使用QueryWrapper。
在本篇文章中,將介紹LambdaQueryWrapper和QueryWrapper的使用方法,并提供詳細(xì)的開發(fā)流程思路以及代碼。
前置條件
在使用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>
如何使用
接下來(lái),我們將分別介紹LambdaQueryWrapper與QueryWrapper的使用方法。
LambdaQueryWrapper的使用方法
LambdaQueryWrapper可以使用lambda表達(dá)式構(gòu)建SQL查詢語(yǔ)句,這讓我們可以在不使用繁瑣的SQL語(yǔ)句的情況下快速地進(jìn)行數(shù)據(jù)庫(kù)操作。
首先,我們需要在實(shí)體類中注解@Table和@Id,以指定表名和主鍵:
@Data @TableName("user") public class UserEntity { @TableId(type = IdType.AUTO) private Long id; private String name; private Integer age; }
接下來(lái),我們可以使用LambdaQueryWrapper來(lái)進(jìn)行查詢操作。
例如,我們希望查詢年齡大于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語(yǔ)句來(lái)構(gòu)建查詢條件。
如果你使用的是Mybatis-plus 3.0.7版本以前的版本,那么你需要使用QueryWrapper。
使用QueryWrapper進(jìn)行查詢操作的代碼示例:
QueryWrapper<UserEntity> qw = new QueryWrapper<UserEntity>() .eq("name", "張三") // 姓名 = 張三 .gt("age", 18); // 年齡 > 18 List<UserEntity> userList = userMapper.selectList(qw);
以上代碼使用了QueryWrapper的eq和gt方法,它們分別表示等于和大于操作。
實(shí)踐應(yīng)用
在實(shí)際應(yīng)用中,LambdaQueryWrapper和QueryWrapper常常被用于復(fù)雜的查詢操作,甚至可以用于分頁(yè)查詢。
例如,我們可以使用LambdaQueryWrapper來(lái)實(shí)現(xiàn)帶分頁(yè)的查詢操作:
IPage<UserEntity> page = new Page<>(1, 10); // 分頁(yè)查詢 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()); // 輸出查詢結(jié)果
以上代碼中,我們使用了分頁(yè)查詢,并通過LambdaQueryWrapper實(shí)現(xiàn)了復(fù)雜的查詢操作。
在實(shí)際應(yīng)用中,我們還可以使用LambdaQueryWrapper和QueryWrapper實(shí)現(xiàn)更多復(fù)雜的查詢操作,以滿足不同的業(yè)務(wù)需求。
例如,我們可以使用LambdaQueryWrapper和QueryWrapper進(jìn)行動(dòng)態(tài)查詢,通過判斷前端傳入的參數(shù),來(lái)組合SQL語(yǔ)句,實(shí)現(xiàn)靈活的查詢操作。
以下是代碼示例:
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實(shí)現(xiàn)了動(dòng)態(tài)的查詢操作。
如果傳入的name參數(shù)不為空,那么就會(huì)添加一個(gè)等于查詢條件;如果傳入的age參數(shù)不為空,那么就會(huì)添加一個(gè)大于查詢條件。
這樣的查詢操作,可以根據(jù)前端傳入的參數(shù),靈活地組合SQL語(yǔ)句,實(shí)現(xiàn)更多的業(yè)務(wù)需求。
總結(jié)
LambdaQueryWrapper和QueryWrapper是Mybatis-plus框架中常用的查詢工具類,通過它們,我們可以在不使用繁瑣的SQL語(yǔ)句的情況下,快速地進(jìn)行數(shù)據(jù)庫(kù)操作。
LambdaQueryWrapper使用lambda表達(dá)式構(gòu)建SQL查詢語(yǔ)句,QueryWrapper需要使用SQL語(yǔ)句來(lái)構(gòu)建查詢條件。
它們可以被用于復(fù)雜的查詢操作,包括分頁(yè)查詢、動(dòng)態(tài)查詢等,在實(shí)際應(yīng)用中具有非常廣泛的應(yīng)用場(chǎng)景。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
MyBatisPlus使用@TableField注解處理默認(rèn)填充時(shí)間的問題
這篇文章主要介紹了MyBatisPlus使用@TableField注解處理默認(rèn)填充時(shí)間的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01JavaEE開發(fā)基于Eclipse的環(huán)境搭建以及Maven Web App的創(chuàng)建
本文主要介紹了如何在Eclipse中創(chuàng)建的Maven Project,本文是JavaEE開發(fā)的開篇,也是基礎(chǔ)。下面內(nèi)容主要包括了JDK1.8的安裝、JavaEE版本的Eclipse的安裝、Maven的安裝、Tomcat 9.0的配置、Eclipse上的M2Eclipse插件以及STS插件的安裝。2017-03-03解決Java中socket使用getInputStream()阻塞問題
這篇文章主要介紹了解決Java中socket使用getInputStream()阻塞問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12Java統(tǒng)計(jì)代碼的執(zhí)行時(shí)間的N種方法
在日常開發(fā)中經(jīng)常需要測(cè)試一些代碼的執(zhí)行時(shí)間,但又不想使用向 JMH(Java?Microbenchmark Harness,Java 微基準(zhǔn)測(cè)試套件)這么重的測(cè)試框架,所以本文就匯總了一些 Java 中比較常用的執(zhí)行時(shí)間統(tǒng)計(jì)方法,總共包含以下 6 種,需要的朋友可以參考下2022-08-08springboot后端接收前端傳數(shù)組參數(shù)三種方法
這篇文章主要給大家介紹了關(guān)于springboot后端接收前端傳數(shù)組參數(shù)三種方法,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-07-07Servlet第一個(gè)項(xiàng)目的發(fā)布(入門)
這篇文章主要介紹了Servlet第一個(gè)項(xiàng)目的發(fā)布,下面是用servlet實(shí)現(xiàn)的一個(gè)簡(jiǎn)單的web項(xiàng)目,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2021-04-04log4j.properties 配置(實(shí)例講解)
下面小編就為大家?guī)?lái)一篇log4j.properties 配置(實(shí)例講解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2017-08-08