MybatisPlus使用聚合函數(shù)的示例代碼
前言
今天遇到了一個(gè)求總數(shù)返回的情況,我一想這不是用sum就完事了嗎。
但是仔細(xì)想想,MybatisPlus好像沒有直接使用sum的api。
雖然沒有直接提供,但是辦法還是有的,下面就分享下如何實(shí)現(xiàn)的:
首先如果使用sql是這么寫的:
ok,既然知道了sql怎么寫的,那就開始寫代碼吧
注意,本文主要以sum為例,但是也同時(shí)適用于其他聚合函數(shù),比如avg,min,max
方式1 通過select自定義sql
求一個(gè)sum
雖然MybatisPlus沒有直接提供對(duì)sum函數(shù)操作的api,但是QueryWrapper里面有一個(gè)select的api,可以支持我們自定義查詢sql。
注意:我這種寫法需要實(shí)體中有這個(gè)別名,不然不行的!
那我就直接把代碼貼出來了:
public Map queryGuaranteeOrderSumAmount() { GuaranteeOrder guaranteeOrder =new GuaranteeOrder(); QueryWrapper<GuaranteeOrder> queryWrapper = new QueryWrapper<>(); // 退款金額總計(jì) sum聚合函數(shù) queryWrapper.select("sum(refund_amount)refundAmount"); // 這條訂單信息的詳情 GuaranteeOrder guaranteeOrderDetail= this.getOne(queryWrapper); if (guaranteeOrderDetail== null){ guaranteeOrder.setRefundAmount(BigDecimal.valueOf(Double.valueOf(0))); }else{ guaranteeOrder.setRefundAmount(guaranteeOrderDetail.getRefundAmount()); } HashMap<String, Object> map = new HashMap<>(); // 退款金額總計(jì) map.put("refundSumAmount",guaranteeOrderDetail.getRefundAmount()); return map; }
可以看到執(zhí)行的sql是一樣的。證明我們的思路和語法是沒問題的
求多個(gè)sum
那有的小可愛(大聰明)可能就會(huì)這么想了,那我要是想sum多個(gè)值,是不是再寫一個(gè)select就可以了,那還真不是!我就是這個(gè)大聰明:
如圖所示,我又sum了一個(gè)字段,但是調(diào)用接口的時(shí)候,發(fā)現(xiàn)一個(gè)值是空的:
這其實(shí)是錯(cuò)誤的!除非再創(chuàng)建一個(gè)queryWrapper寫select!
正所謂高手怕菜鳥,其實(shí)是我們想的太復(fù)雜啦,簡(jiǎn)單的解決方式是:sql怎么寫,你就怎么寫嘛,直接在后面再拼一個(gè)條件就好了,例如:
這次就好啦,解決問題!
方式2 xml手寫原生sql
覺得上面的方式比較麻煩,那就可以簡(jiǎn)單點(diǎn),直接在mapper(dao).xml里面手寫sql
一般項(xiàng)目中都是MybatisPlus和Mybatis同時(shí)使用的,就是防止一些關(guān)聯(lián)或者特別麻煩的sql。
總結(jié)
雖然MybatisPlus沒有直接提供我們使用聚合函數(shù)的api,但是通過select也是可以獲取到編寫自定義sql的,使用起來也還好啦。希望后續(xù)國產(chǎn)MP開發(fā)團(tuán)隊(duì)可以專門針對(duì)這些函數(shù)進(jìn)行封裝,這樣使用起來就更方便了!
到此這篇關(guān)于MybatisPlus使用聚合函數(shù)的示例代碼的文章就介紹到這了,更多相關(guān)MybatisPlus 聚合函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java中提供synchronized后為什么還要提供Lock
這篇文章主要介紹了Java中提供synchronized后為什么還要提供Lock,在Java中提供了synchronized關(guān)鍵字來保證只有一個(gè)線程能夠訪問同步代碼塊,下文更多相關(guān)資料需要的小伙伴可以參考一下2022-03-03解析Spring中@Controller@Service等線程安全問題
這篇文章主要為大家介紹解析了Spring中@Controller@Service等線程的安全問題,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-03-03Springboot項(xiàng)目啟動(dòng)不加載resources目錄下的文件問題
這篇文章主要介紹了Springboot項(xiàng)目啟動(dòng)不加載resources目錄下的文件問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08checkpoint 機(jī)制具體實(shí)現(xiàn)示例詳解
這篇文章主要為大家介紹了checkpoint 機(jī)制具體實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02Spring實(shí)現(xiàn)動(dòng)態(tài)數(shù)據(jù)源切換的方法總結(jié)
這篇文章主要為大家詳細(xì)介紹了一種Spring實(shí)現(xiàn)動(dòng)態(tài)數(shù)據(jù)源切換的方法,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以跟隨小編一起了解一下2023-06-06