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

avatar
avatar
云惠网小编
2129
文章
0
评论
2020年9月26日15:51:25 评论 24 次浏览 786字阅读2分37秒
摘要

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

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上加上这个配置就可以了。

腾讯云618
avatar
网联V2X测试解决方案 阿里云开发与运维

网联V2X测试解决方案

V2X,顾名思义就是vehicle-to-everything,通过现代通信与网络技术,实现车与人、车、路、后台等信息交换共享,从而帮助汽车实现安全、舒适、节能、高效行驶。
腾讯云618
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: