设为首页 加入收藏

TOP

SSM框架手动实现分页逻辑(非PageHelper)(一)
2019-10-09 19:59:53 】 浏览:29
Tags:SSM 框架 手动 实现 逻辑 PageHelper

第一种方法:查询出所有数据再分页

分析:

  1. 分页时,需要获得前台传来的两个参数,分别为pageNo(第几页数据),pageSize(每页的条数);
  2. 根据这两个参数来计算出前端需要的数据是查出数据list中的开始索引和结束索引;
  3. 利用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.writeva lueAsString(object);
        } catch (JsonProcessingException e) {
            e.printStackTrace();
        }
        return jsonString;
    }
}

第二种方法:用SQL分页,只查询当前页所需要的数据

分析:

  • 第一种方法在数据量比较小时可以使用,但当数据量非常大时,如果我们仅需要某一页的几条数据,而去查找所有数据,显得没有必要,或者说代价太大,所有我们现在采用第二种分页方式;

  • 第二种方法与第一种类似,获取前端传来的页码和每页显示的条数,通过自定义SQL语句查询数据库来得到需要的数据;

  • sql分页参考:

    Mysql复杂查询

    【MySQL】条件查询之排序聚合分组分页查询

实现过程

1. 获取参数

分析

  • 参数中,pageNo是前端传来的页码,即第几页;pageSize是每一页要显示的条数,默认为5;
  • 使用SQL分页时,查询语句中需要的参数为显示数据在数据库中的索引和每页显示的数据条目数;
    • 计算索引的公式:开始的索引 = (当前的页码 - 1) * 每页显示的条数;
  • 在这里还要判断一下前端传来的页码数是否超出总数据最大的分页数,如果超出则显示最大页数;
    • 最大页数计算:int maxPage =(int) Math.ceil(count/pageSize.doubleva lue());

CustomerController.java

@Controller
public class CustomerController {
    @Autowired
    CustomerService customerService;
    
    @ResponseBody
    @GetMapping("/allSql")
    public String findAllPageSql(
        @RequestParam(required = true,defaultValue
首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇maven仓库之第二篇 下一篇死磕 java同步系列之终结篇

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目