亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

MyBatis查詢返回Map示例代碼

2024-07-14 08:42:38
字體:
來源:轉載
供稿:網友

前言

有時候我們做查詢, 只需要返回兩個string類型的字段,方便我們后續的處理.比如根據商品的code查詢對應的分類的名字,需要返回一個map, key為商品code, value為商品分類對應的名稱.以方便我們后續對結果集的處理.如果你直接用mybatis返回一個map, 你可能會發現,結果根據不是自己需要的.這時候我們需要自己實現一個ResultHandler來實現我們想要的結果,廢話不多說,直接上代碼

方法如下

第一步,在mapper.xml文件當中,定義一個ResultMap

 <resultMap id="cateNameMapping" type="java.util.HashMap" >  <result property="key" column="commodityCode"></result>  <result property="value" column="cateName"></result> </resultMap>

這個map當中的property的定義,是我們在定義ResultHandler的時候,需要用到的.column是我們做sql查詢的時候mysql中字段的名稱,注意這里不支持駝峰自動映射,比如我這里寫了commodityCode, 后面需要用AS來處理一下.

第二步正常的在我們的mapper.xml中寫查詢語句

<select id="processCateNameMappingByGoodsCodes" parameterType="java.util.List" resultMap="cateNameMapping">    SELECT        c.commodity_code AS commodityCode,        CONCAT(tc.cate_name,',',tc1.cate_name, ',', tc2.cate_name) AS cateName    FROM       t_commodity c LEFT JOIN t_category tc ON c.commodity_first_id = tc.id              LEFT JOIN t_category tc1 ON c.commodity_second_id = tc1.id              LEFT JOIN t_category tc2 ON c.commodity_third_id = tc2.id    WHERE      c.commodity_code IN        <foreach collection="list" separator="," open="(" close=")" item="code">          #[code]        </foreach>  </select>

注意返回類型為ResultMap, 也就是我們上面定義的那個.

第三步 自定義一個ResultHandler

package org.linuxsogood.es.statistical.handler; import org.apache.ibatis.session.ResultContext;import org.apache.ibatis.session.ResultHandler; import java.util.HashMap;import java.util.Map; /** * @author honway * @date 2018/10/22 11:49. * @blog http://linuxsogood.org */public class MapResultHandler implements ResultHandler {   private final Map<String ,String> mappedResults = new HashMap();   @Override  public void handleResult(ResultContext resultContext) {    Map<String ,String> m = (Map) resultContext.getResultObject();    mappedResults.put(m.get("key"), m.get("value"));  }   public Map getMappedResults() {    return mappedResults;  }}

第四步 就是使用了, 我們在service層, 利用spring的自動注入,來注入mybatis的sqlSession

@Servicepublic class GoodsSalesServiceImpl implements IGoodsSalesService {   private final GoodsSalesMapper goodsSalesMapper;  private final SqlSession sqlSession;   @Autowired  public GoodsSalesServiceImpl(GoodsSalesMapper goodsSalesMapper, SqlSession sqlSession) {    this.goodsSalesMapper = goodsSalesMapper;    this.sqlSession = sqlSession;  }   /**   * 根據商品code查詢商品的一二三級分類   * @param commodityCodeList 商品code   * @return 返回商品和分類的映射, key為商品code, value為商品的一二三級分類,用逗號隔開   */  @Override  public Map<String, String> processCateNameMappingByGoodsCodes(List<String> commodityCodeList) {    MapResultHandler handler = new MapResultHandler();    sqlSession.select("com.tramy.es.statistical.dao.GoodsSalesMapper.processCateNameMappingByGoodsCodes",commodityCodeList ,handler);    return handler.getMappedResults();  }}

使用sqlSession的select方法,第一個參數是mapper.xml文件當中定義的select的命名空間, 第二個參數是需要傳入的參數,如果沒有可以不要這個參數.第三個是我們自定義的handler, 這樣就能返回我們要的map結果了.

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美性xxxxxxxxx| 成人免费网站在线观看| 91精品啪在线观看麻豆免费| 精品日本高清在线播放| 国产精品第一视频| 午夜精品一区二区三区在线视频| 日韩精品日韩在线观看| 精品国产欧美一区二区五十路| 国产在线一区二区三区| 日产精品99久久久久久| 在线视频免费一区二区| 日韩中文字幕免费| 色琪琪综合男人的天堂aⅴ视频| 久久这里有精品| 亚州精品天堂中文字幕| 欧美电影在线免费观看网站| 九九精品在线播放| 91精品久久久久久久久久久久久| 欧美激情一区二区三区高清视频| 91热精品视频| 久久99国产综合精品女同| 国产乱肥老妇国产一区二| 欧美激情奇米色| 亚洲综合精品一区二区| 97视频免费在线观看| 欧美性猛交xxxx黑人| 欧美男插女视频| 日韩在线播放视频| 欧美人与性动交| 国产91|九色| 精品动漫一区二区| 精品在线观看国产| 亚洲国产精品字幕| 亚洲色图15p| 亚洲第一中文字幕在线观看| 国产一区二区三区精品久久久| 久久免费国产视频| 国产精品99久久久久久www| 国产精品中文久久久久久久| 欧美日韩性生活视频| 久国内精品在线| 国产欧美久久久久久| 国产99久久精品一区二区 夜夜躁日日躁| 日韩av最新在线观看| 亚洲精品电影在线| 久久精品国产久精国产一老狼| 久久伊人精品视频| 亚洲国产美女精品久久久久∴| 91黑丝在线观看| 日韩中文字幕精品视频| 国产日韩精品电影| 欧美一级电影在线| 欧美激情精品久久久久久| 成人激情电影一区二区| 黑人极品videos精品欧美裸| 国产精品爱久久久久久久| 国外成人在线播放| 国产精自产拍久久久久久| 一本色道久久综合亚洲精品小说| 亚洲视频网站在线观看| 日韩理论片久久| 欧美日韩国产综合视频在线观看中文| 一区二区三区天堂av| 欧美大肥婆大肥bbbbb| 国产精品综合网站| 国内精品久久久久久影视8| 成人中文字幕在线观看| 亚洲欧洲av一区二区| 91亚洲va在线va天堂va国| 亚洲综合在线中文字幕| 成人av番号网| 亚洲精品久久久一区二区三区| 亚洲级视频在线观看免费1级| 中文字幕欧美国内| 日本久久久久久久久| 国产精品成人免费电影| 亚洲国产精品成人va在线观看| 成人欧美一区二区三区在线湿哒哒| 国产午夜精品一区二区三区| 欧美成人精品不卡视频在线观看| 国产精品丝袜久久久久久高清| 欧美日韩国产丝袜另类| 国产亚洲成av人片在线观看桃| 久久99精品久久久久久噜噜| 久久成人综合视频| 亚洲国产欧美一区二区三区同亚洲| 欧洲成人免费aa| 日本久久亚洲电影| 亚洲天堂av在线免费观看| 美女黄色丝袜一区| 亚洲成人激情在线观看| 亚洲r级在线观看| 国产成人精品一区二区| 久久久久久久久久久av| 日韩精品中文字幕在线| 中文日韩电影网站| 久久影视免费观看| 久久精品中文字幕免费mv| 在线成人一区二区| 国产精品99久久99久久久二8| 国产精品99久久久久久www| 国产有码在线一区二区视频| 日韩av免费看网站| 亚洲午夜小视频| 国产精品福利小视频| 伊人久久久久久久久久| 日韩免费在线电影| 美女精品久久久| 欧美日韩亚洲国产一区| 中文字幕日韩免费视频| 九九热在线精品视频| 久久精品欧美视频| 中文字幕久久精品| 91在线视频精品| 欧美丝袜第一区| 奇米4444一区二区三区| 法国裸体一区二区| 国产精品自拍小视频| 精品国产一区av| 亚洲伊人一本大道中文字幕| 亚洲精品资源在线| 欧美亚洲国产精品| 欧美激情一区二区三级高清视频| 欧美猛男性生活免费| 亚洲r级在线观看| 久久综合免费视频影院| 亚洲精品在线视频| 欧美丝袜一区二区三区| 国产精品欧美日韩| 久久久久久久久久久av| 91干在线观看| 欧美中文字幕在线播放| 久久久久久久一区二区三区| 欧美一级片免费在线| 成人精品久久av网站| 国产成人综合久久| 九九热99久久久国产盗摄| 亚洲精品国产精品自产a区红杏吧| 欧美猛交免费看| 亚洲成人三级在线| 精品无人国产偷自产在线| 亚洲国产91色在线| 97精品国产97久久久久久免费| 久久精品久久久久久| 国产美女久久精品| 亚洲精品成人久久| 成人动漫网站在线观看| 精品久久久久久久久久久久| 91中文精品字幕在线视频| 欧美激情精品久久久久久蜜臀| 亚洲精品成人久久| 北条麻妃在线一区二区| 日韩成人黄色av| 国产精品视频导航| 精品福利一区二区| 亚洲电影免费观看| 欧美香蕉大胸在线视频观看| 日韩久久免费电影| 亚洲免费小视频| 欧美床上激情在线观看| 成人网页在线免费观看| 国产成人精品网站| 在线精品高清中文字幕| 久久综合国产精品台湾中文娱乐网|