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就是我们数据库中表中的对应的两列了.
其实只需要重写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就是我们数据库中表中的对应的两列了.
相关文章推荐
- mybatis的mapper返回map结果集
- Mybatis 连表查询,返回结果封装为Map
- springboot+mybatis MyBatis查询返回Map时设置值为null的字段没有在结果集中
- mybatis的mapper返回map结果集
- MyBatis笔记:使用resultMap映射sql返回的结果
- Spring boot + MyBatis 查询返回Map时设置值为null的字段也在结果集中
- 好947 Mybatis 配置resultMap 带参数查询Map 注意selectOne数据库返回结果一条数据库 否则会报错
- Mybatis 连表查询,返回结果封装为Map
- 13、Mybatis把返回结果封装成map类型
- Mybatis 连表查询,返回结果封装为Map
- Mybatis 查询结果返回 Map
- mybatis执行任意sql,不配置resultMap,返回结果集
- mybatis的mapper返回map结果集
- mybatis学习之查询结果返回List以及Map
- MyBatis查询返回Map时设置值为null的字段也在结果集中
- mybatis返回结果封装为map的探索
- Mybatis 如何返回Map集合
- perl 如何将多个map的结果返回给数组
- MyBatis返回Map键值对数据
- mybatis3的返回结果集如何映射到对应的bean或者是map中?