亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

SQL返回Map集合或者對象的操作

 更新時間:2021年07月19日 09:34:32   作者:無關痛癢qaq  
這篇文章主要介紹了SQL返回Map集合或者對象的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

需求:

在下面的sql中我們需要返回一個sum函數(shù)和一個count函數(shù),因為兩個返回的值都不是表中的字段,所以這里需要考慮的是我的sql返回值類型應該是什么?

在這里插入圖片描述

在日常的開發(fā)中,遇到這種問題我們首先會想到兩種返回值類型,一種是將total和num設置為key,封裝到map中。

另一種是封裝一個對象,將total和num設置為這個對象的兩個成員變量,下面描述一下使用這兩種方法在分層開發(fā)中各個層中的用法。

方法一:使用對象作為返回值類型

1.首先封裝一個對象

在這里插入圖片描述

可以看到這個對象中的num和total兩個成員變量就是我們sql語句中的兩個返回值(total是sum函數(shù)的別名,num是count函數(shù)的別名)

2.controller層

在controller層中,就是這行代碼最終使用了上面的sql語句與數(shù)據(jù)庫進行交互,他的返回值類型是RedPackCountBo,也就是我們封裝的對象。

在這里插入圖片描述

3.service層

service層的返回值也是這個對象,不做贅述

在這里插入圖片描述

4.serviceImpl層

在這里插入圖片描述

5.mapper.java層

在這里插入圖片描述

6.mapper.xml層(重點)

在這里插入圖片描述

使用這種方法我們就能將total和Num以對象的形式返回到controller層,在需要使用這兩個值的地方我們直接使用對象取值的方式獲取就可以了。

在這里再說一個點:

如果需要傳遞一個以上的參數(shù)到sql語句中的時候,可以使用@param()注解或者封裝到map集合中以map的形式傳遞到sql。我在這里一共傳遞了三個參數(shù),使用了map的形式將參數(shù)進行封裝,所以sql語句中的parameterType是java.util.Map

在這里插入圖片描述

方法二:使用Map作為返回值類型

1.controller層

在這里插入圖片描述

2.service層

在這里插入圖片描述

3.serviceImpl層

在這里插入圖片描述

4.mapper.java層

在這里插入圖片描述

5.mapper.xml層

在這里插入圖片描述

通過這種方法也可以實現(xiàn)需求,但是我個人覺得封住一個對象(也就是方法一)用的更爽,因為封裝map可能會因為你最終需求的數(shù)據(jù)類型不同來進行一系列的數(shù)據(jù)類型轉換,可能會出現(xiàn)java.lang.classCastException(類型轉換異常)

我在使用map作為返回值類型的時候,從數(shù)據(jù)庫中返回的count函數(shù)值(也就是num)的數(shù)據(jù)類型是Long型,sum函數(shù)(也就是total)返回值類型是BigDecimal類型(使用Object的getClass()方法可以查看數(shù)據(jù)類型),然后自己又做了類型轉換。

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

相關文章

  • 基于HttpServletResponse 相關常用方法的應用

    基于HttpServletResponse 相關常用方法的應用

    本篇文章小編為大家介紹,基于HttpServletResponse 相關常用方法的應用,需要的朋友參考下
    2013-04-04
  • Java synchronized的鎖升級過程詳解

    Java synchronized的鎖升級過程詳解

    在 JDK 1.6之前,synchronized 是一個重量級、效率比較低下的鎖,但是在JDK 1.6后,JVM 為了提高鎖的獲取與釋放效,,對 synchronized 進行了優(yōu)化,所以本文給大家介紹了synchronized的鎖升級過程,需要的朋友可以參考下
    2024-04-04
  • 兩種實現(xiàn)Java類隔離加載的方法

    兩種實現(xiàn)Java類隔離加載的方法

    這篇文章主要介紹了兩種實現(xiàn)Java類隔離加載的方法,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下
    2021-02-02
  • Spring?Bean名稱不會被代理的命名技巧

    Spring?Bean名稱不會被代理的命名技巧

    Spring Bean一些使用小細節(jié)就是在不斷的源碼探索中逐步發(fā)現(xiàn)的,今天就來和小伙伴們聊一下通過 beanName 的設置,可以讓一個 bean 拒絕被代理
    2023-11-11
  • Java如何將json字符串與實體類互相轉換

    Java如何將json字符串與實體類互相轉換

    在我們調(diào)用三方平臺接口時,經(jīng)常需要將我們封裝的實體類轉換為json作為傳參,下面這篇文章主要給大家介紹了關于Java如何將json字符串與實體類互相轉換的相關資料,需要的朋友可以參考下
    2023-11-11
  • Java實現(xiàn)JSON與XML相互轉換的簡明教程

    Java實現(xiàn)JSON與XML相互轉換的簡明教程

    Java實現(xiàn)復雜數(shù)據(jù)結構(如嵌套對象、數(shù)組)在 JSON 與 XML 之間的相互轉換,可以使用 Jackson 和 Jackson XML 擴展庫來完成,Jackson 是一個流行的 JSON 處理庫,通過 Jackson 的 XML 擴展庫,可以實現(xiàn) JSON 和 XML 之間的轉換,需要的朋友可以參考下
    2024-08-08
  • java8中的Collectors.groupingBy用法詳解

    java8中的Collectors.groupingBy用法詳解

    這篇文章主要介紹了java8中的Collectors.groupingBy用法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • mybatis-plus中wrapper的用法實例詳解

    mybatis-plus中wrapper的用法實例詳解

    本文給大家介紹了mybatis-plus中wrapper的用法,包括條件構造器關系、項目實例及具體使用操作,本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-02-02
  • JavaSE、JavaEE和JavaWeb三大工程目錄詳解

    JavaSE、JavaEE和JavaWeb三大工程目錄詳解

    這篇文章主要給大家介紹了關于JavaSE、JavaEE和JavaWeb三大工程目錄的相關資料,很多對java不是很了解的同學在看到課程?綱的時候發(fā)現(xiàn)??出現(xiàn)了JavaSE、JavaEE、JavaME、JavaWEB這些詞,搞得?頭霧?,需要的朋友可以參考下
    2023-07-07
  • MongoDB中ObjectId的誤區(qū)及引起的一系列問題

    MongoDB中ObjectId的誤區(qū)及引起的一系列問題

    這篇文章主要介紹了MongoDB中ObjectId的誤區(qū)及引起的一系列問題,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-12-12

最新評論