mybatis利用插件如何实现分页?
- 1.为什么要实现分页查询?
- 2.如何实现分页查询?
- 1.原始sql语句
- 2.使用pageHelper插件
- (1)第一步
- (2)在mybatis主配置文件中进行配置
- (3)使用PageHelper对象
1.为什么要实现分页查询?
想必大家对分页并不陌生,我们浏览网站时,都会看见分页的存在;
那为什么要使用分页呢?主要有以下几点原因!
- 1.提高性能,减少查询数据;
意思是如果我们数据库中有上万条数据,我们不可能一次性查询出来,这样会大大降低性能; - 2.提高用户体验,美化页面
大家想,如果我们不分页,直接把查询的数据全部展示在一页上,用户体验有多不好呀!
2.如何实现分页查询?
1.原始sql语句
要想使用mybatis实现分页,我们可以直接使用sql语句中的limit()
比如我们要查询第一页,共5条数据,我么可以
select * from product limit 0,5;
limit 0 ,5表示从第一条数据开始查到第5条数据
不过有时我们会对sql语句进行优化:
查询第1条到第10条的数据的sql是:select * from table limit 0,10; ->对应我们的需求就是查询第一页的数据:select * from table limit (1-1)*10,10;查询第10条到第20条的数据的sql是:select * from table limit 10,20; ->对应我们的需求就是查询第二页的数据:select * from table limit (2-1)*10,20;查询第20条到第30条的数据的sql是:select * from table limit 20,30; ->对应我们的需求就是查询第三页的数据:select * from table limit (3-1)*10,30; 通过上面的分析,可以得出符合我们自己需求的分页sql格式 pageNo表示第几页,pageSize表示每一页有多少数据 mysql分页:select * from 表 limit (pageNo-1)*pageSize,pageNo*pageSize;
人们总是想着偷懒的!!!因此看看插件怎么用吧!
2.使用pageHelper插件
(1)第一步
在maven中引入依赖
<dependency><groupId>com.github.pagehelper</groupId><artifactId>pagehelper</artifactId><version>5.1.10</version></dependency>
(2)在mybatis主配置文件中进行配置
很简单只需要一个标签,
注意:该标签一定要放在<environments>标签之前
<plugins><plugin interceptor = "com.github.pagehelper.PageInterceptor" /> <plugins>
其实是配置了一个拦截器
(3)使用PageHelper对象
查询语句之前调用PageHelper.startPage()静态方法
除了PageHelper.startPage()方法外,还提供了PageHelper.offsetPage()方法.
在你需要进行分页的mybatis查询方法前调用PageHelper.startPage()即可,
紧跟在这个方法后的第一个mybatis查询方法会被进行分页;
No code No bibi!!!
比如我们在dao层中写了一个查询方法
List<Students> selectAll();
然后对应的mybatis的xml文件:
<select id="selectAll" resultType="com.jw.domain.Student"> select * from student order by id;</select>
然后在service层中调用
有人会问了?你的sql语句不是写的select * from student order by id吗?这不是查询全部数据吗?哪里实现分页了?
别急,这时我们的插件发挥作用了,虽然我们写的是select * from student order by id,但是因为我们多加了这么一行代码
PageHelper.startPage(2,3);
那么在执行sql语句时,插件会为我们自动加上limit,不信,你看!
结果是三条数据,是吧!!
所以,分页查询简单吧!小伙伴赶快使用起来吧