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

MyBatis-Plus條件構造器Wrapper應用實例

 更新時間:2023年09月19日 09:28:34   作者:行者張良  
QueryWrapper是用于查詢的Wrapper條件構造器,可以通過它來構建SELECT語句中的WHERE條件,這篇文章主要介紹了MyBatis-Plus數(shù)據(jù)表操作條件構造器Wrapper,需要的朋友可以參考下

一、Wapper分類

Wrapper : 條件構造抽象類,最頂端父類
AbstractWrapper : 用于查詢條件封裝,生成 sql 的 where 條件
QueryWrapper : Entity 對象封裝操作類,不是用lambda語法
UpdateWrapper : Update 條件封裝,用于Entity對象更新操作
AbstractLambdaWrapper : Lambda 語法使用 Wrapper統(tǒng)一處理解析 lambda 獲取 column
LambdaQueryWrapper :看名稱也能明白就是用于Lambda語法使用的查詢Wrapper
LambdaUpdateWrapper : Lambda 更新封裝Wrapper

二、各構造器的區(qū)別

1)QueryWrapper、QueryChainWrapper只能指定需要的數(shù)據(jù)庫列名;
2)LambdaQueryWrapper、LambdaQueryChainWrapper可以通過Lambda獲取數(shù)據(jù)庫列名;
3)QueryWrapper 、LambdaQueryWrapper不能使用鏈式查詢的方式,必須借助BaseMapper來執(zhí)行;
4)QueryChainWrapper、LambdaQueryChainWrapper可以使用鏈式查詢的方式,如list(),one();

三、構造器常用方法

在這里插入圖片描述

eq:equals,等于

gt:greater than ,大于 >

ge:greater than or equals,大于等于≥

lt:less than,小于<

le:less than or equals,小于等于≤

between:相當于SQL中的BETWEEN

like:模糊匹配。like(“name”,“黃”),相當于SQL的name like ‘%黃%’

likeRight:模糊匹配右半邊。likeRight(“name”,“黃”),相當于SQL的name like ‘黃%’

likeLeft:模糊匹配左半邊。likeLeft(“name”,“黃”),相當于SQL的name like ‘%黃’

notLike:notLike(“name”,“黃”),相當于SQL的name not like ‘%黃%’

isNull

isNotNull

and:SQL連接符AND

or:SQL連接符OR

in: in(“age",{1,2,3})相當于 age in(1,2,3)

groupBy: groupBy(“id”,“name”)相當于 group by id,name

orderByAsc :orderByAsc(“id”,“name”)相當于 order by id ASC,name ASC

orderByDesc :orderByDesc (“id”,“name”)相當于 order by id DESC,name DESC

四、Wrapper常用構造器應用實例

4.1 QueryWrapper

QueryWrapper是用于查詢的Wrapper條件構造器,可以通過它來構建SELECT語句中的WHERE條件

@Test
public void testQueryWrapper() {
// 查詢條件構造器
QueryWrapper<BannerItem> wrapper = new QueryWrapper<>();
wrapper.eq("banner_id", id);
// 查詢操作
List<BannerItem> bannerItems = bannerItemMapper.selectList(wrapper);
//我們可以引入lambda,避免在代碼中寫類似的于banner_id的硬編碼
QueryWrapper<BannerItem> wrapper = new QueryWrapper<>();
wrapper.lambda().eq(BannerItem::getBannerId, id);
List<BannerItem> bannerItems = bannerItemMapper.selectList(wrapper);
}

4.2 UpdateWrapper

QueryWrapper是用于查詢的Wrapper條件構造器,可以通過它來構建SELECT語句中的WHERE條件:
SQL SET 字段
例: set(“name”, “張三”)
例: set(“name”, “”)—>數(shù)據(jù)庫字段值變?yōu)榭兆址?br />例: set(“name”, null)—>數(shù)據(jù)庫字段值變?yōu)閚ull

@Test
public void testUpdateWrapper() {
UpdateWrapper<User> updateWrapper = new UpdateWrapper<>();
updateWrapper.set("age", 20).eq("name", "張三");
int affectedRows = userMapper.update(null, updateWrapper);
}

4.3 LambdaQueryWrapper

Lambda條件構造器是一種更加便捷、類型安全的Wrapper條件構造器,可以通過Lambda表達式來構建WHERE條件

作用:

1)字段檢查,防止字段寫錯2)防止傳入的數(shù)據(jù)為null作為條件

書寫方式如下:

1)引入對象

2)調用函數(shù)

為了簡化lambda的使用,我們可以改寫成LambdaQueryWrapper構造器,語法如下:

LambdaQueryWrapper<BannerItem> wrapper = new QueryWrapper<BannerItem>().lambda();
wrapper.eq(BannerItem::getBannerId, id);
List<BannerItem> bannerItems = bannerItemMapper.selectList(wrapper);

我們可以再次將QueryWrapper.lambda()簡化,變成這個樣子

LambdaQueryWrapper<BannerItem> wrapper = new LambdaQueryWrapper<>();
wrapper.eq(BannerItem::getBannerId, id);
List<BannerItem> bannerItems = bannerItemMapper.selectList(wrapper);

鏈式查詢

MyBatis-Plus還提供了一種鏈式查詢的方式,和上面的代碼效果一樣。

但是這種寫法偏向于炫技,可讀性沒有上面的代碼強,大家可以根據(jù)需要自行選擇方式。

List<BannerItem> bannerItems = new LambdaQueryChainWrapper<>(bannerItemMapper)
                        .eq(BannerItem::getBannerId, id)
                        .list();

如果只想查詢一條記錄,例如通過id查詢某條記錄的詳情,使用.one()即可,例如

BannerItem bannerItem = new LambdaQueryChainWrapper<>(bannerItemMapper)
                        .eq(BannerItem::getId, id)
                        .one();

4.4Lambda條件構造器

前面在使用條件構造器時列名都是用字符串的形式去指定。這種方式無法在編譯期確定列名的合法性。

所以MP提供了一個Lambda條件構造器可以讓我們直接以實體類的方法引用的形式來指定列名。

Lambda條件構造器相比于傳統(tǒng)的Wrapper條件構造器,具有以下幾個好處:

更加簡潔易懂:Lambda條件構造器使用Lambda表達式來構建WHERE條件,代碼更加簡潔易懂,不需要繁瑣的字符串拼接(避免硬編碼)。

更加類型安全:Lambda條件構造器在編譯時就能檢查出類型錯誤,避免在運行時出現(xiàn)類型轉換異常的問題。

更加靈活:Lambda條件構造器支持鏈式調用,可以方便地組合多個條件,還支持自定義SQL片段,更加靈活

4.5.示例

要執(zhí)行的查詢對應的SQL如下

SELECT 
	id,user_name,PASSWORD,NAME,age,address 
FROM 
	USER 
WHERE 
	age > 18 AND address = '狐山'

如果使用之前的條件構造器寫法如下

@Test
public void testLambdaWrapper(){
QueryWrapper queryWrapper = new QueryWrapper();
queryWrapper.gt(“age”,30);
queryWrapper.eq(“address”,“黃山”);
List users = userMapper.selectList(queryWrapper);
}

如果使用Lambda條件構造器寫法如下

 @Test
    public void testLambdaWrapper2(){
        LambdaQueryWrapper<User> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.gt(User::getAge,30);
        queryWrapper.eq(User::getAddress,"黃山");
        List<User> users = userMapper.selectList(queryWrapper);
    }

到此這篇關于MyBatis-Plus數(shù)據(jù)表操作條件構造器Wrapper的文章就介紹到這了,更多相關MyBatis-Plus條件構造器Wrapper內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Java使用pdfbox實現(xiàn)給pdf文件加圖片水印

    Java使用pdfbox實現(xiàn)給pdf文件加圖片水印

    有時候需要給pdf加水印,市面上工具都是收費的要會員,還是自食其力吧;嘗試過 spire.pdf.free 那個超過10頁就不行了!所以本文還是使用了pdfbox,感興趣的可以了解一下
    2022-11-11
  • Spring與Redis集成的正確方式流程詳解

    Spring與Redis集成的正確方式流程詳解

    這篇文章主要為大家介紹了Spring與Redis集成的正確方式流程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • Spring 4 支持的 Java 8 特性

    Spring 4 支持的 Java 8 特性

    Spring 框架 4 支持 Java 8 語言和 API 功能。在本文中,我們將重點放在 Spring 4 支持新的 Java 8 的功能。最重要的是 Lambda 表達式,方法引用,JSR-310的日期和時間,和可重復注釋。下面跟著小編一起來看下吧
    2017-03-03
  • Netty中的DelimiterBasedFrameDecoder使用方法詳解

    Netty中的DelimiterBasedFrameDecoder使用方法詳解

    這篇文章主要介紹了Netty中的DelimiterBasedFrameDecoder使用方法詳解,DelimiterBasedFrameDecoder與LineBasedFrameDecoder類似,只不過更加通用,允許我們指定任意特殊字符作為分隔符,我們還可以同時指定多個分隔符,需要的朋友可以參考下
    2023-12-12
  • ReadWriteLock接口及其實現(xiàn)ReentrantReadWriteLock方法

    ReadWriteLock接口及其實現(xiàn)ReentrantReadWriteLock方法

    下面小編就為大家?guī)硪黄猂eadWriteLock接口及其實現(xiàn)ReentrantReadWriteLock方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • SpringBoot使用MyBatis-Flex實現(xiàn)靈活的數(shù)據(jù)庫訪問

    SpringBoot使用MyBatis-Flex實現(xiàn)靈活的數(shù)據(jù)庫訪問

    MyBatisFlex是一款優(yōu)秀的持久層框架,本文主要介紹了SpringBoot使用MyBatis-Flex實現(xiàn)靈活的數(shù)據(jù)庫訪問,具有一定的參考價值,感興趣的可以了解一下
    2024-06-06
  • 淺析Java IO相關知識點

    淺析Java IO相關知識點

    本篇文章給大家分享了關于java io的一些相關知識點以及相關內(nèi)容,對此有需要的朋友可以學習參考下。
    2018-05-05
  • java利用Future實現(xiàn)多線程執(zhí)行與結果聚合實例代碼

    java利用Future實現(xiàn)多線程執(zhí)行與結果聚合實例代碼

    這篇文章主要給大家介紹了關于java利用Future實現(xiàn)多線程執(zhí)行與結果聚合的相關資料,Future模式的核心,去除了主函數(shù)的等待時間,并使得原本需要等待的時間段可以用于處理其他業(yè)務邏輯,需要的朋友可以參考下
    2021-12-12
  • SpringBoot?@Profile的使用

    SpringBoot?@Profile的使用

    本文主要介紹了SpringBoot?@Profile的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • java實現(xiàn)求兩個字符串最長公共子串的方法

    java實現(xiàn)求兩個字符串最長公共子串的方法

    這篇文章主要介紹了java實現(xiàn)求兩個字符串最長公共子串的方法,是一道華為OJ上的一道題目,涉及Java針對字符串的遍歷、轉換及流程控制等技巧,需要的朋友可以參考下
    2015-12-12

最新評論