【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;
    }
相关推荐
摇滚侠21 分钟前
Java 零基础全套教程,File 类与 IO 流,笔记 175-176
java·开发语言·笔记
蝎子莱莱爱打怪31 分钟前
零基础用AI写App?兄弟😂 醒醒吧,那只是个玩具罢了!
前端·人工智能·后端
Brookty43 分钟前
lntelliJ IDEA使用技巧
java·开发语言·intellij-idea·java入门
公孙秋1 小时前
IDEA MyBatisCodeHelper Pro插件高版本解密
java·ide·intellij-idea
AI@独行侠1 小时前
【超详细】IDEA 2025版-常用设置配置-一篇文章带您解决idea 2025版本常用配置
java·ide·intellij-idea
砍材农夫1 小时前
物联网 基于netty控制报文结构(发布与接收)
java·开发语言·前端·javascript·物联网
Lucaju1 小时前
做共享目录实时同步,踩过这些坑
java·后端
阿聪谈架构1 小时前
第12章:高级 RAG 技术 —— 让检索更精准、更全面
人工智能·后端
武子康1 小时前
Java-06 深入浅出 MyBatis 数据库1对1模型实战:从概念到查询实现
java·后端
日月云棠1 小时前
4 AbstractStringBuilder —— 可变字符串的骨架实现
java·后端