SQL返回Map集合或者對(duì)象的操作
需求:
在下面的sql中我們需要返回一個(gè)sum函數(shù)和一個(gè)count函數(shù),因?yàn)閮蓚€(gè)返回的值都不是表中的字段,所以這里需要考慮的是我的sql返回值類(lèi)型應(yīng)該是什么?
在日常的開(kāi)發(fā)中,遇到這種問(wèn)題我們首先會(huì)想到兩種返回值類(lèi)型,一種是將total和num設(shè)置為key,封裝到map中。
另一種是封裝一個(gè)對(duì)象,將total和num設(shè)置為這個(gè)對(duì)象的兩個(gè)成員變量,下面描述一下使用這兩種方法在分層開(kāi)發(fā)中各個(gè)層中的用法。
方法一:使用對(duì)象作為返回值類(lèi)型
1.首先封裝一個(gè)對(duì)象
可以看到這個(gè)對(duì)象中的num和total兩個(gè)成員變量就是我們sql語(yǔ)句中的兩個(gè)返回值(total是sum函數(shù)的別名,num是count函數(shù)的別名)
2.controller層
在controller層中,就是這行代碼最終使用了上面的sql語(yǔ)句與數(shù)據(jù)庫(kù)進(jìn)行交互,他的返回值類(lèi)型是RedPackCountBo,也就是我們封裝的對(duì)象。
3.service層
service層的返回值也是這個(gè)對(duì)象,不做贅述
4.serviceImpl層
5.mapper.java層
6.mapper.xml層(重點(diǎn))
使用這種方法我們就能將total和Num以對(duì)象的形式返回到controller層,在需要使用這兩個(gè)值的地方我們直接使用對(duì)象取值的方式獲取就可以了。
在這里再說(shuō)一個(gè)點(diǎn):
如果需要傳遞一個(gè)以上的參數(shù)到sql語(yǔ)句中的時(shí)候,可以使用@param()注解或者封裝到map集合中以map的形式傳遞到sql。我在這里一共傳遞了三個(gè)參數(shù),使用了map的形式將參數(shù)進(jìn)行封裝,所以sql語(yǔ)句中的parameterType是java.util.Map
方法二:使用Map作為返回值類(lèi)型
1.controller層
2.service層
3.serviceImpl層
4.mapper.java層
5.mapper.xml層
通過(guò)這種方法也可以實(shí)現(xiàn)需求,但是我個(gè)人覺(jué)得封住一個(gè)對(duì)象(也就是方法一)用的更爽,因?yàn)榉庋bmap可能會(huì)因?yàn)槟阕罱K需求的數(shù)據(jù)類(lèi)型不同來(lái)進(jìn)行一系列的數(shù)據(jù)類(lèi)型轉(zhuǎn)換,可能會(huì)出現(xiàn)java.lang.classCastException(類(lèi)型轉(zhuǎn)換異常)
我在使用map作為返回值類(lèi)型的時(shí)候,從數(shù)據(jù)庫(kù)中返回的count函數(shù)值(也就是num)的數(shù)據(jù)類(lèi)型是Long型,sum函數(shù)(也就是total)返回值類(lèi)型是BigDecimal類(lèi)型(使用Object的getClass()方法可以查看數(shù)據(jù)類(lèi)型),然后自己又做了類(lèi)型轉(zhuǎn)換。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
基于HttpServletResponse 相關(guān)常用方法的應(yīng)用
本篇文章小編為大家介紹,基于HttpServletResponse 相關(guān)常用方法的應(yīng)用,需要的朋友參考下2013-04-04Java synchronized的鎖升級(jí)過(guò)程詳解
在 JDK 1.6之前,synchronized 是一個(gè)重量級(jí)、效率比較低下的鎖,但是在JDK 1.6后,JVM 為了提高鎖的獲取與釋放效,,對(duì) synchronized 進(jìn)行了優(yōu)化,所以本文給大家介紹了synchronized的鎖升級(jí)過(guò)程,需要的朋友可以參考下2024-04-04兩種實(shí)現(xiàn)Java類(lèi)隔離加載的方法
這篇文章主要介紹了兩種實(shí)現(xiàn)Java類(lèi)隔離加載的方法,幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下2021-02-02Spring?Bean名稱(chēng)不會(huì)被代理的命名技巧
Spring Bean一些使用小細(xì)節(jié)就是在不斷的源碼探索中逐步發(fā)現(xiàn)的,今天就來(lái)和小伙伴們聊一下通過(guò) beanName 的設(shè)置,可以讓一個(gè) bean 拒絕被代理2023-11-11Java如何將json字符串與實(shí)體類(lèi)互相轉(zhuǎn)換
在我們調(diào)用三方平臺(tái)接口時(shí),經(jīng)常需要將我們封裝的實(shí)體類(lèi)轉(zhuǎn)換為json作為傳參,下面這篇文章主要給大家介紹了關(guān)于Java如何將json字符串與實(shí)體類(lèi)互相轉(zhuǎn)換的相關(guān)資料,需要的朋友可以參考下2023-11-11Java實(shí)現(xiàn)JSON與XML相互轉(zhuǎn)換的簡(jiǎn)明教程
Java實(shí)現(xiàn)復(fù)雜數(shù)據(jù)結(jié)構(gòu)(如嵌套對(duì)象、數(shù)組)在 JSON 與 XML 之間的相互轉(zhuǎn)換,可以使用 Jackson 和 Jackson XML 擴(kuò)展庫(kù)來(lái)完成,Jackson 是一個(gè)流行的 JSON 處理庫(kù),通過(guò) Jackson 的 XML 擴(kuò)展庫(kù),可以實(shí)現(xiàn) JSON 和 XML 之間的轉(zhuǎn)換,需要的朋友可以參考下2024-08-08java8中的Collectors.groupingBy用法詳解
這篇文章主要介紹了java8中的Collectors.groupingBy用法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03mybatis-plus中wrapper的用法實(shí)例詳解
本文給大家介紹了mybatis-plus中wrapper的用法,包括條件構(gòu)造器關(guān)系、項(xiàng)目實(shí)例及具體使用操作,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-02-02MongoDB中ObjectId的誤區(qū)及引起的一系列問(wèn)題
這篇文章主要介紹了MongoDB中ObjectId的誤區(qū)及引起的一系列問(wèn)題,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12