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ù)據庫進行交互,他的返回值類型是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ù)據類型不同來進行一系列的數(shù)據類型轉換,可能會出現(xiàn)java.lang.classCastException(類型轉換異常)
我在使用map作為返回值類型的時候,從數(shù)據庫中返回的count函數(shù)值(也就是num)的數(shù)據類型是Long型,sum函數(shù)(也就是total)返回值類型是BigDecimal類型(使用Object的getClass()方法可以查看數(shù)據類型),然后自己又做了類型轉換。
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
SpringBoot整合Logback日志框架及高并發(fā)下的性能優(yōu)化
在現(xiàn)代的Java應用開發(fā)中,日志記錄是不可或缺的一部分,Spring Boot作為目前最流行的Java開發(fā)框架之一,默認集成了Logback作為日志框架,Logback是Log4j的繼任者,具有更高的性能和更豐富的功能,本文將詳細介紹如何在Spring Boot中整合Logback日志框架2025-03-03
Spring mvc Controller和RestFul原理解析
這篇文章主要介紹了Spring mvc Controller和RestFul原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-03-03
SpringBoot項目整合jasypt實現(xiàn)過程詳解
這篇文章主要介紹了SpringBoot項目整合jasypt實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-08-08
spring boot tomcat版本升級的實現(xiàn)示例
本文主要介紹了spring boot tomcat版本升級的實現(xiàn)示例,將tomcat升級一個小版本升級到9.0.44版本,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-11-11
使用Spring Data R2DBC +Postgres實現(xiàn)增刪改查功能
這篇文章主要介紹了使用Spring Data R2DBC +Postgres實現(xiàn)增刪改查功能,本文通過兩種方法給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03

