对于新手程序员来说分页应该是一个坎,对于普通的增删改查大家应该还是挺得心应手的.分页刚开始可能不是太熟悉。
分页又分为前端分页和后端分页。
页面上需要对返回的数据进行展示就需要用到分页效果了。
而前端要做的就是尽快接受数据并最快地展示给用户,对于数据不多的场景用前端实现也无妨,然而若考虑到以后会有成千上万条数据应用的场景,显然后端去处理分页更合适些。
每次点击下一页,前端只需发送分页数信息请求后端数据,假设一页显示十条数据,每次点击只需请求这十条数据的信息返回给前端来更快地进行交互。然而若是由前端来进行分页操作,那就得把成千上万条数据全部先拉下来,再进行操作,先不说操作这么多数据拉低的性能,光是先拉下来就得费很长时间了,所以对于数据量大的操作,一般都采用后端分页的操作更合适。
首先要了解为什么要分页。分页主要是为了避免一次性从数据库获取大量数据。其次才是为了展示效果。
在后端分页中有一个点要注意,就是我们的分页sql中一定要使用order by 来指定。
如何实现分页呢?
这里我们以代码演示。
我们如果使用的是mybatis框架,它里面有pageHelper可以实现分页的功能。
package com.ssl.datasource.controller;
import com.github.pagehelper.PageHelper;
import com.ssl.datasource.service.UserService;
import org.apache.catalina.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import java.util.List;
/**
* pageHelperController demo
*/
@Controller
@RequestMapping("pageHelper")
public class PageHelperController {
@Autowired
private UserService userService;
@GetMapping("/users")
public List<User> lists(@RequestParam(defaultValue = "1") int pageNo, @RequestParam(defaultValue = "10") int pageSize) {
PageHelper.startPage(pageNo,pageSize);
return userService.PageHelper();
}
}
package com.ssl.datasource.service;
import com.ssl.datasource.dao.UserDao;
import org.apache.catalina.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class UserService {
@Autowired
UserDao userDao;
public List<User> PageHelper(){
return userDao.pageHelper() ;
}
}
那么如果我们不使用mybatis呢,就是用jdbc。我们该如何分页呢?
这里我们的数据库不同,sql语句也有差异,但是基本原理都是让前端传过来我们需要分页的参数一般是pageSize offset,然后我么把数据的总量,以及每页需要展示多少数据传给前端,这样前端就可以每次都调用来获取不同页的数据。
package com.ssl.datasource.entity;
public class Result<T> {
//是否成功
private Boolean success;
//状态码
private Integer code;
//提示信息
private String msg;
//数据
private T data;
//偏移量
private int offset;
//每页显示的数量
private int pageSize;
//总数
private int rowCount;
public Result() {
}
public Boolean getSuccess() {
return success;
}
public void setSuccess(Boolean success) {
this.success = success;
}
public Integer getCode() {
return code;
}
public void setCode(Integer code) {
this.code = code;
}
public String getMsg() {
return msg;
}
public void setMsg(String msg) {
this.msg = msg;
}
public T getData() {
return data;
}
public void setData(T data) {
this.data = data;
}
//自定义返回结果的构造方法
public Result(Boolean success,Integer code, String msg,T data) {
this.success = success;
this.code = code;
this.msg = msg;
this.data = data;
}
public int getOffset() {
return offset;
}
public void setOffset(int offset) {
this.offset = offset;
}
public int getPageSize() {
return pageSize;
}
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
public int getRowCount() {
return rowCount;
}
public void setRowCount(int rowCount) {
this.rowCount = rowCount;
}
//自定义成功的返回方法
public static Result success(Object data){
Result result = new Result();
result.setSuccess(true);
result.setCode(200);
result.setMsg("请求成功");
result.setData(data);
return result;
}
//自定义异常返回的结果
public static Result defineError(DefinitionException de){
Result result = new Result();
result.setSuccess(false);
result.setCode(de.getErrorCode());
result.setMsg(de.getErrorMsg());
result.setData(null);
return result;
}
//其他异常处理方法返回的结果
public static Result otherError(ErrorEnum errorEnum){
Result result = new Result();
result.setMsg(errorEnum.getErrorMsg());
result.setCode(errorEnum.getErrorCode());
result.setSuccess(false);
result.setData(null);
return result;
}
}