PageHelper怎么把查询到的数值插入到Page类的

首先是写的代码
在这里插入图片描述
lambda表达式写法:
在这里插入图片描述

@Service
public class SectionService {
   
    @Autowired
    private SectionMapper sectionMapper;

    public List<Section> getLimit(int start,int limit){
   
        PageInfo<Section> pageInfo = PageHelper.startPage(start, limit).doSelectPageInfo(() -> sectionMapper.findAll());
        return pageInfo.getList();
    }
}

来看一下一些主要类
先看Iselect类

public interface ISelect {
   
    void doSelect();
}

再来看一下Page类

public class Page<E> extends ArrayList<E> implements Closeable {
   
 public <E> PageInfo<E> doSelectPageInfo(ISelect select) {
   
        select.doSelect();
        return this.toPageInfo();
    }
    
 public PageInfo<E> toPageInfo() {
   
        PageInfo<E> pageInfo = new PageInfo(this);
        return pageInfo;
    }
}

我看到这行代码就很疑惑,返回void,并没有赋值,
怎么this(也就是这个page类)中就包含了查询到的结果呢

先了解一下这个
在这里插入图片描述

首来看一下PageMethod类中的部分代码

	public abstract class PageMethod {
   
	//PageMethod 类中含了一个本地线程LOCAL_PAGE 
	//Threadlocal而是一个线程内部的存储类,可以在指定线程内存储数据,数据存储以后,只有指定线程可以得到存储数据
    protected static final ThreadLocal<Page> LOCAL_PAGE = new ThreadLocal();
    }
    protected static void setLocalPage(Page page) 
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis-Plus提供的PageHelper是用于分页查询的工具,它可以帮助我们简化分页查询的代码,提高开发效率。使用PageHelper进行分页查询的步骤如下: 1. 引入MyBatis-Plus的依赖包和PageHelper的依赖包。 2. 在MyBatis的配置文件中配置PageHelper插件。 3. 在DAO层的Mapper接口中定义查询方法,并添加Page对象作为方法参数。 4. 在查询方法中使用PageHelper.startPage()方法设置分页参数,然后调用Mapper接口的查询方法查询数据。 5. 将查询结果封装到Page对象中,并返回Page对象。 下面是一个示例代码: ``` // 引入PageHelper依赖包 <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>5.1.10</version> </dependency> // 在MyBatis的配置文件中配置PageHelper插件 <plugins> <plugin interceptor="com.github.pagehelper.PageInterceptor"> <property name="helperDialect" value="mysql"/> </plugin> </plugins> // 在DAO层的Mapper接口中定义查询方法,并添加Page对象作为方法参数 public interface UserMapper { List<User> selectUserList(Page<User> page); } // 在查询方法中使用PageHelper.startPage()方法设置分页参数,然后调用Mapper接口的查询方法查询数据 public List<User> getUserList(int pageNum, int pageSize) { Page<User> page = new Page<>(pageNum, pageSize); userMapper.selectUserList(page); return page.getRecords(); } ``` 在上面的示例代码中,我们使用PageHelper.startPage()方法设置分页参数,然后调用Mapper接口的selectUserList()方法查询数据查询结果封装在Page对象中,最后返回Page对象中的记录。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值