Maven+Mybatis+Spring+SpringMVC实现分页查询

it2022-06-08  87

转载:http://www.cnblogs.com/zhangtan/p/5846955.html

一、项目搭建

关于项目搭建,小宝鸽以前写过一篇Spirng+SpringMVC+Maven+Mybatis+MySQL项目搭建,这篇文章提供了详细的搭建过程,而且提供了源码下载,接下来的将在这个源码的基础上继续开发。所以建议各位猿友可以把猿友下载一下。

二、分页插件的介绍

博主采用的插件是PageHelper这个插件,使用起来十分方便。该插件支持以下数据库:

1 2 3 4 5 6 7 8 9 10 Oracle Mysql MariaDB SQLite Hsqldb PostgreSQL DB2 SqlServer( 2005 +) Informix H2

对应于github的项目地址: https://github.com/pagehelper/Mybatis-PageHelper。 关于使用建议猿友们可以详细阅读下这里的介绍: http://git.oschina.net/free/Mybatis_PageHelper/blob/master/wikis/HowToUse.markdown 读一遍之后可能还不能完全懂怎么使用,可以先看完博主的这篇文章,然后慢慢再消化,但是上面的那篇文章还是需要从头到尾看一遍。

三、PageHelper的使用

在”一、项目搭建“里下载好了源码,下载的源码导入eclipse后的结构里面,有如下的文件:

接下来我们并不需要新增文件,直接在这些文件上修改就好了。

3.1、引入依赖

在pom.xml文件添加如下依赖:

1 2 3 4 5 6 <!-- mybatis分页插件依赖 --> <dependency>      <groupId>com.github.pagehelper</groupId>      <artifactId>pagehelper</artifactId>      <version> 4.0 . 0 </version> </dependency>

3.2、在Mybatis配置xml中配置拦截器插件

在mybatis-config.xml文件中添加插件后的内容如下:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 <?xml version= "1.0"  encoding= "UTF-8" ?>  <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"  "http://mybatis.org/dtd/mybatis-3-config.dtd" >  <configuration>    <plugins>      <!-- com.github.pagehelper为PageHelper类所在包名 -->      <plugin interceptor= "com.github.pagehelper.PageHelper" >          <property name= "dialect"  value= "mysql" />          <!-- 该参数默认为 false  -->          <!-- 设置为 true 时,会将RowBounds第一个参数offset当成pageNum页码使用 -->          <!-- 和startPage中的pageNum效果一样-->          <property name= "offsetAsPageNum"  value= "true" />          <!-- 该参数默认为 false  -->          <!-- 设置为 true 时,使用RowBounds分页会进行count查询 -->          <property name= "rowBoundsWithCount"  value= "true" />          <!-- 设置为 true 时,如果pageSize= 0 或者RowBounds.limit = 0 就会查询出全部的结果 -->          <!-- (相当于没有执行分页查询,但是返回结果仍然是Page类型)-->          <property name= "pageSizeZero"  value= "true" />          <!-- 3.3 . 0 版本可用 - 分页参数合理化,默认 false 禁用 -->          <!-- 启用合理化时,如果pageNum< 1 会查询第一页,如果pageNum>pages会查询最后一页 -->          <!-- 禁用合理化时,如果pageNum< 1 或pageNum>pages会返回空数据 -->          <property name= "reasonable"  value= "false" />          <!-- 3.5 . 0 版本可用 - 为了支持startPage(Object params)方法 -->          <!-- 增加了一个`params`参数来配置参数映射,用于从Map或ServletRequest中取值 -->          <!-- 可以配置pageNum,pageSize,count,pageSizeZero,reasonable,不配置映射的用默认值 -->          <!-- 不理解该含义的前提下,不要随便复制该配置 -->          <property name= "params"  value= "pageNum=start;pageSize=limit;" />          <!-- always总是返回PageInfo类型,check检查返回类型是否为PageInfo,none返回Page -->          <property name= "returnPageInfo"  value= "check" />      </plugin> </plugins> </configuration>

3.3、mapper文件添加sql

在userMapper.xml文件里面添加sql:

1 2 3 4 5 6 7 8 9 10 <!-- 根据用户名查询 --> <select id= "selectUserByUserName"  parameterType= "java.lang.String"  resultMap= "BaseResultMap" >      SELECT *      FROM t_user      WHERE 1  = 1      < if  test= "userName != null and userName !=''" >          AND USER_NAME = #{userName,jdbcType=VARCHAR}      </ if >      ORDER BY USER_ID </select>

3.4、dao添加对用方法

UserDao.java添加如下方法:

1 List<User> selectUserByUserName( @Param ( "userName" ) String userName);

记得@Param必须有

3.5、service添加分页查询方法

UserService.java文件添加方法

1 PageInfo<User> queryByPage(String userName,Integer pageNo,Integer pageSize);

3.6、实现类添加对应实现

UserServiceImpl.java添加实现方法

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 @Override public  PageInfo<User> queryByPage(String userName, Integer pageNo,Integer pageSize) {      pageNo = pageNo == null ? 1 :pageNo;      pageSize = pageSize == null ? 10 :pageSize;      PageHelper.startPage(pageNo, pageSize);      List<User> list = userDao.selectUserByUserName(userName);      //用PageInfo对结果进行包装      PageInfo<User> page = new  PageInfo<User>(list);      //测试PageInfo全部属性      System.out.println(page.getPageNum());      System.out.println(page.getPageSize());      System.out.println(page.getStartRow());      System.out.println(page.getEndRow());      System.out.println(page.getTotal());      System.out.println(page.getPages());      System.out.println(page.getFirstPage());      System.out.println(page.getLastPage());      System.out.println(page.isHasPreviousPage());      System.out.println(page.isHasNextPage());      return  page; }

3.7、单元测试类添加分页查询测试方法

UserServiceTest.java文件添加方法:

1 2 3 4 5 @Test       public  void  queryByPageTest(){           PageInfo<User> page =  userService.queryByPage( null , 1 , 1 );          System.out.println(page);      }

3.8、运行

在小宝鸽进行了上面的修改之后,第一运行报错了!!!!最后是pom.xml文件注释了下面两个包的依赖才运行成功了,注释的依赖如下:

具体原因现在小宝鸽也不知道,应该是包有冲突的原因吧,如果猿友们知道原因麻烦私信我或评论解释一下。

然后运行单元测试类,结果如下:

3.9、补充说明

在3.8中,我注释了那两个包依赖是web项目相关的依赖,如果仍需要进行前端开发的猿友可以引入tomcat就好了,引入结果如下:

引入过程:

选中项目右键–>build path,然后如下操作:

4、源码下载

http://download.csdn.net/detail/u013142781/9379685

来自: http://blog.csdn.net//u013142781/article/details/50410243

转载于:https://www.cnblogs.com/jay36/p/7717842.html

相关资源:SSM(Spring mybatis Springmvc) maven Ajax实现分页功能

最新回复(0)