Mybatis分页查询的实现(Rowbounds和PageHelper)

2023-01-21 0 4,028

我们实现查询除了

@org.junit.Test
    public void test02(){
        SqlSession session = MybatisUtil.getSession();

        UserDao mapper = session.getMapper(UserDao.class);
        List<User> allUser = mapper.getAllUser();

        session.close();
        for (User user : allUser) {
            System.out.println(user);
        }


    }

还有这样的方式,Mybatis官网有介绍

@org.junit.Test
    public void test06(){
        SqlSession session = MybatisUtil.getSession();
        //参数是接口的全限定类名加包名
        List<User> users = session.selectList(\"com.dongmu.dao.UserDao.getAllUser\");

        for (User user : users) {
            System.out.println(user);
        }

        session.close();
    }

那么我们下面就学习一下一个

Mybatis分页查询的实现(Rowbounds和PageHelper)

@org.junit.Test
    public void test07(){

        RowBounds bounds =new RowBounds(0,3);

        SqlSession session = MybatisUtil.getSession();



        List<User> users = session.selectList(\"com.dongmu.dao.UserDao.getAllUser\",null,bounds);


        for (User user : users) {
            System.out.println(user);
        }

        session.close();
    }

Mybatis分页查询的实现(Rowbounds和PageHelper)

这里总结一下自己注意到的细节,它的sql语句我们发现是查询的所有的,所以它实际上是逻辑分页,也就是说把结果全部查询除了然后进行按游标分页。

物理分页:物理分页就是数据库本身提供了分页方式,如MySQL的limit,oracle的rownum ,好处是效率高,不好的地方就是不同数据库有不同的搞法

逻辑分页:利用游标分页,好处是所有数据库都统一,坏处就是因为先查询到所有数据,所有效率低。

下面我们再介绍一个分页插件PageHelper
使用方式:

加入依赖:

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

在mybatis的主配置文件中,在<environments>之前加入

<plugins>
 <plugin interceptor=\"com.github.pagehelper.PageInterceptor\" />
</plugins>

在进行失去了查询之前使用方法:

PageHelper.startPage(pageNum,pageSize);

Mybatis分页查询的实现(Rowbounds和PageHelper)

查询结果

Mybatis分页查询的实现(Rowbounds和PageHelper)

可以发现我们的PageHelper用到的是PreparedStatement进行的物理分页查询。

:本文采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可, 转载请附上原文出处链接。
1、本站提供的源码不保证资源的完整性以及安全性,不附带任何技术服务!
2、本站提供的模板、软件工具等其他资源,均不包含技术服务,请大家谅解!
3、本站提供的资源仅供下载者参考学习,请勿用于任何商业用途,请24小时内删除!
4、如需商用,请购买正版,由于未及时购买正版发生的侵权行为,与本站无关。
5、本站部分资源存放于百度网盘或其他网盘中,请提前注册好百度网盘账号,下载安装百度网盘客户端或其他网盘客户端进行下载;
6、本站部分资源文件是经压缩后的,请下载后安装解压软件,推荐使用WinRAR和7-Zip解压软件。
7、如果本站提供的资源侵犯到了您的权益,请邮件联系: 442469558@qq.com 进行处理!

猪小侠源码-最新源码下载平台 Java教程 Mybatis分页查询的实现(Rowbounds和PageHelper) http://www.20zxx.cn/462970/xuexijiaocheng/javajc.html

猪小侠源码,优质资源分享网

常见问题
  • 本站所有资源版权均属于原作者所有,均只能用于参考学习,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担
查看详情
  • 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,建议提前注册好百度网盘账号,使用百度网盘客户端下载
查看详情

相关文章

官方客服团队

为您解决烦忧 - 24小时在线 专业服务