您的位置:首页 > 其它

mybatis返回Map结果集

2017-11-28 17:52 429 查看
原文:http://blog.csdn.net/sou_liu/article/details/47755635

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

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

[html] view
plain copy

<resultMap id="getAllSetDaysResult"   type="HashMap">  

    <result property="key" column="SP_FPARAMEKEY" />  

    <result property="value" column="SP_FPARAMEVALUE" />  

          

</resultMap>  

来看看sql是怎么写的

[html] view
plain copy

<select id="getAllSetDays" resultMap="getAllSetDaysResult">  

SELECT SP.FPARAMEKEY SP_FPARAMEKEY, SP.FPARAMEVALUE SP_FPARAMEVALUE   

  FROM T_SERVER_PARAMETER SP  

 WHERE SP.FPARAMEKEY IN ('XXX')  

</select>  

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

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

[java] view
plain copy

public class FblMapResultHandler implements ResultHandler {  

    @SuppressWarnings("rawtypes")  

    private final Map mappedResults = new HashMap();  

  

    @SuppressWarnings("unchecked")  

    @Override  

    public void handleResult(ResultContext context) {  

        @SuppressWarnings("rawtypes")  

        Map map = (Map) context.getResultObject();   

        mappedResults.put(map.get("key"), map.get("value"));  // xml 配置里面的property的值,对应的列  

    }  

    public Map getMappedResults() {    

        return mappedResults;    

    }    

}  

3、调用select方法:

[java] view
plain copy

       FblMapResultHandler fbl = new FblMapResultHandler();  

getSqlSession().select(NAMESPACE +"getAllSetDays",fbl);  

@SuppressWarnings("rawtypes")  

Map map =fbl.getMappedResults();  

return map;  

此时map里面的key,和value就是我们数据库中表中的对应的两列了.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: