mysql 返回map类型数据
故事的发生是这样的. . . . . . .
一天 我发现我们的页面显示了这样的汇总统计数据,看起来体验还不错哦~~
然后,我发现代码是这样滴:分开每个状态分别去查询数量。
额e,可是为嘛不使用简单便捷的 group by 语句呢
我们知道MyBatis提供了selectMap的方法,查询结果为hashmap。查询的时候,可以配置相应的传入参数和查询返回结果。
对应dao 层代码如下:
//查询各状态对应的数量,三个参数分别对应,select的id,查询参数,返回hashmap的key
public Map>sumStatusByParam(SearchParam searchParam ){return (Map>)sqlSessionTemplate.selectMap(SEARCH_NAME_SPACE + "sumStatusByParam",searchParam,"status");
}
对应mybatis的数据查询语句:
select status as status,count(id) asnumfromselicoco_orderwhere 1=1
and name like concat('%',#{name,jdbcType=VARCHAR},'%')
group bystatus;
最后得到的结果是这样的。
我以为这样就可以了,但是,count(1)这样出来的结果是一个Long类型,并不能直接转换成Integer,虽然查询的时候并没有报错,但是读取的时候一定会告诉你转换失败的,
所以我只能默默的把map里面的 Integer转换成Long类型。
对于这样的结果,我们如果要获取的话,得这样去取
map.get("WAIT_CONFIRM").get("num");
这样其实是比较费力的。明白其中的原理其实可以写一个公用的中间层方法,将里面的map转换出来。因为我的状态并不多,所以直接就使用上面的方式去取值了。
selectMap实现机制:
selectMap调用selectList进行查询,返回一个List,mybatis底层查询返回其实都是hashMap。
然后再从map里面取出我们指定的key值,放入一个map,而value就是底层查询出来的整个hashmap的值。
源码如下:
publicMap selectMap(String statement, String mapKey) {return selectMap(statement, null, mapKey, RowBounds.DEFAULT);
}publicMap selectMap(String statement, Object parameter, String mapKey) {returnselectMap(statement, parameter, mapKey, RowBounds.DEFAULT);
}publicMap selectMap(String statement, Object parameter, String mapKey, RowBounds rowBounds) {final List list =selectList(statement, parameter, rowBounds);final DefaultMapResultHandler mapResultHandler = newDefaultMapResultHandler(mapKey);final DefaultResultContext context = newDefaultResultContext();for(Object o : list) {
context.nextResultObject(o);
mapResultHandler.handleResult(context);
}returnmapResultHandler.getMappedResults();
}publicList selectList(String statement) {return selectList(statement, null);
}publicList selectList(String statement, Object parameter) {returnselectList(statement, parameter, RowBounds.DEFAULT);
}publicList selectList(String statement, Object parameter, RowBounds rowBounds) {try{
MappedStatement ms=configuration.getMappedStatement(statement);returnexecutor.query(ms, wrapCollection(parameter), rowBounds, Executor.NO_RESULT_HANDLER);
}catch(Exception e) {throw ExceptionFactory.wrapException("Error querying database. Cause: " +e, e);
}finally{
ErrorContext.instance().reset();
}
}
publicDefaultMapResultHandler(String mapKey) {this.mapKey =mapKey;
}public voidhandleResult(ResultContext context) {final Object value =context.getResultObject();final MetaObject mo =MetaObject.forObject(value);final Object key =mo.getValue(mapKey);
mappedResults.put(key, value);
}
作者:weixin_39883462
来源链接:https://blog.csdn.net/weixin_39883462/article/details/113974748
版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。
2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。