欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MyBatis將查詢(xún)出的兩列數(shù)據(jù)裝配成鍵值對(duì)的操作方法

 更新時(shí)間:2022年08月08日 15:07:08   作者:jackhb1999  
這篇文章主要介紹了MyBatis將查詢(xún)出的兩列數(shù)據(jù)裝配成鍵值對(duì)的操作代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

描述:

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)文章

  • 詳解spring如何使用注解開(kāi)發(fā)

    詳解spring如何使用注解開(kāi)發(fā)

    今天給大家整理了spring如何使用注解開(kāi)發(fā)這篇文章,文中有非常詳細(xì)的介紹及代碼示例,對(duì)正在學(xué)習(xí)的小伙伴們很有幫助,需要的朋友可以參考下
    2021-05-05
  • java基礎(chǔ)實(shí)現(xiàn)猜數(shù)字小游戲

    java基礎(chǔ)實(shí)現(xiàn)猜數(shù)字小游戲

    這篇文章主要為大家詳細(xì)介紹了java基礎(chǔ)實(shí)現(xiàn)猜數(shù)字小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • 一文盤(pán)點(diǎn)五種最常用的Java加密算法

    一文盤(pán)點(diǎn)五種最常用的Java加密算法

    大家平時(shí)的工作中,可能也在很多地方用到了加密、解密,比如:支付功能等,所以本文為大家盤(pán)點(diǎn)了Java中五個(gè)常用的加密算法,希望對(duì)大家有所幫助
    2023-06-06
  • Netty分布式抽象編碼器MessageToByteEncoder邏輯分析

    Netty分布式抽象編碼器MessageToByteEncoder邏輯分析

    這篇文章主要介紹了Netty分布式抽象編碼器MessageToByteEncoder的抽象邏輯分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-03-03
  • 如何用ObjectMapper將復(fù)雜Map轉(zhuǎn)換為實(shí)體類(lèi)

    如何用ObjectMapper將復(fù)雜Map轉(zhuǎn)換為實(shí)體類(lèi)

    這篇文章主要介紹了如何用ObjectMapper將復(fù)雜Map轉(zhuǎn)換為實(shí)體類(lèi)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • RestTemplate get請(qǐng)求攜帶headers自動(dòng)拼接參數(shù)方式

    RestTemplate get請(qǐng)求攜帶headers自動(dòng)拼接參數(shù)方式

    這篇文章主要介紹了RestTemplate get請(qǐng)求攜帶headers自動(dòng)拼接參數(shù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • springboot+vue實(shí)現(xiàn)七牛云頭像的上傳

    springboot+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-08
  • springboot設(shè)置加載靜態(tài)資源的路徑(spring.resources.static-locations)

    springboot設(shè)置加載靜態(tài)資源的路徑(spring.resources.static-locations)

    這篇文章主要介紹了springboot設(shè)置加載靜態(tài)資源的路徑方式(spring.resources.static-locations),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • Mybatis-Plus自定義集合類(lèi)型的類(lèi)型處理器詳解

    Mybatis-Plus自定義集合類(lèi)型的類(lèi)型處理器詳解

    這篇文章主要介紹了Mybatis-Plus自定義集合類(lèi)型的類(lèi)型處理器詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • 新手了解java 泛型基礎(chǔ)知識(shí)

    新手了解java 泛型基礎(chǔ)知識(shí)

    這篇文章主要給大家介紹了關(guān)于Java中泛型使用的簡(jiǎn)單方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Java具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-07-07

最新評(píng)論