1.概述
最近在做宜立方商城项目时,后台管理系统要求实现分页显示,由于项目使用了Mybatis逆向生成映射文件,所以在此使用了mybatis第三方插件--PageHelper来实现分页这一功能,下面就如何在项目使用这一插件进行说明。
2.使用方法
- 添加依赖 把PageHelper依赖的jar包添加到工程中。官方提供的代码对逆向工程支持的不好,使用参考资料中的pagehelper-fix。首先将下列链接中的pagehelper-fix的maven工程导入myeclipse中,点击run 选择maven install,这步操作便可以把pagehelper-fix安装到本地仓库,从而可以将其当做一个jar包来使用。
pagehelper-fix下载链接:链接: 密码:tgk5
2.修改mybatis配置文件
在Mybatis配置xml中配置拦截器插件:
3. 如何在项目中使用PageHelper
import java.util.List;import org.junit.Test;import org.springframework.context.ApplicationContext;import org.springframework.context.support.ClassPathXmlApplicationContext; import com.github.pagehelper.PageHelper;import com.github.pagehelper.PageInfo; import cn.e3mall.mapper.TbItemMapper;import cn.e3mall.pojo.TbItem;import cn.e3mall.pojo.TbItemExample; /** * @author 熊涛 *分页测试用例 */public class PageHelperTest { @Test public void testPageHelper() throws Exception { //初始化spring容器 ApplicationContext applicationContext = new ClassPathXmlApplicationContext("classpath:spring/applicationContext-*.xml"); //获得Mapper的代理对象 TbItemMapper itemMapper = applicationContext.getBean(TbItemMapper.class); //执行sql语句前设置分页信息使用PageHelper的startPage方法 PageHelper.startPage(1,30); //执行查询 TbItemExample example = new TbItemExample(); Listlist = itemMapper.selectByExample(example); //取分页信息,PageInfo:1.总记录数 2.总页数 3.当前页码 PageInfo pageInfo = new PageInfo<>(list); System.out.println(pageInfo.getTotal()); System.out.println(pageInfo.getPages()); System.out.println(pageInfo.getPageNum()); System.out.println(pageInfo.getPageSize()); }}
4. 在服务层使用PageHelper
@Override public EasyUIDataGridResult getItemList(int page, int rows) { //设置分页信息 PageHelper.startPage(page, rows); //执行查询 TbItemExample example = new TbItemExample(); Listlist = itemMapper.selectByExample(example); //取分页信息 PageInfo pageInfo = new PageInfo<>(list); //创建返回结果对象 EasyUIDataGridResult result = new EasyUIDataGridResult(); result.setTotal(pageInfo.getTotal()); result.setRows(list); return result; }
5. 在控制层使用service
@RequestMapping("/item/list")
@ResponseBodypublic EasyUIDataGridResult getItemList(Integer page, Integer rows) {EasyUIDataGridResult result = itemService.getItemList(page, rows);return result;
}