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

mapper的xml文件能够按以下方式来写:java

<!-- 用来记录分页查询时的全部数据量,避免出现分页查询时须要查询两次 -->
	<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接口:web

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

service层:sql

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

controller层:app

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上加上这个配置就能够了。svg