MyBatis將查詢出的兩列數(shù)據(jù)裝配成鍵值對的操作方法
描述:
MyBatis 直接查詢出的格式是 List 套 Map 的結(jié)構(gòu),當然利用 Stream 流進行轉(zhuǎn)換也非常便捷,但如果這樣的操作很多的話,不如利用 MyBatis 提供的 ResultHandler 接口進行實現(xiàn),做成工具類使用。
此外,如果用 MyBatis 提供的 @MapKey ,也只是對應(yīng)值有冗余,因為 MapKey取一個字段為鍵,取出的所有字段為值。
操作:
1. 實現(xiàn) ResultHandler 接口
/** * 用于MyBatis查詢庫表中兩列映射為鍵值對 */ @Component public class MapResultHandler implements ResultHandler { private final HashMap mapResults = new HashMap<String,String>(); private String key; private String value; @Override public void handleResult(ResultContext resultContext) { HashMap map = (HashMap)resultContext.getResultObject(); mapResults.put(map.get("key"), map.get("value")); } /** * 返回映射 * @return 結(jié)果 */ public HashMap getMapResults() { return mapResults; } /** * @param key key * @param value value */ public MapResultHandler(String key, String value) { this.key = key; this.value = value; } /** * 空構(gòu)造 */ public MapResultHandler() { } }
2. 對應(yīng) DAO 層
對應(yīng) mapper 查詢接口中,在查詢的方法里將 ResultHandler 實現(xiàn)類(MapResultHandler)以參數(shù)形式傳入。
由于使用實現(xiàn)類拿取裝配好的Map,此處的返回類型為 void 。
/** * 提取<圖片名,創(chuàng)建時間>的Map,對應(yīng)創(chuàng)建時間進行處理 * @param imageLength 上傳圖片的個數(shù) * @return */ void selectImageNameAndCreatetime(MapResultHandler mapResultHandler, int imageLength);
對應(yīng) xml 文件中,定義返回類型為 map 。
其中注意給我們需要的鍵值取別名,對應(yīng)別名與 ResultHandler 實現(xiàn)類(MapResultHandler)中定義的相對應(yīng),這樣在ResultHandler 實現(xiàn)類(MapResultHandler)中 map.get() 才能取到。
<select id="selectImageNameAndCreatetime" resultType="map"> select name as 'key',time as 'value' from house_pic_info order by id desc limit #{imageLength} </select>
3. 使用
先實例化 ResultHandler 實現(xiàn)類(MapResultHandler),作為參數(shù)傳入。
取 Map 時依然從 ResultHandler 實現(xiàn)類(MapResultHandler)中取。
MapResultHandler handler = new MapResultHandler(); housePicInfoMapper.selectImageNameAndCreatetime(handler, length); Map imageMap = handler.getMapResults();
思考:對應(yīng) ResultHandler 接口只需實現(xiàn)一個 handleResult 方法,在 MyBatis 中 @MapKey 的實現(xiàn)也應(yīng)該是有對應(yīng)實現(xiàn)。
/** * MyBatis 中 DefaultMapResultHandler 實現(xiàn) * @author Clinton Begin */ public class DefaultMapResultHandler<K, V> implements ResultHandler<V> { private final Map<K, V> mappedResults; private final String mapKey; private final ObjectFactory objectFactory; private final ObjectWrapperFactory objectWrapperFactory; private final ReflectorFactory reflectorFactory; @SuppressWarnings("unchecked") public DefaultMapResultHandler(String mapKey, ObjectFactory objectFactory, ObjectWrapperFactory objectWrapperFactory, ReflectorFactory reflectorFactory) { this.objectFactory = objectFactory; this.objectWrapperFactory = objectWrapperFactory; this.reflectorFactory = reflectorFactory; this.mappedResults = objectFactory.create(Map.class); this.mapKey = mapKey; } @Override public void handleResult(ResultContext<? extends V> context) { final V value = context.getResultObject(); final MetaObject mo = MetaObject.forObject(value, objectFactory, objectWrapperFactory, reflectorFactory); // TODO is that assignment always true? final K key = (K) mo.getValue(mapKey); mappedResults.put(key, value); } public Map<K, V> getMappedResults() { return mappedResults; } }
到此這篇關(guān)于MyBatis將查詢出的兩列數(shù)據(jù)裝配成鍵值對的文章就介紹到這了,更多相關(guān)MyBatis查詢數(shù)據(jù)裝配成鍵值對內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java基礎(chǔ)實現(xiàn)猜數(shù)字小游戲
這篇文章主要為大家詳細介紹了java基礎(chǔ)實現(xiàn)猜數(shù)字小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-11-11Netty分布式抽象編碼器MessageToByteEncoder邏輯分析
這篇文章主要介紹了Netty分布式抽象編碼器MessageToByteEncoder的抽象邏輯分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-03-03如何用ObjectMapper將復(fù)雜Map轉(zhuǎn)換為實體類
這篇文章主要介紹了如何用ObjectMapper將復(fù)雜Map轉(zhuǎn)換為實體類的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08RestTemplate get請求攜帶headers自動拼接參數(shù)方式
這篇文章主要介紹了RestTemplate get請求攜帶headers自動拼接參數(shù)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07springboot+vue實現(xiàn)七牛云頭像的上傳
本文將介紹如何在Spring Boot項目中利用七牛云進行圖片上傳并將圖片存儲在云存儲中,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08springboot設(shè)置加載靜態(tài)資源的路徑(spring.resources.static-locations)
這篇文章主要介紹了springboot設(shè)置加載靜態(tài)資源的路徑方式(spring.resources.static-locations),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08