当前位置:首页 > 数据库 > mysql 返回map类型数据

mysql 返回map类型数据

故事的发生是这样的. . . . . . .

一天 我发现我们的页面显示了这样的汇总统计数据,看起来体验还不错哦~~

mysql 返回map类型数据 _ JavaClub全栈架构师技术笔记

然后,我发现代码是这样滴:分开每个状态分别去查询数量。

额e,可是为嘛不使用简单便捷的 group by 语句呢

我们知道MyBatis提供了selectMap的方法,查询结果为hashmap。查询的时候,可以配置相应的传入参数和查询返回结果。

mysql 返回map类型数据 _ JavaClub全栈架构师技术笔记

对应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;

最后得到的结果是这样的。

mysql 返回map类型数据 _ JavaClub全栈架构师技术笔记

我以为这样就可以了,但是,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),我们将第一时间核实后及时予以删除。


本文链接:https://www.javaclub.cn/database/68195.html

分享给朋友: