第一部分链接
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实现分页功能(三)