【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;
    }
相关推荐
铁皮饭盒7 小时前
bun直接tsx,优雅!
javascript·后端
Cosolar7 小时前
藏在 Claude Code 里的极致浪漫:完整 187 条 Spinner Verbs 全收录
后端·程序员·代码规范
Csvn8 小时前
Linux 防火墙管理 — firewalld 实战
后端
Csvn8 小时前
`functools.lru_cache` —— 一行代码搞定缓存加速
后端·python
leeyi8 小时前
Multi-Agent:让多个 AI 分工协作完成复杂任务
后端·aigc·agent
长栎8 小时前
你的策略模式是 Map<String, Strategy>?那不过是最廉价的 if-else 替代品
后端
长栎8 小时前
你写的 abstract class 里全是钩子方法——模板模式不是让你填空,是让你别越界
后端
ping某8 小时前
语法树,到底是一棵什么形状的树?
后端
_柳青杨8 小时前
一文吃透 Node.js 事件循环:从原理到 Node 20+ 重大变更
javascript·后端
Alson_Code9 小时前
人机协作项目文档--HITL-AgentScope
后端·aigc·ai编程