Mybatis select返回值为map时,选取表字段的两列作为key,value

最近需要用到Mybatis中查询结果集为Map的功能,查了好多资料,最终搞定。其实只需要重写ResultHandler接口,,然后用SqlSession 的select方法,将xml里面的映射文件的返回值配置成 HashMap 就可以了。具体过程如下

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

<resultMap id="getAllSetDaysResult"   type="HashMap">
	<result property="key" column="SP_FPARAMEKEY" />
	<result property="value" column="SP_FPARAMEVALUE" />
		
</resultMap>

来看看sql是怎么写的

<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接口:

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方法:

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

评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值