mybatis返回Map结果集

原文:http://blog.csdn.net/sou_liu/article/details/47755635


其实只需要重写ResultHandler接口,,然后用SqlSession 的select方法,将xml里面的映射文件的返回值配置成 HashMap 就可以了。具体过程如下

1、先看看xml文件怎么配置

[html]  view plain  copy
  1. <resultMap id="getAllSetDaysResult"   type="HashMap">  
  2.     <result property="key" column="SP_FPARAMEKEY" />  
  3.     <result property="value" column="SP_FPARAMEVALUE" />  
  4.           
  5. resultMap>  

来看看sql是怎么写的

[html]  view plain  copy
  1. <select id="getAllSetDays" resultMap="getAllSetDaysResult">  
  2. SELECT SP.FPARAMEKEY SP_FPARAMEKEY, SP.FPARAMEVALUE SP_FPARAMEVALUE   
  3.   FROM T_SERVER_PARAMETER SP  
  4.  WHERE SP.FPARAMEKEY IN ('XXX')  
  5. select>  

这里面的property属性列的值,就是你后面实现的 ResultHandler 接口返回的map集的key和value,具体看代码


2、重写org.apache.ibatis.session 中ResultHandler接口:

[java]  view plain  copy
  1. public class FblMapResultHandler implements ResultHandler {  
  2.     @SuppressWarnings("rawtypes")  
  3.     private final Map mappedResults = new HashMap();  
  4.   
  5.     @SuppressWarnings("unchecked")  
  6.     @Override  
  7.     public void handleResult(ResultContext context) {  
  8.         @SuppressWarnings("rawtypes")  
  9.         Map map = (Map) context.getResultObject();   
  10.         mappedResults.put(map.get("key"), map.get("value"));  // xml 配置里面的property的值,对应的列  
  11.     }  
  12.     public Map getMappedResults() {    
  13.         return mappedResults;    
  14.     }    
  15. }  

3、调用select方法:

[java]  view plain  copy
  1.        FblMapResultHandler fbl = new FblMapResultHandler();  
  2. getSqlSession().select(NAMESPACE +"getAllSetDays",fbl);  
  3. @SuppressWarnings("rawtypes")  
  4. Map map =fbl.getMappedResults();  
  5. return map;  
此时map里面的key,和value就是我们数据库中表中的对应的两列了.

你可能感兴趣的:(mybatis)