SpringCloud+MyBatis分页处理(前后端分离)

所属分类: 软件编程 / java 阅读数: 34
收藏 0 赞 0 分享

分页处理,这是做JavaWeb项目中常见的场景。

背景:

1.系统架构:SpringCloud分布式
2.持久层:MyBatis
3.前端:前后分离vue.js/bootstrap等.

后台提供restful api 接口,前端访问后端接口展示数据。

2种方式提供分页处理方案:

一、直接MyBatis数据库进行分页

controller接口

@ApiImplicitParams({
 @ApiImplicitParam(name = "categoryId", value = "支付渠道大类Id", required = false, dataType = "Long", paramType = "query"),
 @ApiImplicitParam(name = "payChannelId", value = "支付渠道ID", required = false, dataType = "Long", paramType = "query"),
 @ApiImplicitParam(name = "bankCode", value = "银行名称code", required = false, dataType = "String", paramType = "query"),
 @ApiImplicitParam(name = "startTime", value = "创建时间起始(示例:2018-09-05)", required = false, dataType = "String", paramType = "query", length = 10),
 @ApiImplicitParam(name = "endTime", value = "创建时间截止(示例:2018-09-05)", required = false, dataType = "String", paramType = "query", length = 10),
 @ApiImplicitParam(name = "pageNum", value = "查询开始页", required = true, dataType = "int", paramType = "query"),
 @ApiImplicitParam(name = "pageSize", value = "查询的页面大小不需要分页则把此值填大一点", required = true, dataType = "int", paramType = "query")})
 public PageResult<ChannelBaseDataResp> queryPayChannel(
   @RequestParam(value = "categoryId", required = false) Long categoryId,
   @RequestParam(value = "payChannelId", required = false) Long payChannelId,
   @RequestParam(value = "bankCode", required = false) String bankCode,
   @RequestParam(value = "startTime", required = false) String startTime,
   @RequestParam(value = "endTime", required = false) String endTime,
   @RequestParam(value = "pageNum", required = true) Integer pageNum,
   @RequestParam(value = "pageSize", required = true) Integer pageSize) {
 PageResult<ChannelBaseDataResp> response = new PageResult<ChannelBaseDataResp>();
 try {
 int endRowNo = pageNum * pageSize;
 int beginRowNo = (pageNum - 1) * pageSize + 1;
 return channelBaseDataService.queryBaseData(categoryId,payChannelId,bankCode,startTime,endTime,beginRowNo,endRowNo);
 } catch (Exception e) {
 response = new PageResult<ChannelBaseDataResp>();
 if (e instanceof AppException) {
 response.setCode(((AppException) e).getErrorCode());
 response.setResult(((AppException) e).getErrorMsg());
 } else {
 response.setCode(CumReturnCode.SYSTEM_EXCEPTION.code);
 response.setResult(CumReturnCode.SYSTEM_EXCEPTION.message);
 }
 return response;
 }
 }

Swagger-ui接口界面如下:

pageNum 和 pageSize 用于前端分页的参数,pageNum:表示页码第几页,pageSize:表示每页展示数据数量。

所有查询条件参数,在mapper-xml里进行处理,再利用数据库oracle本身的rownum行值进行分页。

xml代码:

<select id="queryBaseDataList" resultMap="BaseResultMap">
 select
 ID, PAY_CHANNEL_MAIN_ID, PAY_CHANNEL_ID,
 BANK_CODE, CREATE_TIME, UPDATE_TIME,UPDATOR
 from (
 select A.*, rownum RN
 from (
 select ID, PAY_CHANNEL_MAIN_ID, PAY_CHANNEL_ID,
 BANK_CODE, CREATE_TIME, UPDATE_TIME,UPDATOR
 from CUM_PAY_CHANNEL_BASE
 <where>
 <if test="beginCreateTime != null">
 CREATE_TIME <![CDATA[ >= ]]> #{beginCreateTime,jdbcType=TIMESTAMP}
 </if>
 <if test="endCreateTime != null">
 AND CREATE_TIME <![CDATA[ <= ]]> #{endCreateTime,jdbcType=TIMESTAMP}
 </if>
 <if test="categoryId != null and categoryId != '' ">
 AND PAY_CHANNEL_MAIN_ID = #{categoryId,jdbcType=DECIMAL}
 </if>
 <if test="payChannelId != null and payChannelId != ''">
 AND PAY_CHANNEL_ID = #{payChannelId,jdbcType=DECIMAL}
 </if>
 <if test="bankCode != null and bankCode != ''">
 AND BANK_CODE = #{bankCode,jdbcType=VARCHAR}
 </if>
 </where>
 order by CREATE_TIME desc
 ) A
 where rownum &lt;= #{endRowNo,jdbcType=DECIMAL}
 )
 where RN &gt;= #{beginRowNo,jdbcType=DECIMAL}
</select>

优点:直观、方便、易排查问题。 缺点:访问数据库过于频繁,未利用到mybatis本身的缓存优势。

二、Java+缓存分页

这种方法对于前端而言是没变化,无感的。

只是在后端处理稍作变动,思路:

1.先把所有数据记录查询出来
2.数据库实体再次封装为查询实体
3.纯java代码进行分页

controller接口不变

service业务处理——>数据库crud操作变动

把所有数据库记录查询处理

<select id="queryBaseDataList" resultMap="BaseResultMap">
 select
 ID, PAY_CHANNEL_MAIN_ID, PAY_CHANNEL_ID,
 BANK_CODE, CREATE_TIME, UPDATE_TIME,UPDATOR
 from CUM_PAY_CHANNEL_BASE
 <where>
 <if test="beginCreateTime != null">
 CREATE_TIME <![CDATA[ >= ]]> #{beginCreateTime,jdbcType=TIMESTAMP}
 </if>
 <if test="endCreateTime != null">
 AND CREATE_TIME <![CDATA[ <= ]]> #{endCreateTime,jdbcType=TIMESTAMP}
 </if>
 <if test="categoryId != null and categoryId != '' ">
 AND PAY_CHANNEL_MAIN_ID = #{categoryId,jdbcType=DECIMAL}
 </if>
 <if test="payChannelId != null and payChannelId != ''">
 AND PAY_CHANNEL_ID = #{payChannelId,jdbcType=DECIMAL}
 </if>
 <if test="bankCode != null and bankCode != ''">
 AND BANK_CODE = #{bankCode,jdbcType=VARCHAR}
 </if>
 </where>
 order by CREATE_TIME desc
</select>

再按照pageNum和pageSize进行分页处理

//以分页形式输出给前端
List<ChannelRouteGroupResp> resultList = new ArrayList<>();
 if(groupRespList.size() >= endRowNo){
 for(int i=(beginRowNo-1); i< endRowNo; i++){
 resultList.add(groupRespList.get(i));
 }
 }else{
 for(int i=(beginRowNo-1); i< groupRespList.size(); i++){
 resultList.add(groupRespList.get(i));
 }
 }

优点:利用了mybatis缓存机制,分页查询快速,减少数据库访问次数。

缺点:当数据量大的时候,100W+;在没有条件查询数据库的时候,耗时久

前端分页后的界面展示如下:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

Springmvc restful配置遇到的小坑

本文是小编给大家带了的Springmvc restful配置遇到的小小坑,小编给大家带来了问题原因及解决办法,非常不错,具有参考借鉴价值,感兴趣的朋友一起看下吧
收藏 0 赞 0 分享

Java中的匿名内部类小结

java内部类分为: 成员内部类、静态嵌套类、方法内部类、匿名内部类。这篇文章主要介绍了Java中的匿名内部类的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

Java的云打印Lodop

这篇文章主要介绍了Java的云打印Lodop 的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

Java线程池框架核心代码解析

这篇文章主要针对Java线程池框架核心代码进行详细解析,分析Java线程池框架的实现ThreadPoolExecutor,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Java 交换两个变量的数值实现方法

下面小编就为大家带来一篇Java 交换两个变量的数值实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

全面了解JAVA_BaseDAO数据处理类

下面小编就为大家带来一篇全面了解JAVA_BaseDAO数据处理类。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

java、python、JavaScript以及jquery循环语句的区别

本篇文章主要介绍java、python、JavaScript以及jquery的循环语句的区别,这里整理了它们循环语句语法跟示例,以便大家阅读,更好的区分它们的不同
收藏 0 赞 0 分享

基于JDBC封装的BaseDao(实例代码)

下面小编就为大家带来一篇基于JDBC封装的BaseDao(实例代码)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

简单通用JDBC辅助类封装(实例)

下面小编就为大家带来一篇简单通用JDBC辅助类封装(实例)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

浅谈java线程中生产者与消费者的问题

下面小编就为大家带来一篇浅谈java线程中生产者与消费者的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享
查看更多