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ù)國(guó)產(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)文章
解決nacos啟動(dòng)報(bào)錯(cuò)Server check fail, please che
這篇文章主要介紹了nacos啟動(dòng) Server check fail, please check server localhost ,port 9848 is available的錯(cuò)誤原因以及解決方法,需要的朋友可以參考下2023-09-09
idea運(yùn)行tomcat報(bào)錯(cuò)找不到catalina.bat,系統(tǒng)找不到指定的文件問題
這篇文章主要介紹了idea運(yùn)行tomcat報(bào)錯(cuò)找不到catalina.bat,系統(tǒng)找不到指定的文件問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,2023-11-11
springboot整合mybatis中的問題及出現(xiàn)的一些問題小結(jié)
這篇文章主要介紹了springboot整合mybatis中的問題及出現(xiàn)的一些問題小結(jié),本文給出了解決方案,需要的朋友可以參考下2018-11-11
Java實(shí)現(xiàn)導(dǎo)出合并Excel單元格
隨著數(shù)據(jù)的不斷增長(zhǎng),很多時(shí)候需要將數(shù)據(jù)導(dǎo)出到Excel中進(jìn)行分析、處理和展示。本文將介紹如何使用Java實(shí)現(xiàn)Excel導(dǎo)出,并且可以合并單元格,需要的可以參考一下2023-04-04
InteliJ IDEA 設(shè)置eclipse快捷鍵 的圖文教程
本文通過圖文并茂的形式給大家介紹了InteliJ IDEA 設(shè)置eclipse快捷鍵 ,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下2018-06-06
IDEA JetBrains Mono字體介紹和安裝教程(詳解)
這篇文章主要介紹了IDEA JetBrains Mono字體介紹和安裝教程,本給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-03-03

