您好,登錄后才能下訂單哦!
本篇內容介紹了“SQL返回Map集合或者對象的方法”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
在下面的sql中我們需要返回一個sum函數和一個count函數,因為兩個返回的值都不是表中的字段,所以這里需要考慮的是我的sql返回值類型應該是什么?
在日常的開發中,遇到這種問題我們首先會想到兩種返回值類型,一種是將total和num設置為key,封裝到map中。
另一種是封裝一個對象,將total和num設置為這個對象的兩個成員變量,下面描述一下使用這兩種方法在分層開發中各個層中的用法。
可以看到這個對象中的num和total兩個成員變量就是我們sql語句中的兩個返回值(total是sum函數的別名,num是count函數的別名)
在controller層中,就是這行代碼最終使用了上面的sql語句與數據庫進行交互,他的返回值類型是RedPackCountBo,也就是我們封裝的對象。
service層的返回值也是這個對象,不做贅述
使用這種方法我們就能將total和Num以對象的形式返回到controller層,在需要使用這兩個值的地方我們直接使用對象取值的方式獲取就可以了。
在這里再說一個點:
如果需要傳遞一個以上的參數到sql語句中的時候,可以使用@param()注解或者封裝到map集合中以map的形式傳遞到sql。我在這里一共傳遞了三個參數,使用了map的形式將參數進行封裝,所以sql語句中的parameterType是java.util.Map
通過這種方法也可以實現需求,但是我個人覺得封住一個對象(也就是方法一)用的更爽,因為封裝map可能會因為你最終需求的數據類型不同來進行一系列的數據類型轉換,可能會出現java.lang.classCastException(類型轉換異常)
我在使用map作為返回值類型的時候,從數據庫中返回的count函數值(也就是num)的數據類型是Long型,sum函數(也就是total)返回值類型是BigDecimal類型(使用Object的getClass()方法可以查看數據類型),然后自己又做了類型轉換。
“SQL返回Map集合或者對象的方法”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。