mybatis 返回Map類型key改為小寫(xiě)的操作
默認(rèn)情況下,當(dāng)resultType=“java.util.Map”時(shí),返回的key值都是大寫(xiě)的。
現(xiàn)在想key改成自己想要的,只需為查詢出來(lái)的字段增加個(gè)別名即可。
如:
<select id="getStudentList" resultType="java.util.Map"> select t.name as "sName",t.sex as "sSex" from student </select>
as 后的雙引號(hào)很關(guān)鍵,否則不起作用。
補(bǔ)充知識(shí):mybatis返回map key值大小寫(xiě)去重,CaseInsensitiveMap、LinkedCaseInsensitiveMap源碼
今天在寫(xiě)項(xiàng)目的時(shí)候遇見(jiàn)一個(gè)問(wèn)題:
編寫(xiě)的是一套完全解耦的模塊,用于利用freemarker模板動(dòng)態(tài)拼接sql
然而拼接好的sql只能用LinkedHashMap返回結(jié)果集,保證數(shù)據(jù)有序,但是在數(shù)據(jù)輸出的時(shí)候,mybatis 返回了key 相同,但大小寫(xiě)不同的數(shù)據(jù),
在處理這個(gè)數(shù)據(jù)的時(shí)候,首先我選用了利用value值相同去做處理,但是有些數(shù)據(jù)的value值相同但是key不同
看來(lái)只能用key去做處理,首先我用了CaseInsensitiveMap 將linkedHashMap的數(shù)據(jù)放入到CaseInsensitiveMap 中,
輸出的時(shí)候結(jié)果確實(shí)起到了去重的效果,但是在excel導(dǎo)出的時(shí)候要對(duì)應(yīng)header標(biāo)題頭,mybatis 查詢的順序跟header 抬頭是對(duì)應(yīng)的,但是取出的順序卻不是對(duì)應(yīng)的,
因此只能通過(guò)排序進(jìn)行數(shù)據(jù)對(duì)應(yīng),但是排序的話只能使用LinkedHashMap去記住順序
因此查詢了資料發(fā)現(xiàn)了LinkedCaseInsensitiveMap
LinkedCaseInsensitiveMap 繼承了 LinkedHashMap,可以檢測(cè)關(guān)鍵字(不區(qū)分大小寫(xiě))的唯一性,所以 ok bug完美解決
附加 LinkedCaseInsensitiveMap 源碼
package org.springframework.util;
import java.util.HashMap;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.Locale;
import java.util.Map;
import java.util.Map.Entry;
public class LinkedCaseInsensitiveMap<V> extends LinkedHashMap<String, V> {
private Map<String, String> caseInsensitiveKeys;
private final Locale locale;
public LinkedCaseInsensitiveMap() {
this((Locale)null);
}
public LinkedCaseInsensitiveMap(Locale locale) {
this.caseInsensitiveKeys = new HashMap();
this.locale = locale != null?locale:Locale.getDefault();
}
public LinkedCaseInsensitiveMap(int initialCapacity) {
this(initialCapacity, (Locale)null);
}
public LinkedCaseInsensitiveMap(int initialCapacity, Locale locale) {
super(initialCapacity);
this.caseInsensitiveKeys = new HashMap(initialCapacity);
this.locale = locale != null?locale:Locale.getDefault();
}
public V put(String key, V value) {
String oldKey = (String)this.caseInsensitiveKeys.put(this.convertKey(key), key);
if(oldKey != null && !oldKey.equals(key)) {
super.remove(oldKey);
}
return super.put(key, value);
}
public void putAll(Map<? extends String, ? extends V> map) {
if(!map.isEmpty()) {
Iterator var2 = map.entrySet().iterator();
while(var2.hasNext()) {
Entry entry = (Entry)var2.next();
this.put((String)entry.getKey(), entry.getValue());
}
}
}
public boolean containsKey(Object key) {
return key instanceof String && this.caseInsensitiveKeys.containsKey(this.convertKey((String)key));
}
public V get(Object key) {
if(key instanceof String) {
String caseInsensitiveKey = (String)this.caseInsensitiveKeys.get(this.convertKey((String)key));
if(caseInsensitiveKey != null) {
return super.get(caseInsensitiveKey);
}
}
return null;
}
public V getOrDefault(Object key, V defaultValue) {
if(key instanceof String) {
String caseInsensitiveKey = (String)this.caseInsensitiveKeys.get(this.convertKey((String)key));
if(caseInsensitiveKey != null) {
return super.get(caseInsensitiveKey);
}
}
return defaultValue;
}
public V remove(Object key) {
if(key instanceof String) {
String caseInsensitiveKey = (String)this.caseInsensitiveKeys.remove(this.convertKey((String)key));
if(caseInsensitiveKey != null) {
return super.remove(caseInsensitiveKey);
}
}
return null;
}
public void clear() {
this.caseInsensitiveKeys.clear();
super.clear();
}
public Object clone() {
LinkedCaseInsensitiveMap copy = (LinkedCaseInsensitiveMap)super.clone();
copy.caseInsensitiveKeys = new HashMap(this.caseInsensitiveKeys);
return copy;
}
protected String convertKey(String key) {
return key.toLowerCase(this.locale);
}
}
以上這篇mybatis 返回Map類型key改為小寫(xiě)的操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot2.0整合jackson配置日期格式化和反序列化的實(shí)現(xiàn)
這篇文章主要介紹了SpringBoot2.0整合jackson配置日期格式化和反序列化的實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-11-11
Java遞歸算法詳解(動(dòng)力節(jié)點(diǎn)整理)
Java遞歸算法是基于Java語(yǔ)言實(shí)現(xiàn)的遞歸算法。遞歸算法對(duì)解決一大類問(wèn)題很有效,它可以使算法簡(jiǎn)潔和易于理解。接下來(lái)通過(guò)本文給大家介紹Java遞歸算法相關(guān)知識(shí),感興趣的朋友一起學(xué)習(xí)吧2017-03-03
詳解JAVAEE——SSH三大框架整合(spring+struts2+hibernate)
這篇文章主要介紹了詳解JAVAEE——SSH三大框架整合(spring+struts2+hibernate),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07
Java實(shí)現(xiàn)檢查多個(gè)時(shí)間段是否有重合
這篇文章主要為大家詳細(xì)介紹了如何使用Java實(shí)現(xiàn)檢查多個(gè)時(shí)間段是否有重合,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-02-02
Java Quartz觸發(fā)器CronTriggerBean配置用法詳解
這篇文章主要介紹了Java Quartz觸發(fā)器CronTriggerBean配置用法詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
Maven實(shí)現(xiàn)項(xiàng)目構(gòu)建工具
本文主要介紹了Maven實(shí)現(xiàn)項(xiàng)目構(gòu)建工具,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07
Spring Cloud EureKa Ribbon 服務(wù)注冊(cè)發(fā)現(xiàn)與調(diào)用
這篇文章主要介紹了Spring Cloud EureKa Ribbon 服務(wù)注冊(cè)發(fā)現(xiàn)與調(diào)用,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-02-02
SpringData整合ElasticSearch實(shí)現(xiàn)CRUD的示例代碼(超詳細(xì))
本文主要介紹了SpringData整合ElasticSearch實(shí)現(xiàn)CRUD的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07

