MyBatis Map結(jié)果的Key轉(zhuǎn)為駝峰式
MyBatis 配置文件中,支持下面這幾種配置:
properties, settings, typeAliases, typeHandlers,
objectFactory, objectWrapperFactory, reflectorFactory,
plugins, environments, databaseIdProvider, mappers
我們使用objectWrapperFactory
來解決這個問題。
配置這個屬性時,必須遵守上面屬性配置的順序進行配置(在objectFactory
后面,在reflectorFactory
前面),否則就會出錯。
objectWrapperFactory 接口如下:
public interface ObjectWrapperFactory { boolean hasWrapperFor(Object object); ObjectWrapper getWrapperFor(MetaObject metaObject, Object object); }
通過實現(xiàn)這個接口,可以判斷當(dāng)object
是Map
類型時,返回true
,然后在下面的getWrapperFor
中返回一個可以處理 key 為駝峰的Wrapper 類即可。
首先,參考已有的MapWrapper
實現(xiàn)自己的MyWrapper
:
package tk.mybatis; import org.apache.ibatis.reflection.MetaObject; import org.apache.ibatis.reflection.wrapper.MapWrapper; import java.util.Map; /** * 駝峰處理 */ public class MyMapWrapper extends MapWrapper { public MyMapWrapper(MetaObject metaObject, Map<String, Object> map) { super(metaObject, map); } @Override public String findProperty(String name, boolean useCamelCaseMapping) { if (useCamelCaseMapping && ((name.charAt(0) >= 'A' && name.charAt(0) <= 'Z') || name.indexOf("_") >= 0)) { return underlineToCamelhump(name); } return name; } /** * 將下劃線風(fēng)格替換為駝峰風(fēng)格 * @param inputString * @return */ public String underlineToCamelhump(String inputString) { StringBuilder sb = new StringBuilder(); boolean nextUpperCase = false; for (int i = 0; i < inputString.length(); i++) { char c = inputString.charAt(i); if (c == '_') { if (sb.length() > 0) { nextUpperCase = true; } } else { if (nextUpperCase) { sb.append(Character.toUpperCase(c)); nextUpperCase = false; } else { sb.append(Character.toLowerCase(c)); } } } return sb.toString(); } }
這種方式實現(xiàn)起來很容易。然后提供ObjectWrapperFactory
實現(xiàn)類:
package tk.mybatis; import org.apache.ibatis.reflection.MetaObject; import org.apache.ibatis.reflection.wrapper.ObjectWrapper; import org.apache.ibatis.reflection.wrapper.ObjectWrapperFactory; import java.util.Map; /** * Map 類型結(jié)果轉(zhuǎn)駝峰 */ public class MapWrapperFactory implements ObjectWrapperFactory { @Override public boolean hasWrapperFor(Object object) { return object != null && object instanceof Map; } @Override public ObjectWrapper getWrapperFor(MetaObject metaObject, Object object) { return new MyMapWrapper(metaObject, (Map) object); } }
仍然很簡單,在 MyBatis 配置文件中配置上objectWrapperFactory
:
<objectWrapperFactory type="tk.mybatis.MapWrapperFactory"/>
因為代碼中判斷了useCamelCaseMapping
,所以想要真正能夠使用這個功能,還需要在settings
中增加如下配置:
<settings> <setting name="mapUnderscoreToCamelCase" value="true"/> <!-- 其他配置 --> </settings>
這種方式不需要使用攔截器,而且直接從源頭對Map
的key 進行處理,不會產(chǎn)生任何額外的消耗,如果你經(jīng)常設(shè)置返回值resultType
為map,可以嘗試該方法。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
相關(guān)文章
Spring Boot基于Active MQ實現(xiàn)整合JMS
這篇文章主要介紹了Spring Boot基于Active MQ實現(xiàn)整合JMS,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-07-07java實現(xiàn)Spring在XML配置java類的方法
下面小編就為大家?guī)硪黄猨ava實現(xiàn)Spring在XML配置java類的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11Springdoc替換swagger的實現(xiàn)步驟分解
最近在spring看到的,spring要對api文檔動手了,有些人說swagger不好用,其實也沒那么不好用,有人說代碼還是有點侵入性,這倒是真的,我剛試了springdoc可以說還是有侵入性但是也可以沒有侵入性,這就看你對文檔有什么要求了2023-02-02Java 并發(fā)編程學(xué)習(xí)筆記之核心理論基礎(chǔ)
編寫優(yōu)質(zhì)的并發(fā)代碼是一件難度極高的事情。Java語言從第一版本開始內(nèi)置了對多線程的支持,這一點在當(dāng)年是非常了不起的,但是當(dāng)我們對并發(fā)編程有了更深刻的認(rèn)識和更多的實踐后,實現(xiàn)并發(fā)編程就有了更多的方案和更好的選擇。本文是對并發(fā)編程的核心理論做了下小結(jié)2016-05-05Java使用異或運算實現(xiàn)簡單的加密解密算法實例代碼
這篇文章主要介紹了Java使用異或運算實現(xiàn)簡單的加密解密算法實例代碼,具有一定借鑒價值,需要的朋友可以參考下。2017-12-12