MyBatis 中如何实现分页 ?

1. MyBatis 中如何实现分页 ?

MyBatis 中的分页有两种实现方式:物理分页 or 逻辑分页

【物理分页】

1.1 原生 SQL 物理分页

物理分页是通过 SQL 查询语句,LIMIT 语法进行分页的,它是在数据库引擎层面实现的。

1.2 PageHepler 插件实现分页

物理分页还可以使用 PageHepler 插件来实现。

代码示例:

  1. service、dao、xml 层查询整表数据 - getALl()
  2. service 接口,以及实现类新增分页方法 getAllByPage()
  3. controller 层调用分页方法即可。
@Resource
private UserMapper userMapper;

public List getAll() {
    return userMapper.getAll();
}

public PageInfo getAllByPage(Integer pIndex, Integer pSize) {
    PageHelper.startPage(pIndex, pSize); // 关键代码
    List list = userMapper.getAll();
    PageInfo pageInfo = new PageInfo<>(list); // 关键代码
    return pageInfo;
}

【逻辑分页】

        使用 MyBatis 自带的 RowBounds 进行分页就是逻辑分页,它是一次性将符合条件的所有数据查询出来放到内存中,然后在内存中进行分页的,而且内存中是没有索引的,所以数据量非常大的时候,不建议使用。

关键代码:

RowBounds rowBounds = new RowBounds(offset,limit);
List results = sqlSession.selectList("getUserList",null,rowBounds);

面试官问:RowBounds 是一次性查询全部数据吗 ?

        答案是否。首先 MyBatis 是对 JDBC 的封装,而在 JDBC 驱动中有一个 Fetch Size 的配置,它规定了每次最多从数据库中查询出多少条数据。这个 Fetch Size 的默认值是 1000.

于是我们可以在 xml 的 select * from userinfo;

你可能感兴趣的:(JavaEE进阶,mybatis,java,spring)