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

MybatisPlus使用聚合函數(shù)的示例代碼

 更新時間:2023年03月16日 16:13:35   作者:小花皮豬  
本文主要介紹了MybatisPlus使用聚合函數(shù)的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

今天遇到了一個求總數(shù)返回的情況,我一想這不是用sum就完事了嗎。

但是仔細(xì)想想,MybatisPlus好像沒有直接使用sum的api。

雖然沒有直接提供,但是辦法還是有的,下面就分享下如何實(shí)現(xiàn)的:

首先如果使用sql是這么寫的:

ok,既然知道了sql怎么寫的,那就開始寫代碼吧

注意,本文主要以sum為例,但是也同時適用于其他聚合函數(shù),比如avg,min,max

方式1 通過select自定義sql

求一個sum

雖然MybatisPlus沒有直接提供對sum函數(shù)操作的api,但是QueryWrapper里面有一個select的api,可以支持我們自定義查詢sql。

注意:我這種寫法需要實(shí)體中有這個別名,不然不行的!

那我就直接把代碼貼出來了:

 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是一樣的。證明我們的思路和語法是沒問題的

求多個sum

那有的小可愛(大聰明)可能就會這么想了,那我要是想sum多個值,是不是再寫一個select就可以了,那還真不是!我就是這個大聰明:

如圖所示,我又sum了一個字段,但是調(diào)用接口的時候,發(fā)現(xiàn)一個值是空的:

這其實(shí)是錯誤的!除非再創(chuàng)建一個queryWrapper寫select!

正所謂高手怕菜鳥,其實(shí)是我們想的太復(fù)雜啦,簡單的解決方式是:sql怎么寫,你就怎么寫嘛,直接在后面再拼一個條件就好了,例如:

這次就好啦,解決問題!

方式2 xml手寫原生sql

覺得上面的方式比較麻煩,那就可以簡單點(diǎn),直接在mapper(dao).xml里面手寫sql

一般項(xiàng)目中都是MybatisPlus和Mybatis同時使用的,就是防止一些關(guān)聯(lián)或者特別麻煩的sql。

總結(jié)

雖然MybatisPlus沒有直接提供我們使用聚合函數(shù)的api,但是通過select也是可以獲取到編寫自定義sql的,使用起來也還好啦。希望后續(xù)國產(chǎn)MP開發(fā)團(tuán)隊(duì)可以專門針對這些函數(shù)進(jìn)行封裝,這樣使用起來就更方便了!

到此這篇關(guān)于MybatisPlus使用聚合函數(shù)的示例代碼的文章就介紹到這了,更多相關(guān)MybatisPlus 聚合函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Spring循環(huán)依賴產(chǎn)生與解決

    Spring循環(huán)依賴產(chǎn)生與解決

    Spring的解決循環(huán)依賴是有前置條件的,要解決循環(huán)依賴我們首先要了解Spring Bean對象的創(chuàng)建過程和依賴注入的方式。依賴注入方式,我之前的博客有所分享,大家可以在看本篇文章之前進(jìn)行一下小小的回顧
    2022-12-12
  • Java中提供synchronized后為什么還要提供Lock

    Java中提供synchronized后為什么還要提供Lock

    這篇文章主要介紹了Java中提供synchronized后為什么還要提供Lock,在Java中提供了synchronized關(guān)鍵字來保證只有一個線程能夠訪問同步代碼塊,下文更多相關(guān)資料需要的小伙伴可以參考一下
    2022-03-03
  • Java中的equsals和==

    Java中的equsals和==

    這篇文章主要介紹了Java中的equsals和==的相關(guān)內(nèi)容,感興趣的朋朋友可以參考下文
    2021-08-08
  • Java系統(tǒng)的高并發(fā)解決方法詳解

    Java系統(tǒng)的高并發(fā)解決方法詳解

    這篇文章主要介紹了Java系統(tǒng)的高并發(fā)解決方法,內(nèi)容十分豐富,在這里分享給大家,需要的朋友可以參考。
    2017-09-09
  • 解析Spring中@Controller@Service等線程安全問題

    解析Spring中@Controller@Service等線程安全問題

    這篇文章主要為大家介紹解析了Spring中@Controller@Service等線程的安全問題,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-03-03
  • Springboot項(xiàng)目啟動不加載resources目錄下的文件問題

    Springboot項(xiàng)目啟動不加載resources目錄下的文件問題

    這篇文章主要介紹了Springboot項(xiàng)目啟動不加載resources目錄下的文件問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • checkpoint 機(jī)制具體實(shí)現(xiàn)示例詳解

    checkpoint 機(jī)制具體實(shí)現(xiàn)示例詳解

    這篇文章主要為大家介紹了checkpoint 機(jī)制具體實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • springboot上傳文件,url直接訪問資源問題

    springboot上傳文件,url直接訪問資源問題

    這篇文章主要介紹了springboot上傳文件,url直接訪問資源問題。具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • springboot打war包的全過程記錄

    springboot打war包的全過程記錄

    其實(shí)一般使用springboot使用打成jar包比較省事的,但也有很多童鞋是習(xí)慣使用war包的,下面這篇文章主要給大家介紹了關(guān)于springboot打war包的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • Spring實(shí)現(xiàn)動態(tài)數(shù)據(jù)源切換的方法總結(jié)

    Spring實(shí)現(xiàn)動態(tài)數(shù)據(jù)源切換的方法總結(jié)

    這篇文章主要為大家詳細(xì)介紹了一種Spring實(shí)現(xiàn)動態(tài)數(shù)據(jù)源切換的方法,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以跟隨小編一起了解一下
    2023-06-06

最新評論