Mybatis返回map集合時,列的順序與select不一致問題
返回map集合,列的順序與select不一致
<select id="queryPercentByAsset" resultType="java.util.HashMap">
將Hashmap換成LinkedHashMap即可
<select id="queryPercentByAsset" resultType="java.util.LinkedHashMap">
mybatis中返回map集合問題
關(guān)于mybatis返回map集合的操作:
1.mapper.xml中寫一個查詢返回map的sql
<select id="findMap" parameterType="com.sxd.swapping.domain.HuaYangArea" resultType="java.util.HashMap">
select
hy.uid,
hy.area_name
from
hua_yang_area AS hy
<where>
<if test="areaPerson != null">
AND hy.area_person >= #{areaPerson}
</if>
</where>
</select>2.mapper.java 對應(yīng)接收
注意,這里并不是直接使用Map<>接收,因為sql查出的不是一條數(shù)據(jù),而是多條數(shù)據(jù),所以是List<Map<>>接收
/**
* mybatis 查詢接收map集合
* @param area
* @return
*/
List<Map<String,String>> findMap(HuaYangArea area);3.錯誤寫法
錯誤的寫法就是直接讀取List中的Map<>
@Override
public Map<String, String> findMap(HuaYangArea entity) {
List<Map<String,String>> list = huaYangAreaMapper.findMap(entity);
Map<String,String> res = new HashMap<>();
for (Map<String, String> stringStringMap : list) {
System.out.println(stringStringMap.toString());
stringStringMap.forEach((k,v)->{
System.out.println("key:"+k+">>>value:"+v);
res.put(k,v);
});
}
return res;
}這樣查詢到的結(jié)果是:

我們需要看一哈實際List<Map<>>中到底存儲的是什么

結(jié)果集中存儲是按照{字段名1:字段值1,字段名2:字段值2}
而我們其實期望的是{字段值1:字段值2}
4.正確寫法
所以正確的寫法應(yīng)該是
@Override
public Map<String, String> findMap(HuaYangArea entity) {
List<Map<String,String>> list = huaYangAreaMapper.findMap(entity);
Map<String,String> res = new HashMap<>();
for (Map<String, String> stringStringMap : list) {
System.out.println(stringStringMap.toString());
String uid = null;
String areaName = null;
for (Map.Entry<String,String> entry:stringStringMap.entrySet()){
if ("uid".equals(entry.getKey())){
uid = entry.getValue();
}else {
areaName = entry.getValue();
}
}
res.put(uid,areaName);
}
return res;
}返回結(jié)果:

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java連接數(shù)據(jù)庫JDBC技術(shù)之prepareStatement的詳細介紹
這篇文章主要介紹了Java連接數(shù)據(jù)庫JDBC技術(shù)之prepareStatement的詳細介紹,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-07-07
Spring Security 實現(xiàn)短信驗證碼登錄功能
這篇文章主要介紹了Spring Security 實現(xiàn)短信驗證碼登錄功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05
深入學習java并發(fā)包ConcurrentHashMap源碼
這篇文章主要介紹了深入學習java并發(fā)包ConcurrentHashMap源碼,整個 ConcurrentHashMap 由一個個 Segment 組成,Segment 代表”部分“或”一段“的意思,所以很多地方都會將其描述為分段鎖。,需要的朋友可以參考下2019-06-06
SpringBoot如何根據(jù)目錄結(jié)構(gòu)生成API接口前綴
這篇文章主要介紹了SpringBoot如何根據(jù)目錄結(jié)構(gòu)生成API接口前綴,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-02-02

