MyBatis 的 3 种分页方式

简介: MyBatis 的 3 种分页方式

MyBatis 是一个优秀的持久层框架,提供了丰富的数据库操作功能。在实际开发中,数据分页是一个常见需求。MyBatis 提供了多种方式来实现数据分页,本文将介绍其中的 3 种常用方式。

Limit 和 Offset 分页

在传统的 SQL 中,我们可以使用 LIMITOFFSET 关键字实现分页。这种方式能够方便地控制返回结果的数量和偏移量。

@Mapper
public interface UserMapper {
   
   
    List<User> getUsersByPage(int limit, int offset);
}

在上述代码中,我们定义了一个名为 getUsersByPage 的方法,该方法接收 limitoffset 两个参数。通过使用 LIMITOFFSET 关键字,我们可以在 SQL 查询中指定要返回的记录数及其偏移量。

RowBounds 分页

除了使用 LIMITOFFSET 进行分页之外,MyBatis 还提供了 RowBounds 类来实现分页。RowBounds 是 MyBatis 提供的一个用于控制查询结果集范围的对象。

@Mapper
public interface UserMapper {
   
   
    List<User> getUsersByPage(RowBounds rowBounds);
}

在上述代码中,我们将 RowBounds 对象作为参数传递给数据库查询方法。通过设置 offsetlimit 属性,我们可以控制返回结果的数量和偏移量。

int offset = 0;
int limit = 10;
RowBounds rowBounds = new RowBounds(offset, limit);
List<User> users = userMapper.getUsersByPage(rowBounds);

在实际调用时,我们可以创建一个 RowBounds 对象,并设置相应的 offsetlimit 值。然后将该对象传递给分页查询方法,即可实现数据分页。

PageHelper 插件

除了上述两种方式之外,还有一个非常强大的分页插件可供使用,那就是 MyBatis 的 PageHelper。PageHelper 是一个开源的 MyBatis 分页插件,提供了丰富的分页功能和易于使用的 API。

首先,我们需要引入 PageHelper 的依赖:

<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper</artifactId>
    <version>5.2.1</version>
</dependency>

然后,在 Spring Boot 配置类中配置 PageHelper:

@Configuration
public class MyBatisConfig {
   
   
    @Bean
    public PageInterceptor pageInterceptor() {
   
   
        PageInterceptor pageInterceptor = new PageInterceptor();
        Properties properties = new Properties();
        properties.setProperty("helperDialect", "mysql");
        pageInterceptor.setProperties(properties);
        return pageInterceptor;
    }

    @Bean
    public SqlSessionFactoryBean sqlSessionFactory(DataSource dataSource, PageInterceptor pageInterceptor) throws IOException {
   
   
        SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
        sessionFactory.setDataSource(dataSource);

        // 添加 PageInterceptor 插件
        Interceptor[] plugins = new Interceptor[] {
   
   pageInterceptor};
        sessionFactory.setPlugins(plugins);

        return sessionFactory;
    }
}

在上述配置中,我们创建了一个名为 pageInterceptorPageInterceptor Bean,并设置了相关属性,如数据库方言等。

最后,在需要分页的查询方法上使用 @com.github.pagehelper.PageHelper 注解即可实现分页功能:

@Mapper
public interface UserMapper {
   
   
    @PageHelper(startPage = 1, pageSize = 10)
    List<User> getUsersByPage();
}

在上述代码中,@PageHelper 注解用于标记要进行分页的方法。通过设置 startPagepageSize 属性,我们可以指定当前页数和每页记录数。

总结:

本文介绍了 MyBatis 中的 3 种常用分页方式:Limit 和 Offset 分页、RowBounds 分页以及 PageHelper 插件。每种方式都有各自的优劣和适用场景,开发人员可以根据具体需求选择合适的分页方式。

目录
相关文章
|
7月前
SpringBoot+Mybatis-Plus+PageHelper分页+多条件查询
SpringBoot+Mybatis-Plus+PageHelper分页+多条件查询
186 0
|
4月前
|
SQL XML Java
8、Mybatis-Plus 分页插件、自定义分页
这篇文章介绍了Mybatis-Plus的分页功能,包括如何配置分页插件、使用Mybatis-Plus提供的Page对象进行分页查询,以及如何在XML中自定义分页SQL。文章通过具体的代码示例和测试结果,展示了分页插件的使用和自定义分页的方法。
8、Mybatis-Plus 分页插件、自定义分页
|
1月前
|
SQL Java 数据库连接
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
|
1月前
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
|
2月前
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
78 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
3月前
|
SQL Java 数据库连接
解决mybatis-plus 拦截器不生效--分页插件不生效
本文介绍了在使用 Mybatis-Plus 进行分页查询时遇到的问题及解决方法。依赖包包括 `mybatis-plus-boot-starter`、`mybatis-plus-extension` 等,并给出了正确的分页配置和代码示例。当分页功能失效时,需将 Mybatis-Plus 版本改为 3.5.5 并正确配置拦截器。
1054 6
解决mybatis-plus 拦截器不生效--分页插件不生效
|
3月前
|
SQL XML Java
springboot整合mybatis-plus及mybatis-plus分页插件的使用
这篇文章介绍了如何在Spring Boot项目中整合MyBatis-Plus及其分页插件,包括依赖引入、配置文件编写、SQL表创建、Mapper层、Service层、Controller层的创建,以及分页插件的使用和数据展示HTML页面的编写。
springboot整合mybatis-plus及mybatis-plus分页插件的使用
|
4月前
|
Java 数据库 Spring
MyBatisPlus分页插件在SpringBoot中的使用
这篇文章介绍了如何在Spring Boot项目中配置和使用MyBatis-Plus的分页插件,包括创建配置类以注册分页拦截器,编写测试类来演示如何进行分页查询,并展示了测试结果和数据库表结构。
MyBatisPlus分页插件在SpringBoot中的使用
|
4月前
|
SQL Java 关系型数据库
MyBatis-Plus 分页魅力绽放!紧跟技术热点,带你领略数据分页的高效与便捷
【8月更文挑战第29天】在 Java 开发中,数据处理至关重要,尤其在大量数据查询与展示时,分页功能尤为重要。MyBatis-Plus 作为一款强大的持久层框架,提供了便捷高效的分页解决方案。通过封装数据库分页查询语句,开发者能轻松实现分页功能。在实际应用中,只需创建 `Page` 对象并设置页码和每页条数,再通过 `QueryWrapper` 构建查询条件,调用 `selectPage` 方法即可完成分页查询。MyBatis-Plus 不仅生成分页 SQL 语句,还自动处理参数合法性检查,并支持条件查询和排序等功能,极大地提升了系统性能和稳定性。
70 0
|
5月前
|
SQL 关系型数据库 Java
mybatis-分页
1. MyBatis RowBounds分页:先查询所有结果,再进行内存分页。 2. PageHelper插件:自动识别数据库类型并添加对应分页关键字,分两步执行:添加分页查询,然后查询总数。 3. SQL分页:直接在SQL中使用`LIMIT`或`ROWNUM`等进行分页。 4. 数组分页:DAO层查询所有数据,Service层通过`subList`方法实现分页。 5. 拦截器分页:自定义拦截器对特定方法进行拦截,并在SQL语句中添加分页参数。 6. 总结:逻辑分页适合小数据量,物理分页适合大数据量避免内存溢出。物理分页优于逻辑分页。