欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

LambdaQueryWrapper與QueryWrapper的使用方式

 更新時(shí)間:2024年05月06日 16:20:46   作者:沙漠真有魚  
這篇文章主要介紹了LambdaQueryWrapper與QueryWrapper的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

介紹

在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í)間的問題

    這篇文章主要介紹了MyBatisPlus使用@TableField注解處理默認(rèn)填充時(shí)間的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • java開發(fā)微信公眾號(hào)支付

    java開發(fā)微信公眾號(hào)支付

    這篇文章主要給大家結(jié)合微信支付接口開發(fā)的實(shí)踐,從獲取用戶授權(quán)到各主要接口的使用方法等方面介紹微信支付的關(guān)鍵點(diǎn)技術(shù),有需要的小伙伴可以參考下
    2015-08-08
  • JavaEE開發(fā)基于Eclipse的環(huán)境搭建以及Maven Web App的創(chuàng)建

    JavaEE開發(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 用itext設(shè)置pdf紙張大小操作

    java 用itext設(shè)置pdf紙張大小操作

    這篇文章主要介紹了java 用itext設(shè)置pdf紙張大小操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
    2021-01-01
  • Spring JPA 增加字段執(zhí)行異常問題及解決

    Spring JPA 增加字段執(zhí)行異常問題及解決

    這篇文章主要介紹了Spring JPA 增加字段執(zhí)行異常問題及解決,具有很好的參考價(jià)值,
    2022-06-06
  • 解決Java中socket使用getInputStream()阻塞問題

    解決Java中socket使用getInputStream()阻塞問題

    這篇文章主要介紹了解決Java中socket使用getInputStream()阻塞問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • Java統(tǒng)計(jì)代碼的執(zhí)行時(shí)間的N種方法

    Java統(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-08
  • springboot后端接收前端傳數(shù)組參數(shù)三種方法

    springboot后端接收前端傳數(shù)組參數(shù)三種方法

    這篇文章主要給大家介紹了關(guān)于springboot后端接收前端傳數(shù)組參數(shù)三種方法,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-07-07
  • Servlet第一個(gè)項(xiàng)目的發(fā)布(入門)

    Servlet第一個(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-04
  • log4j.properties 配置(實(shí)例講解)

    log4j.properties 配置(實(shí)例講解)

    下面小編就為大家?guī)?lái)一篇log4j.properties 配置(實(shí)例講解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2017-08-08

最新評(píng)論