pagehelper获取总条数,pagehelper分页使用
PageHelper是mybatis框架的一个插件,用于支持在mybatis执行分页操作,使用非常方便,在这儿写一下基本的使用.
github文档地址:https://github.com/page helper/my batis-page helper/blob/master/wikis/zh/how to use.MD
准备maven项目,并使用关联依赖项Mybatis
log4j(可以在控制台查看sql语句的执行)
mysql-connector(mysql的驱动包)
lombok(用于生成setter,getter方法)
! - -依赖于my batis -
依存
groupIdorg.mybatis/groupId
身份验证/身份验证
版本3.4.6 /版本
/dependency
! -- mysql --
! - https://mvn repository.com/artifact/MySQL/MySQL-connector-Java-- -
依存
groupIdmysql/groupId
artifactidmysql-connector-Java/artifact id
版本5.1.18 /版本
/dependency
! -日志依赖-
依存
groupIdlog4j/groupId
artifactIdlog4j/artifactId
版本1.2.17 /版本
/dependency
! -- lombok --
! - https://mvn repository.com/artifact/org.project lombok/lombok -
依存
groupid org.project lombok/groupid
身份验证/身份验证id
版本1.16.20 /版本
scopeprovided/scope
/dependency
! -- pageHelper依赖-
依存
groupid com.github.page helper/groupid
artifactidpagehelper/artifact id
版本5.1.10 /版本
/dependency
准备student这个表,准备3个字段,id,name,age,几种数据
3、配置项目首先在resources目录下创建Mybatis-config.xml文件,包含数据库连接信息、事务、映射文件路径、日志实现、类别名、类别名
置
<configuration><properties resource="db.properties" /><settings> <!--日志的实现是LOG4J--><setting name="logImpl" value="LOG4J" /></settings><typeAliases><package name="com.ren.domain" /></typeAliases> <!--mybatis的插件配置--><plugins><!-- com.github.pagehelper为PageHelper类所在包名 --><plugin interceptor="com.github.pagehelper.PageInterceptor"><!-- 表示使用mysql的分页方法 --><property name="helperDialect" value="mysql" /><!-- 表示当页码长度为0 的时候,就不进行分页查询 --><property name="pageSizeZero" value="true"/></plugin></plugins><!-- 配置连接数据库四要素 --><environments default="dev"><environment id="dev"><transactionManager type="JDBC" /><dataSource type="POOLED"><property name="driver" value="${driverClassName}" /><property name="url" value="${url}" /><property name="username" value="${username}" /><property name="password" value="${password}" /></dataSource></environment></environments><mappers><mapper resource="com/ren/mapper/StudentMapper.xml" /></mappers></configuration> 4.编写mapper,domain类
Student类,字段名和数据库表中对应的字段名尽量一致
5.首先做高级查询(条件查询)编写StudentMapper类和QueryObject类,在StudentMapper类中编写一个高级查询的方法,名为queryByConditions,根据姓名关键字和年龄范围查询,把查询条件封装到QueryObject类中.QueryObject类包括了姓名的关键字,年龄的范围,QueryObject类中的currentPage,和pageSize用于存储分页的条件
StudentMapper类:
QueryObject类:
编写StudentMapper对应的mapper文件.StudentMapper.xml
4.在mybatis中引入一段配置
<plugins> <!-- com.github.pagehelper为PageHelper类所在包名 --> <plugin interceptor="com.github.pagehelper.PageInterceptor"> <!-- 使用什么数据库 --> <property name="helperDialect" value="mysql"/></plugin></plugins>
5.编写分页的业务,IStudentService,以及实现类StudentServiceImpl,page(qo)方法最终返回一个PageInfo对象
IStudentService的实现类StudentServiceImpl
PageHelper库中中有一个核心类PageInfo封装查询的list,包含了分页信息(结果总数,当前页,上一页,下一页,当前页的结果集),还有一个PageHelper类,在分页查询之前使用PageHelper.startPage(当前页,每一页的条数),完成分页查询操作
调用自己的查询方法queryByConditions()方法查询出的list对象封装到PageInfo中即可完成,PageInfo中包括了分页的结果集
把高级查询返回的list对象(list对象)作为构造器参数传入PageInfo中,即可.
使用Junit5单元测试编写一个StudentMapperTest类
可以观察sql语句,在mapper文件中并没有写limit,pageHelper已经帮我们加上了limit关键字完成了查询.OK了