本文介绍: Springboot如何快速生成分页展示以及统计统计条数公式: 手撕原始代码:1.Mapper(DAO)层:2. Service服务接口层:实现Service服务类:3.Controller层:完结,在postman测试成功!2. Mapper(DAO)层:3.Service接口层:4.实现Service服务类: 4.Controller层(不用改动,与上文一致):5.启动程序:自行进行测试,完结散花!

这是表结构: 

前置知识

分页查询公式():
-- 推导一个公式
-- select * from emp 
-- 	order by empno
-- 	limit 每页显示记录数 * (第几页-1),每页显示记录
统计条数公式:
select count(*) from emp;
自定义一个请求返回格式,使请求结果统一
 
@Data
@NoArgsConstructor
@AllArgsConstructor
public class Result {
    private Integer code;// 响应码: 1代表成功  0 代表失败
    private String mes; // 响应信息 描述字符串
    private Object date; // 返回数据

    public static Result success(){
        return new Result(1, "success", null);
    }

    public static Result success(Object date){
        return new Result(1, "success", date);
    }

    public static Result error(String msg){
        return new Result(0, msg, null);
    }
}

 手撕原始代码

1.Mapper(DAO)层:
@Mapper
public interface EmpMapper {
    @Select("select count(*) from emp")
    public long count();

    @Select("select * from emp limit #{start},#{pageSize}")
    public List<Emp> page(Integer start,Integer pageSize);
}
2. Service服务接口层:
public interface EmpService {
    Pagebean page(Integer page, Integer pageSize);
}
实现Service服务类:
@Service
public class EmpServiceImpl implements EmpService{
    @Autowired
    private EmpMapper empMapper;

    @Override
    public Pagebean page(Integer page, Integer pageSize) {

        //1.获取记录数
        Long count = empMapper.count();

        //2.获取分页查询结果列表
        Integer start = (page-1)*pageSize;
        List<Emp> empList = empMapper.page(start,pageSize);
        //3.封装pageBean对象
        Pagebean pageBean = new Pagebean(count, empList);
        return pageBean;
    }
}
3.Controller层:
@Slf4j
@RestController
public class EmpController {

    @Autowired
    private EmpService empService;

    @GetMapping("/emps")
    public Result page(@RequestParam(defaultValue = "1") Integer page,@RequestParam(defaultValue = "10") Integer pageSize){
        log.info("分页查询参数: {},{}", page,pageSize);
        //调用service分页查询
        Pagebean pagebean =  empService.page(page,pageSize);
        return Result.success(pagebean);
    }
}

完结,在postman测试成功!

使用pagehelper插件快速开发

1.配置pox.xml添加相关依赖
<!--        PageHelper分页插件-->
        <dependency>
            <groupId>com.github.pagehelper</groupId>
            <artifactId>pagehelper-spring-boot-starter</artifactId>
            <version>1.4.2</version>
        </dependency>
2. Mapper(DAO)层:
@Mapper
public interface EmpMapper {
    @Select("select * from emp")
    public List<Emp> list();

}
3.Service接口层:
public interface EmpService {
    Pagebean page(Integer page, Integer pageSize);
}

4.实现Service服务类:

@Service
public class EmpServiceImpl implements EmpService{
    @Autowired
    private EmpMapper empMapper;
    @Override
    public Pagebean page(Integer page, Integer pageSize) {
        //1.设置分页参数
        PageHelper.startPage(page, pageSize);

        //2.执行查询
        List<Emp> empList = empMapper.list();
        Page<Emp> p = (Page<Emp>) empList;

        //3.封装pageBean对象
        Pagebean pageBean = new Pagebean(p.getTotal(), p.getResult());
        return pageBean;
    }
}
 4.Controller层(不用改动,与上文一致):
@Slf4j
@RestController
public class EmpController {

    @Autowired
    private EmpService empService;

    @GetMapping("/emps")
    public Result page(@RequestParam(defaultValue = "1") Integer page,@RequestParam(defaultValue = "10") Integer pageSize){
//        if(page == null){
//            page = 1;
//        }
//        if(pageSize == null) {
//            pageSize = 10;
//        }
        log.info("分页查询参数: {},{}", page,pageSize);
        //调用service分页查询
        Pagebean pagebean =  empService.page(page,pageSize);
        return Result.success(pagebean);
    }
}
5.启动程序

自行进行测试,完结散花! 

原文地址:https://blog.csdn.net/qq_58341172/article/details/134641089

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_29314.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注