mybatis返回Map结果集

时间:2025-04-21 10:05:06


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

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

 

[html] 
 
  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]
 
  1. <select id="getAllSetDays" resultMap="getAllSetDaysResult">  
  2. SELECT  SP_FPARAMEKEY,  SP_FPARAMEVALUE   
  3.   FROM T_SERVER_PARAMETER SP  
  4.  WHERE  IN ('XXX')  
  5. </select>  


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

 

2、重写 中ResultHandler接口:

 

[java] 
 
  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) ();   
  10.         (("key"), ("value"));  // xml 配置里面的property的值,对应的列  
  11.     }  
  12.     public Map getMappedResults() {    
  13.         return mappedResults;    
  14.     }    
  15. }  

3、调用select方法:

 

[java] 
 
  1.        FblMapResultHandler fbl = new FblMapResultHandler();  
  2. getSqlSession().select(NAMESPACE +"getAllSetDays",fbl);  
  3. @SuppressWarnings("rawtypes")  
  4. Map map =();  
  5. return map;  

此时map里面的key,和value就是我们数据库中表中的对应的两列了.