【SpringBoot】-- 使用PageHelper实现分页查询

1、PageBean

PageBean实体类:

复制代码
@Data
@NoArgsConstructor
@AllArgsConstructor
public class PageBean <T>{
    private Long total;//总条数
    private List<T> items;//当前页数据集合
}

2、Controller

Controller类:

前端需要传入页码和每页数量。以PageBean类型返回。

3、Impl

具体实现:

调用PageHelper的startPage方法;根据条件查询数据库中所有的数据并保存到list中,将list强转为Page类型,调用Page类型的setTotal和setItems方法可以实现分页,最后返回PageBean。

复制代码
    @Override
    public PageBean<Player> list(Integer pageNum, Integer pageSize, Integer categoryId,String name) {
        //创建PageBean对象
        PageBean<Player> pb = new PageBean<>();
        //开启分页查询 pagehelper
        PageHelper.startPage(pageNum,pageSize);
        //调用mapper
        Map<String,Object> map = ThreadLocalUtil.get();
        Integer userId;
        if(map != null){
            userId = (Integer) map.get("id");
        }else{
            userId = null;
        }
        List<Player> as = playerMapper.list(userId,categoryId,name);
        Page<Player> p = (Page<Player>) as;

        //把数据填充到pagebean
        pb.setTotal(p.getTotal());
        pb.setItems(p.getResult());
        return pb;
    }
相关推荐
姗姗的鱼尾喵1 天前
Java 面试内容分享
java·spring boot·面试
渡过晚枫1 天前
[第十六届蓝桥杯/java]2.2025
java·职场和发展·蓝桥杯
6+h1 天前
【Spring】Service层常用注解详解
java·后端·spring
REDcker1 天前
Linux C++ 内存泄漏排查分析手册
java·linux·c++
杰克尼1 天前
苍穹外卖--day11
java·数据库·spring boot·mybatis·notepad++
weixin199701080161 天前
搜好货商品详情页前端性能优化实战
java·前端·python
XiYang-DING1 天前
【Java SE】Java代码块详解
java·开发语言·python
白云如幻1 天前
【JDBC】面向对象的思路编写JDBC程序
java·数据库
摇滚侠1 天前
Java SpringBoot 项目,项目启动后执行的方法,有哪些方式实现
java·开发语言·spring boot
木易士心1 天前
告别手写SQL? Cursor智能生成实战指南与避坑技巧
后端·ai编程