1.首先根据自己实际需求编写实体类

 import java.io.Serializable;

 public class User implements Serializable{  //最好将该实体类序列化

     private static final long serialVersionUID = 1L;

     private Integer id;
     private String name;
     private String birthday;
     private String gender;
     private String career;
     private String address;
     private String mobile;
     private String picPath;

     public User() {
     }

     public User(Integer id, String name, String birthday, String gender, String career, String address, String mobile,
             String picPath) {
         this.id = id;
         this.name = name;
         this.birthday = birthday;
         this.gender = gender;
         this.career = career;
         this.address = address;
         this.mobile = mobile;
         this.picPath = picPath;
     }

     public Integer getId() {
         return id;
     }
     public void setId(Integer id) {
         this.id = id;
     }
     public String getName() {
         return name;
     }
     public void setName(String name) {
         this.name = name;
     }
     public String getBirthday() {
         return birthday;
     }
     public void setBirthday(String birthday) {
         this.birthday = birthday;
     }
     public String getGender() {
         return gender;
     }
     public void setGender(String gender) {
         this.gender = gender;
     }
     public String getCareer() {
         return career;
     }
     public void setCareer(String career) {
         this.career = career;
     }
     public String getAddress() {
         return address;
     }
     public void setAddress(String address) {
         this.address = address;
     }
     public String getMobile() {
         return mobile;
     }
     public void setMobile(String mobile) {
         this.mobile = mobile;
     }
     public String getPicPath() {
         return picPath;
     }
     public void setPicPath(String picPath) {
         this.picPath = picPath;
     }

     @Override
     public String toString() {
         return "User [id=" + id + ", name=" + name + ", birthday=" + birthday + ", gender=" + gender + ", career="
                 + career + ", address=" + address + ", mobile=" + mobile + ", picPath=" + picPath + "
                 + "]";
     }
 }

2.编写分页所需要的通用bean,这是关键的一步。如果你用的是easyUI框架写的管理系统,currPage,PageSize,total,totalPage,rows这几个参数是必须的。

 import java.util.List;

 public class PageNationBean<T> {
     //请求参数
     private Integer currPage=1;//当前页
     private Integer PageSize=10;//页面数据条数

     //响应数据
     private Integer total;    //数据的总记录数
     private Integer totalPage;//总页数
     private List<T> rows;

     public PageNationBean() {
     }

     public PageNationBean(Integer currPage, Integer pageSize, Integer total, Integer totalPage, List<T> rows) {
         this.currPage = currPage;
         this.PageSize = pageSize;
         this.total = total;
         this.totalPage = totalPage;
         this.rows = rows;
     }

     public Integer getCurrPage() {
         return currPage;
     }
     public void setCurrPage(Integer currPage) {
         this.currPage = currPage;
     }
     public Integer getPageSize() {
         return PageSize;
     }
     public void setPageSize(Integer pageSize) {
         PageSize = pageSize;
     }
     public Integer getTotal() {
         return total;
     }
     public void setTotal(Integer total) {
         this.total = total;
     }
     public Integer getTotalPage() {
         return totalPage;
     }
     public void setTotalPage(Integer totalPage) {
         this.totalPage = totalPage;
     }
     public List<T> getRows() {
         return rows;
     }
     public void setRows(List<T> rows) {
         this.rows = rows;
     }
     @Override
     public String toString() {
         return "\n\tPageNationBean [currPage=" + currPage + ", PageSize=" + PageSize + ", total=" + total + ", totalPage="
                 + totalPage + ", rows=" + rows + "]";
     }

 }

3.数据库中建好需要测试的表,插入一定量的数据是肯定的

4.编写映射接口

public interface UserMapper {

    PageNationBean<User> getUsersByPagenation(PageNationBean<User> userBean);

}

5.编写映射所需的xml配置文件

 <?xml version="1.0" encoding="UTF-8" ?>
 <!DOCTYPE mapper
 PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
 "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
 <!-- 命名空间与映射接口的全类名一致 -->
 <mapper namespace="com.yc.us.mapper.UserMapper">

     <resultMap type="PageNationBean" id="PageNationBeanMap">
         <result column="pageSize" property="pageSize"/>
         <result column="currPage" property="currPage"/>
         <collection property="rows" column="{pageSize=pageSize,currPage=currPage}" select="getUsers"/>
     </resultMap>

     <!-- #是采用占用符    $是直接取到值 -->
     <select id="getUsersByPagenation" parameterType="PageNationBean" resultMap="PageNationBeanMap">
         select count(1) total,ceil(count(1)/${pageSize}) totalPage,${pageSize} pageSize,${currPage} currPage from profile
     </select>
     <select id="getUsers" resultType="User">
         select * from
         (select m.*,rownum rn from
         (select * from profile) m where ${currPage}*${pageSize} >=rownum)
         where rn > (${currPage}-1)*${pageSize}
     </select>

 </mapper>

6.根据自己实际需求写一个测试类,进行实际测试

mybatis如何做分页处理的更多相关文章

  1. Mybatis Generator实现分页功能

    Mybatis Generator实现分页功能 分类: IBATIS2013-07-17 17:03 882人阅读 评论(1) 收藏 举报 mybatisibatisgeneratorpage分页 众 ...

  2. Mybatis中的分页

    Mybatis中有哪些分页方式? 数组分页:查询出全部数据,然后再list中截取需要的部分.(逻辑分页) 优点:效率高     缺点:占用内存比较高 sql分页:只从数据库中查询当前页的数据.(物理分 ...

  3. 用PHP+MySQL来做分页的演示

    用php做分页弄懂逻辑关系其实不难,不过我在听课的时候估计是被老师讲的那些变量里的英文单词给听懵了,因为有几个变量的名字都很像,只是换了两三个英文字母而已,有的就少几个这样的,听到一半已经不知道老师讲 ...

  4. mybatis框架中分页的实现

    2.分页的实现? 分页的时候考虑的问题: 分页的大小,分页的索引. 比如:分页的大小为10,分页的起始索引为1(索引从1开始) 第一页:1到10.    起始行号: (页的索引-1)*分页大小+1 结 ...

  5. Ajax做分页

    Ajax做分页 用这种ajax做分页的方法比较简单,把代码直接复制就可以,然后根据实际更改一下里面的参数. .设置分页显示显示的样式,显示效果如下. 复制代码 <style type=" ...

  6. 使用PHP做分页查询(查询结果也显示为分页)

    1.先把数据库里所有的数据分页显示在页面,并在显示数据的表格上方加上查询表单.(加上条件,实现目标结果.) <!DOCTYPE html PUBLIC "-//W3C//DTD XHT ...

  7. SpringBoot+Mybatis配置Pagehelper分页插件实现自动分页

    SpringBoot+Mybatis配置Pagehelper分页插件实现自动分页 **SpringBoot+Mybatis使用Pagehelper分页插件自动分页,非常好用,不用在自己去计算和组装了. ...

  8. SpringBoot+Mybatis+PageHelper实现分页

    SpringBoot+Mybatis+PageHelper实现分页 mybatis自己没有分页功能,我们可以通过PageHelper工具来实现分页,非常简单方便 第一步:添加依赖 <depend ...

  9. 关于使用coreseek并为其做分页的介绍(转)

    coreseek 做分页时找数据总量还真不好找.以为他会给一个方法(函数)什么的去获取,结果却不是.首先需要了解:num_matches: 当前返回的结果数,<= limit设置值.max_ma ...

随机推荐

  1. PL/SQL循环

    1.if循环做判断 SET SERVEROUTPUT ON accept num prompt 'qinshuu'; DECLARE pnum NUMBER :=& num ; BEGIN T ...

  2. 简单的maven配置

    groupId是指com.xx 组织标识 artifactId才是项目名称 2)编译源代码 mvn compile 3)编译测试代码 mvn test-compile 4)清空 mvn clean 5 ...

  3. 企业SOA架构设计理论

    SOA简介 SOA(Service-Oriented Architecture,面向服务架构)是一种将信息系统模块化为服务的架构风格.拥有了服务之后,我们就可以迅速地将这些服务按不同方式重新组合,从而 ...

  4. html页面制作css基本设置

    html{ height: 100%;} *{ margin: 0; padding: 0;}/* tell the browser to render HTML 5 elements as bloc ...

  5. UVa 524 Prime Ring Problem(回溯法)

    传送门 Description A ring is composed of n (even number) circles as shown in diagram. Put natural numbe ...

  6. Mac OS使用brew安装Nginx、MySQL、PHP-FPM的LAMP开发环境

    准备工作 新版的 Mac OS 内置了Apache 和 PHP,我的系统版本是OS X 10.9.3,可以通过以下命令查看Apache和PHP的版本号: httpd -v Server version ...

  7. Mui.ajax请求服务器正确返回json数据格式

    ajax: mui.ajax('http://server-name/login.php',{ data:{ username:'username', password:'password' }, d ...

  8. UVA1637Double Patience(概率 + 记忆化搜索)

    训练指南P327 题意:36张牌分成9堆, 每堆4张牌.每次拿走某两堆顶部的牌,但需要点数相同.如果出现多种拿法则等概率的随机拿. 如果最后拿完所有的牌则游戏成功,求成功的概率. 开个9维数组表示每一 ...

  9. dict与list的in 操作的速度

    今天刷一道题,计算一串数字中其中两个数字相加等于目标值的题目,且取其中最早的两个数字(最后一个数字的位置靠前). 如[1,25,32,4,3,6,9,5]  targer:9  输出 [3,6]   ...

  10. vue.js开发环境搭建

    1.安装node.js(http://www.runoob.com/nodejs/nodejs-install-setup.html) 2.基于node.js,利用淘宝npm镜像安装相关依赖 在cmd ...