在我们使用mybatis 时,当我们根据分页去查询数据集时,需要传入的参数有page(页码)和size(每页的条数),而我们期望获取到的数据有,小于或等于size的list数据集,同时我们还需要得到一个count,总共的数据条数。
官方提供了一个select sql_calc_found_rows 字段 from 表 ... ; 然后再调用select found_rows(); 获取总记录数。 那么如何在mybatis中同时执行两个sql获取结果集?
解决方法:
(1)连接数据库的时候,指定可支持多查询“allowMultiQueries=true”,如配置文件中 jdbc.url=jdbc:mysql://localhost:3306/wash?autoReconnect=true&useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true
(2)mybatis的xml文件中查询语句添加一个结果集,并且用逗号隔开。 resultMap="BaseResultMap, countAdminResultMap"。同时select 之后添加一个关键字 sql_calc_found_rows (必须)。
select sql_calc_found_rows id, username, mobile, password, type
from sys_admin where 1 = 1limit #{pageSizeBegin, jdbcType=INTEGER} , #{pageSize, jdbcType=INTEGER};
SELECT found_rows() as count;
(3)mapper文件方法名
List> listdata(Map paramMap);
(4)service方法
这里仅查看serviceImpl方法即可。 这里返回的List> 包含两个数据,一个是数据list,另一个是count。接收它们放入我们的Page对象即可。
public Page> listdata(MapparamMap) {
List> list =adminMapper.listdata(paramMap);
List > listMaps = new ArrayList<>();
listMaps= (List >) list.get(0); //数据list
int count = ((List)list.get(1)).get(0); //总记录数
Page > page = new Page >();
page.setData(listMaps);
page.setCount(count);returnpage;
}
总结:通过这种方法,我们可以方便的获取到count,而不需要两次连接数据库,执行一次不必要的查询。 而以上这种方式主要利用的缓存,第二次查询直接从缓存中查出数据,花费时间可忽略不计。