MyBatis將查詢(xún)出的兩列數(shù)據(jù)裝配成鍵值對(duì)的操作方法
描述:
MyBatis 直接查詢(xún)出的格式是 List 套 Map 的結(jié)構(gòu),當(dāng)然利用 Stream 流進(jìn)行轉(zhuǎn)換也非常便捷,但如果這樣的操作很多的話,不如利用 MyBatis 提供的 ResultHandler 接口進(jìn)行實(shí)現(xiàn),做成工具類(lèi)使用。
此外,如果用 MyBatis 提供的 @MapKey ,也只是對(duì)應(yīng)值有冗余,因?yàn)?MapKey取一個(gè)字段為鍵,取出的所有字段為值。
操作:
1. 實(shí)現(xiàn) ResultHandler 接口
/** * 用于MyBatis查詢(xún)庫(kù)表中兩列映射為鍵值對(duì) */ @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. 對(duì)應(yīng) DAO 層
對(duì)應(yīng) mapper 查詢(xún)接口中,在查詢(xún)的方法里將 ResultHandler 實(shí)現(xiàn)類(lèi)(MapResultHandler)以參數(shù)形式傳入。
由于使用實(shí)現(xiàn)類(lèi)拿取裝配好的Map,此處的返回類(lèi)型為 void 。
/** * 提取<圖片名,創(chuàng)建時(shí)間>的Map,對(duì)應(yīng)創(chuàng)建時(shí)間進(jìn)行處理 * @param imageLength 上傳圖片的個(gè)數(shù) * @return */ void selectImageNameAndCreatetime(MapResultHandler mapResultHandler, int imageLength);
對(duì)應(yīng) xml 文件中,定義返回類(lèi)型為 map 。
其中注意給我們需要的鍵值取別名,對(duì)應(yīng)別名與 ResultHandler 實(shí)現(xiàn)類(lèi)(MapResultHandler)中定義的相對(duì)應(yīng),這樣在ResultHandler 實(shí)現(xiàn)類(lèi)(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. 使用
先實(shí)例化 ResultHandler 實(shí)現(xiàn)類(lèi)(MapResultHandler),作為參數(shù)傳入。
取 Map 時(shí)依然從 ResultHandler 實(shí)現(xiàn)類(lèi)(MapResultHandler)中取。
MapResultHandler handler = new MapResultHandler(); housePicInfoMapper.selectImageNameAndCreatetime(handler, length); Map imageMap = handler.getMapResults();
思考:對(duì)應(yīng) ResultHandler 接口只需實(shí)現(xiàn)一個(gè) handleResult 方法,在 MyBatis 中 @MapKey 的實(shí)現(xiàn)也應(yīng)該是有對(duì)應(yīng)實(shí)現(xiàn)。
/** * MyBatis 中 DefaultMapResultHandler 實(shí)現(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將查詢(xún)出的兩列數(shù)據(jù)裝配成鍵值對(duì)的文章就介紹到這了,更多相關(guān)MyBatis查詢(xún)數(shù)據(jù)裝配成鍵值對(duì)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java基礎(chǔ)實(shí)現(xiàn)猜數(shù)字小游戲
這篇文章主要為大家詳細(xì)介紹了java基礎(chǔ)實(shí)現(xiàn)猜數(shù)字小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11Netty分布式抽象編碼器MessageToByteEncoder邏輯分析
這篇文章主要介紹了Netty分布式抽象編碼器MessageToByteEncoder的抽象邏輯分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-03-03如何用ObjectMapper將復(fù)雜Map轉(zhuǎn)換為實(shí)體類(lèi)
這篇文章主要介紹了如何用ObjectMapper將復(fù)雜Map轉(zhuǎn)換為實(shí)體類(lèi)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08RestTemplate get請(qǐng)求攜帶headers自動(dòng)拼接參數(shù)方式
這篇文章主要介紹了RestTemplate get請(qǐng)求攜帶headers自動(dòng)拼接參數(shù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07springboot+vue實(shí)現(xiàn)七牛云頭像的上傳
本文將介紹如何在Spring Boot項(xiàng)目中利用七牛云進(jìn)行圖片上傳并將圖片存儲(chǔ)在云存儲(chǔ)中,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08springboot設(shè)置加載靜態(tài)資源的路徑(spring.resources.static-locations)
這篇文章主要介紹了springboot設(shè)置加載靜態(tài)資源的路徑方式(spring.resources.static-locations),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08Mybatis-Plus自定義集合類(lèi)型的類(lèi)型處理器詳解
這篇文章主要介紹了Mybatis-Plus自定義集合類(lèi)型的類(lèi)型處理器詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01