java实现分页功能(二)

第一部分链接
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<User> 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,在这里我给大家简单说一下JdbcTemplate的几个与查询相关的方法。

queryforMap():查询结果将结果封装为map集合
queryforList():查询结果将结果封装为list集合
query():查询结果,将结果封装为JavaBean对象
queryForObject:查询结果,将结果封装为普通类型的对象(int等)


 //计算总页数
  public int findTotalCount() {
String sql="select count(*) from userms";
return template.queryForObject(sql,Integer.class);

}

//分页查询list    
public List<User> findByPage(int start, int rows) {
String sql="select *from userms limit ? , ?";
return template.query(sql,new BeanPropertyRowMapper<User>(User.class),start,rows);
 }

第三部分链接
java实现分页功能(三)

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值