主题
mybatis pager的应用
场景:有许多商品,前端通过分页来展示这些商品
1、逻辑部分
- 调用 PageHelper 的 startPage
- 把全部的 Product 通过 sql 从数据库中取出(mybatis pager 会自动帮我们取出所传参数的数量)
- 创建 pageInfo 把 全部的 Product 当做参数传入
java
/**
* @param pageNum 第几页
* @param pageSize 每页展示多少个
* ServerResponse 是我所创建的通用的类,不想用去掉即可
*/
public ServerResponse<PageInfo> getProductList(int pageNum, int pageSize){
PageHelper.startPage(pageNum, pageSize);
List<Product> productList = productMapper.selectList(pageNum, pageSize); //调用sql查询
PageInfo pageResult = new PageInfo(productList);
return ServerResponse.createBySuccess(pageResult);
}
- 若从数据库取出的Product不合要求,需要修改,可用下面的代码,不需修改则跳过
java
/**
* @param pageNum 第几页
* @param pageSize 每页展示多少个
* newProduct是自定义的新的类
* ServerResponse 是我所创建的通用的类,不想用去掉即可
*/
public ServerResponse<PageInfo> getProductList(int pageNum, int pageSize){
PageHelper.startPage(pageNum, pageSize);
List<Product> productList = productMapper.selectList(pageNum, pageSize); // 调用sql查询
List<newProduct> newProductList = Lists.newArrayList();
for(Product productItem : productList){
newProduct newProductItem = change(productItem);
newProductList.add(newProductItem);
}
PageInfo pageResult = new PageInfo(productList);
pageResult.setList(mewProductList); // !!!需要用setList重构
return ServerResponse.createBySuccess(pageResult);
}
2、sql部分
- mybatis pager 会自动在后面加上
limit #{pageSize} offset #{pageNum}
xml
<select id="selectList" resultMap="BaseResultMap">
select <include refid="Base_Column_List" /> from mmall_product
order by id asc
</select>