servlet + jsp分页

public class EmpListServlet extends HttpServlet {
 
	private static final int PAGEROW = 4;//设置一个页面里面有四条数据
 
	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
 
		response.setContentType("text/html");
 
		EmpDao ed = new EmpDao();//创建一个数据库操作的对象
		int page = 1;
 
		String nowPage = request.getParameter("nowPage");//获取当前页数
 
		if(nowPage!=null && !"".equals(nowPage)){
			//如果传入的值为非空,则将page设置传入的值,否则page值仍为1
			page = Integer.parseInt(nowPage);
		}
 
		int count = ed.getRowCount();//获取数据库中所有的条目的总数
 
		//得到总共的分页数目
		int pageCount = count%PAGEROW==0?count/PAGEROW:count/PAGEROW+1;
		//如果数据库中的条数不能填满最后一个页面,那页面数就加上1
		//(整除除不尽会去掉小数部分,因而页面会少一个,所以需要+1)
 
		if(page<1){//如果传如的页数小于1了,那就仍旧在第一页
			page = 1;
		}
		if(page > pageCount){//如果传入的页数超过了最大页数,那么就仍旧到最大页数
			page = pageCount;
		}
 
		int start = (page-1) * PAGEROW + 1;//页面里起始的数据行,
		int end = start + PAGEROW - 1;//页面里最末尾的数据行
 
		List elist = ed.findEmpList(start,end);//根据开始和结束从数据库得到列表
 
		request.setAttribute("elist", elist);
		request.setAttribute("page", page);
		request.setAttribute("endPage", pageCount);
 
		RequestDispatcher dispatcher = request.getRequestDispatcher("main.jsp");
		dispatcher.forward(request, response);
	}
 
	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		this.doGet(request, response);
	}
 
}


接下来是EmpDao中调用数据库的方法

public List findEmpList(int start,int end) {
	List list = new ArrayList();
	Connection con = null;
	Statement st = null;
	ResultSet rs = null;
	try {
		con = getConnection();
		st = con.createStatement();
		String sql = "select * from (select e.*, rownum rn from emp e) 
				where rn >="+start+" and rn <="+end;
		rs = st.executeQuery(sql);
		while (rs.next()) {
			Emp emp = new Emp();
			emp.setEmpno(rs.getString(1));
			emp.setEname(rs.getString(2));
			emp.setJob(rs.getString(3));
			emp.setMgr(rs.getString(4));
			Date d = rs.getDate(5);
			if (d != null) {
				emp.setHiredate(d.toString());
			}
			emp.setSal(rs.getString(6));
			emp.setComm(rs.getString(7));
			emp.setDeptno(rs.getString(8));
			list.add(emp);
		}
	} catch (ClassNotFoundException e) {
		e.printStackTrace();
	} catch (SQLException e) {
		e.printStackTrace();
	} finally {
		free(con, st, rs);
	}
 
	return list;
}

然后是JS处理手工输入页面的跳转

<script type="text/javascript">
	function pageto(){
		var np = document.all("nowPage").value;
		if(!isNaN(np)){
			if(np.length>0){
				location.href="EmpListServlet?nowPage="+np;
			}
		}else{
			document.all("nowPage").value="";
			alert("请输入合法的数字!");
		}
	}
</script>

下面是翻页部分的jsp代码

<tr>
	<td colspan="10">
		<a href="EmpListServlet">首页</a>
		<a href="EmpListServlet?nowPage=${page-1 }">上一页</a> 
		<a href="EmpListServlet?nowPage=${page+1 }">下一页</a> 
		<a href="EmpListServlet?nowPage=${endPage }">尾页</a>
		<input type="text" id="nowPage" size="3" />
		<input type="button" value="GO" οnclick="pageto()">   
	</td>
</tr>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JSPServlet中进行分页查询的主要步骤如下: 1. 在JSP页面中,使用<a>标签创建一个链接到Servlet的URL。该链接将包含一个参数,用于指示要查询的页码。例如,可以使用以下代码创建一个链接到Servlet的URL: ```html <a href="<%= request.getContextPath() %>/action?page=<%= page + 1 %>">下一页</a> ``` 这里的`page`是一个变量,表示当前页码。 2. 在Servlet中,使用HttpServletRequest的getParameter方法获取请求中的参数值。例如,可以使用以下代码获取名为"page"的参数的值: ```java int page = Integer.parseInt(request.getParameter("page")); ``` 3. 在Servlet中,根据获取到的页码参数,进行相应的查询操作,获取需要显示的数据。 4. 将查询结果存储在适当的作用域对象中,例如使用request.setAttribute方法将查询结果存储在request对象中,以便在JSP页面中使用。 5. 在JSP页面中,使用EL表达式或JSTL标签库来显示查询结果。 需要注意的是,以上代码只是一个基本的示例,实际的实现可能会根据具体需求有所不同。另外,还可以考虑添加一些验证和错误处理的逻辑,以确保分页查询的正确性和稳定性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [使用ServletJSP完成分页查询](https://blog.csdn.net/qq_33036061/article/details/83753789)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值