• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > [DB][MyBatis]利用mybatis-paginator实现分页

[DB][MyBatis]利用mybatis-paginator实现分页

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了mybatis等相关知识,希望本文的分享对您有所帮助

利用mybatis-paginator实现分页 1、mybatis-paginator简介 mybatis-paginator是gethub上的一个开源项目、用于java后台获取分页数据、该开源项目还提供一个列表组件(mmgrid)用于前端展示。 该开源项目地址:https://github.com/miemiedev 2、该开源项目的使

利用mybatis-paginator实现分页

1、mybatis-paginator简介

mybatis-paginator是gethub上的一个开源项目、用于java后台获取分页数据、该开源项目还提供一个列表组件(mmgrid)用于前端展示。

该开源项目地址:https://github.com/miemiedev

2、该开源项目的使用说明:

Maven中加入依赖:

<dependencies>  
  ...  
    <dependency>  
        <groupId>com.github.miemiedev</groupId>  
        <artifactId>mybatis-paginator</artifactId>  
        <version>1.2.10</version>  
    </dependency>  
  ...  
</dependencies>


Mybatis配置文件添加分页插件:

<?xmlversionxmlversion="1.0"encoding="UTF-8"?>  
<!DOCTYPE configuration  PUBLIC "-//ibatis.apache.org//DTD Config 3.0//EN"  
"http://ibatis.apache.org/dtd/ibatis-3-config.dtd">  
<configuration>  
    <plugins>  
        <plugin interceptor="com.github.miemiedev.mybatis.paginator.OffsetLimitInterceptor">  
            <propertynamepropertyname="dialectClass"value="com.github.miemiedev.mybatis.paginator.
            dialect.OracleDialect"/>  
        </plugin>  
     </plugins>  
</configuration>


创建一个查询,内容可以是任何Mybatis表达式,包括foreach和if等:

<selectidselectid="findByCity"resultType="map">  
    select * from TEST_USER where city = #{city};  
</select>


Dao中的方法或许是这样(用接口也是类似):

public List findByCity(String city, PageBounds pageBounds){
    Mapparams =new HashMap();
    params.put("city",city);
    returngetSqlSession().selectList("db.table.user.findByCity", params, pageBounds);
}


调用方式(分页加多列排序):

int page = 1; //页号
int pageSize = 20; //每页数据条数
String sortString = "age.asc,gender.desc";//如果你想排序的话逗号分隔可以排序多列

PageBounds pageBounds = newPageBounds(page, pageSize , Order.formString(sortString));

List list = findByCity("BeiJing",pageBounds);

//获得结果集条总数
PageList pageList = (PageList)list;
System.out.println("totalCount: "+ pageList.getPaginator().getTotalCount());

PageList类是继承于ArrayList的,这样Dao中就不用为了专门分页再多写一个方法。

使用PageBounds这个对象来控制结果的输出,常用的使用方式一般都可以通过构造函数来配置。

new PageBounds();//默认构造函数不提供分页,返回ArrayList
new PageBounds(int limit);//取TOPN操作,返回ArrayList
new PageBounds(Order... order);//只排序不分页,返回ArrayList
new PageBounds(int page, int limit);//默认分页,返回PageList
new PageBounds(int page, int limit, Order... order);//分页加排序,返回PageList
new PageBounds(int page, int limit, Listorders,boolean containsTotalCount);
//使用containsTotalCount来决定查不查询totalCount,即返回ArrayList还是PageList


=========================================

如果用的是Spring MVC的话可以把JSON的配置写成这样:

<mvc:annotation-driven>  
    <mvc:message-converters register-defaults="true">  
        <bean class="org.springframework.http.converter.StringHttpMessageConverter">  
            <constructor-argvalueconstructor-argvalue="UTF-8"/>          
        </bean>  
   
        <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">  
             <property name="objectMapper">  
             <bean class="com.github.miemiedev.mybatis.paginator.jackson2.PageListJsonMapper"/>  
             </property>  
         </bean>  
     </mvc:message-converters>  
 </mvc:annotation-driven>

那么在Controller就可以这样用了:


@ResponseBody
@RequestMapping(value ="/findByCity.json")
public List findByCity(@RequestParam String city,
                 @RequestParam(required =false,defaultValue ="1") intpage,
                 @RequestParam(required =false,defaultValue ="30") intlimit,
                 @RequestParam(required =false) String sort,
                 @RequestParam(required =false) String dir) {
 
    return userService.findByCity(city, newPageBounds(page, limit, Order.create(sort,dir)));
}




然后序列化后的JSON字符串就会变成这样的:

{
    "items":[
        {"NAME":"xiaoma","AGE":30,"GENDER":1,"ID":3,"CITY":"BeiJing"},
        {"NAME":"xiaoli","AGE":30,"SCORE":85,"GENDER":1,"ID":1,"CITY":"BeiJing"},
        {"NAME":"xiaowang","AGE":30,"SCORE":92,"GENDER":0,"ID":2,"CITY":"BeiJing"},
        {"NAME":"xiaoshao","AGE":30,"SCORE":99,"GENDER":0,"ID":4,"CITY":"BeiJing"}
    ],

    "slider": [1, 2, 3, 4, 5, 6, 7],
    "hasPrePage":false,
    "startRow": 1,
    "offset": 0,
    "lastPage":false,
    "prePage": 1,
    "hasNextPage":true,
    "nextPage": 2,
    "endRow": 30,
    "totalCount": 40351,
    "firstPage":true,
    "totalPages": 1346,
    "limit": 30,
    "page": 1
}

=========================================

在SpringMVC中使用JSTL的话可以参考一下步骤(懒人用法)

在Spring配置文件中加入拦截器,或则参考拦截器实现定义自己的拦截器

<mvc:interceptors>  
    <mvc:interceptor>  
        <mvc:mapping path="/**"/>  
       <bean class="com.github.miemiedev.mybatis.paginator.springmvc.PageListAttrHandlerInterceptor"/>  
    </mvc:interceptor>  
</mvc:interceptors>

然后Controller方法可以这样写

@RequestMapping(value ="/userView.action")
public ModelAndView userView(@RequestParam String city,
                 @RequestParam(required =false,defaultValue ="1")intpage,
                 @RequestParam(required =false,defaultValue ="30")intlimit,
                 @RequestParam(required =false) String sort,
                 @RequestParam(required =false) String dir) {
    List users = userService.findByCity(city,newPageBounds(page, limit, Order.create(sort,dir)));
    returnnewModelAndView("account/user","users", users);
}

JSP中就可以这样用了,拦截器会将PageList分拆添加Paginator属性,默认命名规则为"原属性名称"+"Paginator"

<table>  
    <c:forEach items="${users}"var="user">  
        <tr>  
            <td>${user['ID']}</td>  
            <td>${user['NAME']}</td>  
            <td>${user['AGE']}</td>  
        </tr>  
    </c:forEach>  
</table>  
  
上一页: ${usersPaginat
  


 
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

相关文章

  • 2018-12-05配置mysql允许远程连接的方法
  • 2018-12-05Oracle动态交叉表生成
  • 2017-05-11MySQL基准测试套件Benchmark安装DBI组件过程分享
  • 2018-12-05MySql查询时间段的方法示例代码
  • 2018-12-05MySQL 5.6 如何更改安全的处理密码探讨
  • 2018-12-05MySQL学习之外键的图文详解
  • 2018-12-05sql查询某字段的相同值
  • 2018-12-05mysql 主从服务器的简单配置
  • 2018-12-05由于文件权限问题导致SQL Server 2008 无法正常启动解决
  • 2017-05-11关于mysql中innodb的count优化问题分享

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • 长期使用中型Access数据库的一点经验与缺点
    • MySQL中show命令方法得到表列及整个库的详细信息(精品珍藏)
    • 关于CentOS7如何使用rpm包安装MySQL的详细介绍
    • 分享MySql基于ssl安全连接的主从复制的详细介绍
    • Windows下使用Cygwin编译MySQL客户端
    • SQL语句练习实例之六 人事系统中的缺勤(休假)统计
    • SQL Server 2008的逻辑查询处理步骤
    • 使用mysql_fetch_object()函数获取结果集中一行作为对象(PHP操作MySQL数据库的方法五)
    • mysql导入数据大小设置方法
    • mysql数据控制语言实例分享

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有