java实现分页功能(二)

Servlet分析

我们通过前台获取到当前页和每页显示的记录数,然后在Servlet中接受请求参数。
 通过调用Service中的方法查询PageBean对象,将PageBean存入request,最后转发到要展示数据的页面。

@WebServlet("/findUserByPageServlet")
public class FindUserByPageServlet extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//获取参数
String currentPage=request.getParameter(“currentPage”);//当前页码
String rows=request.getParameter(“rows”);//每页显示的记录数

    //判断参数是否为空
    if (currentPage == null||"".equals(currentPage)){
        currentPage="1";
    }
    if (rows==null || "".equals(rows)){
        rows="8";
    }


    //调用Service查询
    UserService service=new UserServiceImpl();
    PageBean<User> pb=service.findUserByPage(currentPage,rows);
    System.out.println(pb);

    //将pagebean存入request
    request.setAttribute("pb",pb);

    //转发到list.jsp
    request.getRequestDispatcher("/list.jsp").forward(request,response);

}

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    this.doPost(request, response);
}

}

Service分析
首先,我们要创建一个空的PageBean对象,并设置当前页面的属性和每页显示的记录数,调用dao查询总记录数和list集合,然后计算一下总页码的数量,最后不要忘记返回PageBean对象。

public PageBean findUserByPage(String _currentPage, String _rows) {
int currentPage=Integer.parseInt(_currentPage);
int rows=Integer.parseInt(_rows);

if (currentPage <=0){
    currentPage=1;
}

//创建空的PageBean对象
PageBean<User> pb=new PageBean<User>();
//设置参数
pb.setCurrentPage(currentPage);
pb.setRows(rows);
//调用dao查询总记录数
int totalCount=dao.findTotalCount();
pb.setTotalCount(totalCount);
//调用dao查询list集合
//计算开始的记录索引
int start=(currentPage-1)*rows;
List<User> list=dao.findByPage(start,rows);
pb.setList(list);
//计算总页码
int totalPage = (totalCount % rows) == 0 ? totalCount/rows:(totalCount/rows)+1;
pb.setTotalPage(totalPage);
if (currentPage >= totalPage){
    currentPage=totalPage;
}
return pb;

}

Dao分析

通过上面的分析,dao层需要实现两个方法为查询总记录数,和分页查询List

public int findTotalCount() {
String sql=“select count(*) from userms”;
return template.queryForObject(sql,Integer.class);
}
public List findByPage(int start, int rows) {
String sql=“select *from userms limit ? , ?”;
return template.query(sql,new BeanPropertyRowMapper(User.class),start,rows);
}

发布了9 篇原创文章 · 获赞 9 · 访问量 521

猜你喜欢

转载自blog.csdn.net/amazinga/article/details/104354007