Mybatis分页实现流程

第一步:封装分页bean
public class PaginationVO implements Serializable{


private static final long serialVersionUID = 1L;


private Integer page;//对应easyui页面的page

private Integer rows;//对应easyui页面的rows

private Integer begNum;

private Integer endNum;


public Integer getPage() {
return page;
}


public void setPage(Integer page) {
this.page = page;
}


public Integer getRows() {
return rows;
}


public void setRows(Integer rows) {
this.rows = rows;
}


/**
* 返回 begNum 的值
* @return begNum
*/

public Integer getBegNum() {
return begNum;
}



/**
* 设置 begNum 的值
* @param begNum begNum
*/
public void setBegNum(Integer page, Integer rows) {
this.begNum = (page - 1) * rows;
}


/**
* 返回 endNum 的值
* @return endNum
*/
public Integer getEndNum() {
return endNum;
}


/**
* 设置 endNum 的值
* @param endNum endNum
*/
public void setEndNum(Integer endNum) {
this.endNum = endNum;
}


/**

* 描述 设置分页数据
*/
public void setPaginationData() {
this.begNum = (page - 1) * rows;
this.endNum = rows;
}
}








第二步:业务vo继承上面的类
public class FormInfoVO extends PaginationVO{...}




第三步:调用
json =new  GridListJson();
try {
instance.setPaginationData();
json.setRows(userService.findUserList(instance));
json.setTotal(userService.getUserTotal(instance));




第四步:page.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="page">
<sql id="pageBegin">
SELECT A.* FROM (
  </sql>
 
  <sql id="pageEnd">
) A LIMIT #{begNum}, #{endNum}
  </sql>
 
  <sql id="pageCount">
  SELECT count(1) as cnt
  </sql>
</mapper>




第五步:UserManaMapper.xml业务映射文件调用分页组件
<select id="findUserList" parameterType="userVO"
resultMap="BaseResultMap">
<include refid="page.pageBegin" /> <!--分页组件调用 前缀-->
select * from t_user
<include refid="page.pageEnd" /><!--分页组件调用 后缀-->
</select>
   




mybatis中加入对上面两个映射文件的配置
<mappers>
<mapper resource="mybatis/page.xml"></mapper>
<mapper resource="mybatis/UserManaMapper.xml"/>
</mappers>






前台说明:


<table id="tt" class="easyui-datagrid" style="width:600px;height:250px"  
        url="datagrid2_getdata.php"  
        title="Load Data" iconCls="icon-save"  
        rownumbers="true" pagination="true">  
    <thead>  
        <tr>  
            <th field="userid" width="80">user ID</th>  
            <th field="name" width="80">user name</th>  
        </tr>  
    </thead>  
</table>  
我们定义datagrid的datagrid和设置'pagination'属性为true,它将生成一个分页工具栏在datagrid的底部pagination将发送2个参数到服务器:
page: 页码,起始值 1.
rows: 每页显示行
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

静山晚风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值