SSM框架普通分页和pagehelper分页插件的使用

1、普通分页
1.1创建分页实体类

/**
 * 分页 工具类
 */
public class Page{
   
    private int pageNow = 1; // 当前页数
    private int pageSize = 4; // 每页显示记录的条数
    private int totalCount; // 总的记录条数
    private int totalPageCount; // 总的页数
    private int startPos; // 开始位置,从0开始
    private boolean hasFirst;// 是否有首页
    private boolean hasPre;// 是否有前一页
    private boolean hasNext;// 是否有下一页
    private boolean hasLast;// 是否有最后一页
    /**
     * 通过构造函数 传入 总记录数 和 当前页
     * @param totalCount
     * @param pageNow
     */
    public Page(int totalCount, int pageNow) {
   
        this.totalCount = totalCount;
        this.pageNow = pageNow;
    }
    /**
     * 取得总页数,总页数=总记录数/总页数
     * @return
     */
    public int getTotalPageCount() {
   
        totalPageCount = getTotalCount() / getPageSize();
        return (totalCount % pageSize == 0) ? totalPageCount
                : totalPageCount + 1;
    }
    public void setTotalPageCount(int totalPageCount) {
   
        this.totalPageCount = totalPageCount;
    }
    public int getPageNow() {
   
        return pageNow;
    }
    public void setPageNow(int pageNow) {
   
        this.pageNow = pageNow;
    }
    public int getPageSize() {
   
        return pageSize;
    }
    public void setPageSize(int pageSize) {
   
        this.pageSize = pageSize;
    }
    public int getTotalCount() {
   
        return totalCount;
    }
    public void setTotalCount(int totalCount) {
   
        this.totalCount = totalCount;
    }
    /**
     * 取得选择记录的初始位置
     * @return
     */
    public int getStartPos() {
   
        return (pageNow - 1) * pageSize;
    }
    public void setStartPos(int startPos) {
   
        this.startPos = startPos;
    }
    /**
     * 是否是第一页
     * @return
     */
    public boolean isHasFirst() {
   
        return (pageNow == 1) ? false : true;
    }
    public void setHasFirst(boolean hasFirst) {
   
        this.hasFirst = hasFirst;
    }
    /**
     * 是否有首页
     * @return
     */
    public boolean isHasPre() {
   
        // 如果有首页就有前一页,因为有首页就不是第一页,首页从0开始
        return isHasFirst() ? true : false;
    }
    public void setHasPre(boolean hasPre) {
   
        this.hasPre = hasPre;
    }
    /**
     * 是否有下一页
     * @return
     */
    public boolean isHasNext() {
   
        // 如果有尾页就有下一页,因为有尾页表明不是最后一页
        return isHasLast() ? true : false;
    }

    public void setHasNext(boolean hasNext) {
   
        this.hasNext = hasNext;
    }
    /**
     * 是否有尾页
     * @return
     */
    public boolean isHasLast() {
   
        // 如果不是最后一页就有尾页
        return (pageNow == getTotalCount()) ? false : true;
    }

    public void setHasLast(boolean hasLast) {
   
        this.hasLast = hasLast;
    }
}

1.2、在mapper接口中添加分页的抽象方法

	//分页查询
    List<Books> findPages(@Param(value = "startPos") Integer startPos,@Param(value = "pageSize") Integer pageSize) throws Exception;

    //查询总记录数
    Integer getGoodsCount(int id);

1.3、在mapper.xml下添加分页抽象方法相应的sql查询语句

	<select id="findPages" resultType="Books">
      select bookID,bookName,bookCounts,detail from books limit #{startPos},#{pageSize};
    </select>

    <select id="getGoodsCount" parameterType="int" resultType="int">
        select count(#{id}) from books;
    </select>

1.4、在service接口中添加分页的抽象方法

	//分页查询
    List<Books> findPages(@Param(value = "startPos") Integer startPos, @Param(value = "pageSize") Integer pageSize) throws Exception;
    //查询总记录数
    Integer getGoodsCount(int id);

1.5、在serviceImpl实现service接口并把mapper接口注入,使用mapper接口。

	@Override
    public List<Books> findPages(Integer startPos, Integer pageSize) throws Exception {
   
        return bookMapper.findPages(startPos,pageSize);
    }

    @Override
    public Integer getGoodsCount(int id) {
   
        
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值