04PageHelper分页插件使用

查询user表全部数据时,如果数据量过大,展示的就很不方便,此时需要分页展示所查询的数据

MyBatis可以使用第三方的插件来对功能进行扩展,采用的标签为plugins标签,分页助手PageHelper是将分页的复杂操作进行封装,使用简单的方式即可获得分页的相关数据

使用步骤

① 在pom文件中添加通用PageHelper的坐标
      <!-- 分页插件坐标-->
        <dependency>
            <groupId>com.github.pagehelper</groupId>
            <artifactId>pagehelper</artifactId>
            <version>3.7.5</version>
        </dependency>
        <dependency>
            <groupId>com.github.jsqlparser</groupId>
            <artifactId>jsqlparser</artifactId>
            <version>0.9.1</version>
        </dependency>

② 在mybatis核心配置文件mybatis-config.xml中配置PageHelper插件

    <!--配置分页助手插件,-->
    <plugins>
        <plugin interceptor="com.github.pagehelper.PageHelper">
            <!-- 配置方言-->
            <property name="dialect" value="mysql"></property>
        </plugin>
    </plugins>

③ 测试分页数据

    @Test
    public void test01() throws IOException {
        InputStream resourceAsStream = Resources.getResourceAsStream("mybatis-config.xml");
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
        SqlSession session = sqlSessionFactory.openSession(true);//开启事务 默认是关闭的
        UserMapper userMapper = session.getMapper(UserMapper.class);
        //设置分页相关参数   当前页+每页显示的条数
        PageHelper.startPage(1,3);//从第2页开始展示三条数据  不等同于limit语法
//        PageHelper.startPage(2,3);//从第2页开始展示三条数据  不等同于limit语法
        List<User> userList = userMapper.findAll();
        for (User user : userList) {
            System.out.println(user);
        }
        //获得与分页相关参数
        PageInfo<User> pageInfo = new PageInfo<User>(userList);
        System.out.println("当前页:"+pageInfo.getPageNum());
        System.out.println("每页显示条数:"+pageInfo.getPageSize());
        System.out.println("总条数:"+pageInfo.getTotal());
        System.out.println("总页数:"+pageInfo.getPages());
        System.out.println("上一页:"+pageInfo.getPrePage());
        System.out.println("下一页:"+pageInfo.getNextPage());
        System.out.println("是否是第一个:"+pageInfo.isIsFirstPage());
        System.out.println("是否是最后一个:"+pageInfo.isIsLastPage());

        session.close();
    }

运行两次查看运行结果

 数据库中的数据为:从第一条开始

注意:

在mysql中limit语法和不等同于分页插件中PageHelper.startPage(1,3);设置的参数,

mysql中limit的语法规则为

-- LIMIT语句传入一个或两个参数  
-- 传入一个参数n时,返回n条数据,从第1条开始
-- 传入两个参数时x,y x是从(x-1)条数据开始查询,返回y条数据
select * from user  LIMIT 0,3

分页插件 PageHelper.startPage(1,3)的执行结果为:第一页显示前三条数据,内部已经把sql返回的结果集通过Page类封装好

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值