SSM框架手动实现分页逻辑(非PageHelper)
第一种方法:查询出所有数据再分页
分析:
- 分页时,需要获得前台传来的两个参数,分别为
pageNo(第几页数据),pageSize(每页的条数); - 根据这两个参数来计算出前端需要的数据是查出数据list中的开始索引和结束索引;
- 利用List 的subList方法来分割查询出来的所有数据并返回;
实现过程
1. 获取参数
这里返回的是json数据接口,实现方法在service层
@ResponseBody
@GetMapping("/allPage")
public String findAllPage(
@RequestParam(required = true,defaultValue = "1") Integer pageNo,
@RequestParam(required = false,defaultValue = "5") Integer pageSize) {
return customerService.findAllPage(pageNo,pageSize);
}
2. 截取数据
CustomerServiceImpl.java
- 里面的pageUtil类,iterCustomer()方法,JsonUtil类在下面有所介绍,抽离这些类或者方法的目的是提高代码的复用性,减少代码冗余;
@Override
public String findAllPage(Integer pageNo, Integer pageSize) {
List<Customer> customers = customerDao.findAll();
List<Map<String, String>> resultList = new ArrayList<>();
PageUtil<Customer> pageUtil = new PageUtil<>();
for (Customer customer : pageUtil.pageList(customers, pageNo, pageSize){
resultList.add(iterCustomer(customer));
}
return JsonUtil.toJSON(resultList);
}
PageUtil.java
- 这个类是我抽取出来的一个截取List的工具类,创建对象时需要传一个泛型,类型为处理列表List中的类型;
- 该类对象调用pageList方法即可返回一个截取好长度的List 数组;
- pageList方法有三个参数,
- 第一个参数为保存所有数据的List数组;
- 第二个参数为页码;
- 第三个参数为每一页显示的数据条数;
public class PageUtil<T> {
private int beginIndex;//起始索引
private int endIndex;//终止索引
public List<T> pageList(List<T> list, int pageNo, int pageSize) {
int size = list.size();
beginIndex = (pageNo - 1) * pageSize;
endIndex = pageNo * pageSize > size ? size : pageNo * pageSize;
List<T> resultList = list.subList(beginIndex, endIndex);
return resultList;
}
}
iterCustomer()方法
- 作用是得到一个map存储一个Customer实例的值,用键值对表示;
- 参数为需要包装的类对象;
- 返回值为一个Map对象,里面存储了参数类对象的一些信息;
public Map<String, String> iterCustomer(Customer customer) {
Map<String, String> resultMap = new HashMap<>();
resultMap.put("id", customer.getId().toString());
resultMap.put("name", customer.getName());
resultMap.put("phone", customer.getPhone());
resultMap.put("email", customer.getEmail());
return resultMap;
}
JsonUtil.java
- 作用是封装Jackson,返回一个json字符串;
public class JsonUtil {
//使用jackson 转换 json 数据的第一步
private static ObjectMapper MAPPER = new ObjectMapper();
static String jsonString=null;
public static String toJSON(Object object){
try {
//jackson转任意object对象 为json 字符串
jsonString = MAPPER.writeValueAsString(object);
} catch (JsonProcessingException e) {
e.printStackTrace();
}
return jsonString;
}
}
第二种方法:用SQL分页,只查询当前页所需要的数据
分析:
第一种方法在数据量比较小时可以使用,但当数据量非常大时,如果我们仅需要某一页的几条数据,而去查找所有数据,显得没有必要,或者说代价太大,所有我们现在采用第二种分页方式;
第二种方法与第一种类似,获取前端传来的页码和每页显示的条数,通过自定义SQL语句查询数据库来得到需要的数据;
sql分页参考:
实现过程
1. 获取参数
分析
- 参数中,pageNo是前端传来的页码,即第几页;pageSize是每一页要显示的条数,默认为5;
- 使用SQL分页时,查询语句中需要的参数为显示数据在数据库中的索引和每页显示的数据条目数;
- 计算索引的公式:开始的索引 = (当前的页码 - 1) * 每页显示的条数;
- 在这里还要判断一下前端传来的页码数是否超出总数据最大的分页数,如果超出则显示最大页数;
- 最大页数计算:
int maxPage =(int) Math.ceil(count/pageSize.doubleValue());
- 最大页数计算:
CustomerController.java
@Controller
public class CustomerController {
@Autowired
CustomerService customerService;
@ResponseBody
@GetMapping("/allSql")
public String findAllPageSql(
@RequestParam(required = true,defaultValue = "1") Integer pageNo,
@RequestParam(required = false,defaultValue = "5") Integer pageSize) {
/**
* pageSize 是每页显示的条数
* pageNo 是页码,sql分页传递的第一个参数是开始的索引;
* 计算公式:开始的索引 = (当前的页码 - 1) * 每页显示的条数
*/
//数据总数
int count = customerService.count();
//计算最大页码
int maxPage =(int) Math.ceil(count/pageSize.doubleValue());
//当前页码超出最大页码返回最大页码值:
pageNo = pageNo>maxPage?maxPage:pageNo;
//分页开始的索引值
int index = (pageNo - 1) * pageSize > count ? count : (pageNo - 1) * pageSize;
return customerService.findAllPageSql(index, pageSize);
}
}
2.分层调用方法
CustomerServiceImpl.java
@Service
public class CustomerServiceImpl implements CustomerService {
@Autowired
CustomerDao customerDao;
@Override
public String findAllPageSql(Integer index, Integer pageSize) {
return JsonUtil.toJSON(customerDao.findAllPageSql(index, pageSize));
}
}
CustomerDao.java
public interface CustomerDao {
List<Customer> findAllPageSql(Integer index,Integer pageSize);
}
3.定制sql
CustomerMapper.xml
注意,这里参数为两个,获取参数时要使用#{param1}#{param2},或者通过封装Map的形式传参;
sql分页参考:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.vue.dao.CustomerDao">
<select id="findAllPageSql" parameterType="java.lang.Integer" resultType="com.vue.entity.Customer">
SELECT * FROM t_customer LIMIT #{param1},#{param2}
</select>
</mapper>
Mapper.xml映射文件获取多个参数参考:
Mybatis中的Mapper.xml映射文件sql查询接收多个参数 或
Mybatis中的Mapper.xml映射文件sql查询接收多个参数
以上
- 以上就是SSM框架不用PageHelper插件实现分页的全过程,推荐使用第二种定制SQL查询,因为此种查询方法更加符合分页逻辑的实现,每次只查询需要的数据,而不是每次都要查询所有数据,故效率更高。
- 有问题可以一起交流:
- my blog
- 邮箱:594983498@qq.com
SSM框架手动实现分页逻辑(非PageHelper)的更多相关文章
- SSM手动实现分页逻辑---非PageHelper方式
第一种方法:查询出所有数据再分页 分析: 分页时,需要获得前台传来的两个参数,分别为pageNo(第几页数据),pageSize(每页的条数); 根据这两个参数来计算出前端需要的数据是查出数据list ...
- SSM框架手动搭建
SSM框架手动搭建 创建web项目 IDEA创建Maven项目 [File]-->[new]-->[project..] 将项目变为web项目 [File]-->[Project S ...
- java ssm框架实现分页功能 (oracle)
java web 实现分页功能 使用框架:ssm 数据库:oracle 话说 oracle 的分页查询比 mysql 复杂多了,在这里简单谈一下: 查询 前十条数据: SELECT * FROM( S ...
- SSM框架——实现分页和搜索分页
登录|注册 在路上 在路上,要懂得积累:在路上,要学会放下:我在路上!Stay hungry,Stay foolish. 目录视图 摘要视图 订阅 [公告]博客系统优化升级 ...
- SSM框架下分页的实现(封装page.java和List<?>)
之前写过一篇博客 java分页的实现(后台工具类和前台jsp页面),介绍了分页的原理. 今天整合了Spring和SpringMVC和MyBatis,做了增删改查和分页,之前的逻辑都写在了Servle ...
- SSM框架实现分页
SSM框架实现分页 1,.首先创建一个分页的工具类 package cn.page.po; import java.io.Serializable; public class Page impleme ...
- 关于在SSM框架下使用PageHelper
首先,如果各位在这块配置和代码有什么问题欢迎说出来,我也会尽自己最大的能力帮大家解答 这些代码我都是写在一个小项目里的,项目的github地址为:https://github.com/Albert-B ...
- SSM框架使用分页插件显示信息
1.在该SSM工程的pom.xml中加入PageHelper的分页插件依赖(若是版本号不对,可以尝试修改一下) <!-- 分页插件 --> <dependency> <g ...
- 基于SSM框架贺州学院校园二手交易平台设计与实现
前言 这个是我当时的毕业论文,分享出来,给同学们参考. 绪论 随着中国新四大发明的诞生,网购成了千千万万网友们购物的新方式,新的购物方式促进商业的发展,但随着人们生活水平的提高,许多新购置的物品用了没 ...
随机推荐
- set和push方法压入栈顶的值获取方法
向值栈里面放数据(储存的位置在root域里面) 向值栈放数据有多种方式,往往我们只用其中一种 1.set方法压栈 1)在Action中获取值栈对象,使用set()方法向值栈存放数据 ActionCon ...
- javascript 多个异步处理解决方法
JS异步处理真是一个让人头疼的东西,尤其是AJAX这个玩意.刚开始为了方便我会将jquery ajax 这个属性这样设置 async: false但是这样做问题很多,会让浏览器假死,好在ajax提供了 ...
- 通过Service访问应用 (1)
目录 通过Service访问应用 通过Pod IP访问应用 通过ClusterIP Service在集群内部访问 通过Service访问应用 通过之前的操作,应用部署完成了,我们的Demo网站已 ...
- c语言实现去除字符串首尾空格
字符串内存图如下: 引入头文件: 1 #include<stdlib.h> 2 #include<stdio.h> 3 #include<string.h> 函数原 ...
- Mysql的两种存储引擎以及区别
一.Mysql的两种存储引擎 1.MyISAM: ①不支持事务,但是整个操作是原子性的(事务具备四种特性:原子性.一致性.隔离性.持久性) ②不支持外键,支持表锁,每次所住的是整张表 MyIS ...
- 搭建Nuget服务器(Nuget私服)
一.前言 对公司或者对个人来说,经过一段时间的沉淀之后,都会有一些框架或者模块,为了对这些框架或者模块进行更好的管理和维护,也为了方便后面的开发或者其他同事,我们可以在我们本地或者内网搭建一个Nuge ...
- Python 基础 3 - 元组
元组与列表区别 Python 元组与列表类似,不同之处在于列表可以修改,元组不可以修改 元组用小括号 () 定义,列表用方括号 [] 定义 元组不可修改,列表可修改 元组创建 只需要在小括号 () 内 ...
- 【第十篇】easyui-datagrid排序 (转)
本文体验datagrid的排序. □ 思路 当点击datagrid的标题,视图传递给Controller的Form Data类似这样:page=1&rows=10&sort=Custo ...
- Windows7版本了解
1.win7简介Windows7是微软软件公司研发的标准版本,也就是所说的正版安装版或原版.安装版安装用时较长,安装步骤比较复杂,但是系统运行稳定.正版系统由微软刻成光盘出售,买品牌机,或一般大一点的 ...
- Null is your firend, not a mistake
原文作者: Roman Elizarov 原文地址: Null is your firend, not a mistake 译者:秉心说 Kotlin Island from Wikimedia by ...