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

解讀@SelectProvider的使用方法

 更新時間:2024年08月20日 08:45:58   作者:喜歡你的名字和你笑的樣子  
這篇文章主要介紹了@SelectProvider的使用方法,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

解讀@SelectProvider的使用

首先在mapper里面寫個方法

@SelectProvider(type = SalesOrderProvider.class, method = "selectSalesInformation")
    List<SalesInformation> selectSalesInformation(@Param("createDateStart") String createDateStart, @Param("createDateEnd") String createDateEnd);

然后再在SalesOrderProvider.class這個類里面寫方法

public String selectSalesInformation(@Param("createDateStart") String createDateStart, @Param("createDateEnd") String createDateEnd){
        StringBuffer sql = new StringBuffer();
        sql.append(" SELECT ORDER_STATUS,b.number,b.unit_price,a.CREATE_DATE FROM hl4pl_sales_order a join hl4pl_sales_order_goods b ");
        sql.append(" where a.ID=b.ID and a.CREATE_DATE BETWEEN #{createDateStart} and #{createDateEnd} ");
        sql.append(" HAVING ORDER_STATUS =8 or ORDER_STATUS =6 ");
        return sql.toString();
    }

最后就在實現(xiàn)類里面直接調(diào)用就好了。

public SalesInformaitonVo getSalesInformation(String createDateStart, String createDateEnd){
        List<SalesInformation> salesInformations = salesOrderMapper.selectSalesInformation(createDateStart,createDateEnd);
        BigDecimal salesVolume = BigDecimal.ZERO;//銷售額
        BigDecimal totalOrders = BigDecimal.ZERO;//訂單總量
        int totalSales = salesInformations.size();//銷售總量
        for (SalesInformation salesInformation : salesInformations) {
            if (salesInformation.getNumber()!=null&&salesInformation.getUnitPrice()!=null&&salesInformation.getNumber()!=BigDecimal.ZERO&&salesInformation.getUnitPrice()!=BigDecimal.ZERO){
                salesVolume = salesVolume.add(salesInformation.getNumber().multiply(salesInformation.getUnitPrice()));
                totalOrders = totalOrders.add(salesInformation.getNumber());
            }
        }
        SalesInformaitonVo salesInformaitonVo = new SalesInformaitonVo();
        salesVolume=salesVolume.divide(BigDecimal.valueOf(10000));
        BigDecimal bigDecimal = salesVolume.setScale(2, BigDecimal.ROUND_UP);//四舍五入兩位小數(shù)
        salesInformaitonVo.setSalesVolume(bigDecimal);
        salesInformaitonVo.setTotalOrders(totalOrders);
        salesInformaitonVo.setTotalSales(totalSales);
        return salesInformaitonVo;
    }

@Select @SelectProvider中使用foreach時不生效問題

問題

@Select @SelectProvider中使用<foreach>時不生效。

解決辦法

<foreach>、<when>等標簽屬于xml語法,必須配合<script>標簽使用。

@Select({"<script>",
    "SELECT * FROM tbl_order",
    "WHERE 1=1",
    "<when test='title!=null'>",
    "AND mydate = #{mydate}",
    "</when>",
    "</script>"})
List<ExpendVo> queryExpend(ExpendDto dto);

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 使用Java獲取文件樹的代碼實現(xiàn)

    使用Java獲取文件樹的代碼實現(xiàn)

    Java語言提供了豐富的庫和工具,使得我們可以方便地獲取和操作Java文件的語法樹(AST, Abstract Syntax Tree),在這篇博客中,我們將探討如何使用Java來獲取一個Java文件的語法樹,并展示詳細的代碼示例和運行結(jié)果,需要的朋友可以參考下
    2024-08-08
  • Spring?boot?使用QQ郵箱進行一個驗證登入功能

    Spring?boot?使用QQ郵箱進行一個驗證登入功能

    這篇文章主要介紹了Spring?boot?使用QQ郵箱進行一個驗證登入,主要包括qq郵箱開啟權(quán)限和創(chuàng)建發(fā)送驗證碼的請求Controller,本文通過示例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-10-10
  • java高并發(fā)的并發(fā)級別詳解

    java高并發(fā)的并發(fā)級別詳解

    這篇文章主要介紹了java高并發(fā)的并發(fā)級別,內(nèi)容十分豐富,在這里分享給大家,需要的朋友可以參考,希望能夠給你帶來幫助
    2021-10-10
  • 深入理解Java中的WeakHashMap

    深入理解Java中的WeakHashMap

    這篇文章主要介紹了深入理解Java中的WeakHashMap,WeakHashMap從名字可以得知主要和Map有關(guān),不過還有一個Weak,我們就更能自然而然的想到這里面還牽扯到一種弱引用結(jié)構(gòu),因此想要徹底搞懂,我們還需要知道四種引用,需要的朋友可以參考下
    2023-09-09
  • Spring?Boot項目獲取resources目錄下文件并返回給前端的方案

    Spring?Boot項目獲取resources目錄下文件并返回給前端的方案

    我們在項目中經(jīng)常碰到需要讀取固定文件的場景,如模板文件,一般做法是將文件放在resources目錄下,程序通過多種方式可以順利讀取文件,這篇文章主要給大家介紹了關(guān)于Spring?Boot項目獲取resources目錄下文件并返回給前端的相關(guān)資料,需要的朋友可以參考下
    2024-07-07
  • 微服務(wù)通過Feign調(diào)用進行密碼安全認證操作

    微服務(wù)通過Feign調(diào)用進行密碼安全認證操作

    這篇文章主要介紹了微服務(wù)通過Feign調(diào)用進行密碼安全認證操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • SpringBoot權(quán)限認證-Sa-Token的使用詳解

    SpringBoot權(quán)限認證-Sa-Token的使用詳解

    Sa-Token是一款輕量級Java權(quán)限認證框架,它簡化了權(quán)限管理,提高了開發(fā)效率,本文通過實例介紹了Sa-Token的基本概念、與其他框架的比較、基本語法和高級用法,并探討了其核心原理和實際應(yīng)用場景,感興趣的朋友一起看看吧
    2024-09-09
  • 詳解Java的call by value和call by reference

    詳解Java的call by value和call by reference

    在本篇文章里小編給大家總結(jié)了關(guān)于Java的call by value和call by reference的相關(guān)用法和知識點內(nèi)容,需要的朋友們學習下。
    2019-03-03
  • Java中的SkyWalking監(jiān)控告警詳解

    Java中的SkyWalking監(jiān)控告警詳解

    這篇文章主要介紹了Java中的SkyWalking監(jiān)控告警詳解,SkyWalking在6.x版本中新增了告警功能,其核心在于config/alarm-settings.yaml文件中,該文件分為rules和webhooks兩部分,需要的朋友可以參考下
    2023-11-11
  • springcloud gateway設(shè)置context-path的操作

    springcloud gateway設(shè)置context-path的操作

    這篇文章主要介紹了springcloud gateway設(shè)置context-path的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07

最新評論