MybatisPlus使用聚合函數(shù)的示例代碼
前言
今天遇到了一個求總數(shù)返回的情況,我一想這不是用sum就完事了嗎。
但是仔細想想,MybatisPlus好像沒有直接使用sum的api。
雖然沒有直接提供,但是辦法還是有的,下面就分享下如何實現(xiàn)的:
首先如果使用sql是這么寫的:

ok,既然知道了sql怎么寫的,那就開始寫代碼吧
注意,本文主要以sum為例,但是也同時適用于其他聚合函數(shù),比如avg,min,max
方式1 通過select自定義sql
求一個sum
雖然MybatisPlus沒有直接提供對sum函數(shù)操作的api,但是QueryWrapper里面有一個select的api,可以支持我們自定義查詢sql。
注意:我這種寫法需要實體中有這個別名,不然不行的!

那我就直接把代碼貼出來了:
public Map queryGuaranteeOrderSumAmount() {
GuaranteeOrder guaranteeOrder =new GuaranteeOrder();
QueryWrapper<GuaranteeOrder> queryWrapper = new QueryWrapper<>();
// 退款金額總計 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<>();
// 退款金額總計
map.put("refundSumAmount",guaranteeOrderDetail.getRefundAmount());
return map;
}
可以看到執(zhí)行的sql是一樣的。證明我們的思路和語法是沒問題的
求多個sum
那有的小可愛(大聰明)可能就會這么想了,那我要是想sum多個值,是不是再寫一個select就可以了,那還真不是!我就是這個大聰明:
如圖所示,我又sum了一個字段,但是調(diào)用接口的時候,發(fā)現(xiàn)一個值是空的:


這其實是錯誤的!除非再創(chuàng)建一個queryWrapper寫select!
正所謂高手怕菜鳥,其實是我們想的太復雜啦,簡單的解決方式是:sql怎么寫,你就怎么寫嘛,直接在后面再拼一個條件就好了,例如:

這次就好啦,解決問題!

方式2 xml手寫原生sql
覺得上面的方式比較麻煩,那就可以簡單點,直接在mapper(dao).xml里面手寫sql
一般項目中都是MybatisPlus和Mybatis同時使用的,就是防止一些關聯(lián)或者特別麻煩的sql。
總結
雖然MybatisPlus沒有直接提供我們使用聚合函數(shù)的api,但是通過select也是可以獲取到編寫自定義sql的,使用起來也還好啦。希望后續(xù)國產(chǎn)MP開發(fā)團隊可以專門針對這些函數(shù)進行封裝,這樣使用起來就更方便了!
到此這篇關于MybatisPlus使用聚合函數(shù)的示例代碼的文章就介紹到這了,更多相關MybatisPlus 聚合函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java中提供synchronized后為什么還要提供Lock
這篇文章主要介紹了Java中提供synchronized后為什么還要提供Lock,在Java中提供了synchronized關鍵字來保證只有一個線程能夠訪問同步代碼塊,下文更多相關資料需要的小伙伴可以參考一下2022-03-03
解析Spring中@Controller@Service等線程安全問題
這篇文章主要為大家介紹解析了Spring中@Controller@Service等線程的安全問題,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-03-03
Springboot項目啟動不加載resources目錄下的文件問題
這篇文章主要介紹了Springboot項目啟動不加載resources目錄下的文件問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
Spring實現(xiàn)動態(tài)數(shù)據(jù)源切換的方法總結
這篇文章主要為大家詳細介紹了一種Spring實現(xiàn)動態(tài)數(shù)據(jù)源切換的方法,文中的示例代碼講解詳細,具有一定的學習價值,感興趣的小伙伴可以跟隨小編一起了解一下2023-06-06

