MyBatis-Plus條件構造器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文件加圖片水印
有時候需要給pdf加水印,市面上工具都是收費的要會員,還是自食其力吧;嘗試過 spire.pdf.free 那個超過10頁就不行了!所以本文還是使用了pdfbox,感興趣的可以了解一下2022-11-11Netty中的DelimiterBasedFrameDecoder使用方法詳解
這篇文章主要介紹了Netty中的DelimiterBasedFrameDecoder使用方法詳解,DelimiterBasedFrameDecoder與LineBasedFrameDecoder類似,只不過更加通用,允許我們指定任意特殊字符作為分隔符,我們還可以同時指定多個分隔符,需要的朋友可以參考下2023-12-12ReadWriteLock接口及其實現(xiàn)ReentrantReadWriteLock方法
下面小編就為大家?guī)硪黄猂eadWriteLock接口及其實現(xiàn)ReentrantReadWriteLock方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-06-06SpringBoot使用MyBatis-Flex實現(xiàn)靈活的數(shù)據(jù)庫訪問
MyBatisFlex是一款優(yōu)秀的持久層框架,本文主要介紹了SpringBoot使用MyBatis-Flex實現(xiàn)靈活的數(shù)據(jù)庫訪問,具有一定的參考價值,感興趣的可以了解一下2024-06-06java利用Future實現(xiàn)多線程執(zhí)行與結果聚合實例代碼
這篇文章主要給大家介紹了關于java利用Future實現(xiàn)多線程執(zhí)行與結果聚合的相關資料,Future模式的核心,去除了主函數(shù)的等待時間,并使得原本需要等待的時間段可以用于處理其他業(yè)務邏輯,需要的朋友可以參考下2021-12-12