大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全系列IDE稳定放心使用
其实只需要重写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就是我们数据库中表中的对应的两列了.
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/185724.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...