【MyBatis&MyBatis-plus】分页查询避免两次查询同时返回总数和数据 - 新闻资讯 - 云南小程序开发|云南软件开发|云南网站建设-昆明葵宇信息科技有限公司

159-8711-8523

云南网建设/小程序开发/软件开发

知识

不管是网站,软件还是小程序,都要直接或间接能为您产生价值,我们在追求其视觉表现的同时,更侧重于功能的便捷,营销的便利,运营的高效,让网站成为营销工具,让软件能切实提升企业内部管理水平和效率。优秀的程序为后期升级提供便捷的支持!

您当前位置>首页 » 新闻资讯 » 技术分享 >

【MyBatis&MyBatis-plus】分页查询避免两次查询同时返回总数和数据

发表时间:2019-9-24

发布人:葵宇科技

浏览次数:143

mapper的xml文件可以按如下方式来写:

	<!-- 用来记录分页查询时的所有数据量,避免出现分页查询时需要查询两次 -->
	<resultMap type="java.lang.Integer" id="count">
		<result column="total"/>
	</resultMap>
	
	<!-- 多条件查询 /分页查询-->
	<select id="selectPage" resultMap="自定义的resultMap,count">
		SELECT SQL_CALC_FOUND_ROWS * FROM  表名及条件
		WHERE ID in (SELECT ID from (SELECT ID FROM A LIMIT ${(pageNo-1)*pageSize},#{pageSize}) AS t)		
		order by ID;
		<!-- 查询数据量 -->
		SELECT FOUND_ROWS(*) AS total;
	</select>	

mapper接口:

List<Object> selectPage(@Param("pageNo") Integer pageNo, @Param("pageSize") Integer pageSize);

service层:

Mapper接口实例.selectPage(Integer pageNo,Integer pageSize);

controller层:

List<Object> list = Service实例.selectPage(pageNo,pageSize);
List<实体类名> wcenters = (List<实体类名>) list.get(0); //数据集合
Integer total = ((List<Integer>) list.get(1)).get(0);//总量

注意:在使用时需要在配置文件中,设置允许sql进行多语句执行:allowMultiQueries=true,在sql的url上加上这个配置就可以了。

相关案例查看更多