jsp读取数据库实现分页技术简析(2)


<%@ page errorPage="error.jsp"%>
<%@ page contentType="text/html;charset=gb2312"%>
<%@ page import="java.util.*"%>
<%@ page import="java.sql.*"%>
//导入database_basic包下面的databaseBean类,别名是basicDB
<jsp:useBean scope="page"/>
<%
String sql;
ResultSet rs;
int id;
String reply,Exc;
Exc=basicDB.DBConnect();//建立连接,若成功,则返回Success!若失败,则返回相应出错信息
if(!Exc.equals("Success!"))
{
//basicDB.DBDisconnect();
throw new Exception(Exc);
}
int pageSize=10; //定义每页显示的数据条数
int currentPage=1; //当前页(第一次显示的肯定是第一页啦!~),以后的“当前页”由下面出现的页面中的pages参数传入
int allPage=-1;
String pages=request.getParameter("pages");//取得页面中pages参数,此参数代表的页面的就是要显示的“当前页面”
if(pages!=null) currentPage=Integer.valueOf(pages).intValue();//这是一个Integer型转int型的例子,第一次执行这个页面的时候,pages这个参数是null,currentPage=1;当再次执行这个页面的时候,参数pages将被赋值,currentPage=pages的int值
sql="select * from gbook order by id desc";//这样返回的结果集会采用desc降序排列,好处是,显示在前面的是最新的信息
allPage=basicDB.getTotalPage(sql,pageSize);//得到总页码数
rs=basicDB.getPagedRs(sql,pageSize,currentPage);//得到当前页面要显示的结果集
%>
<table cellspacing="1" cellpadding="3" bgcolor="#ffffff">
<%
while(rs.next()){
id=rs.getInt("id");//得到数据库(结果集)中id编号
%>
<tr bgcolor="#FF6600">
<td >Name:<%=rs.getString("leaver")%></td>
<td >Time:<%=rs.getString("leave_date")%></td>
<td >Email:<%=rs.getString("email")%></td>
<td ><div>Home:<%=rs.getString("homepage")%></div></td>
</tr>
<tr bgcolor="#FFE3B9">
<td colspan=4><FONT COLOR="#FF6600">Content:</FONT><BR><BR><%=rs.getString("content")%> </td>
</tr>
<%}%>
<tr><td></td></tr>
<tr>
<td colspan=4 align=right bgcolor="#FF6600">
现在是第<%=currentPage%>页,
<%if(currentPage>1){%>
<!--如果不在第一页,则显示出“首页”链接-->
<A HREF="https://www.jb51.net/admin_show.jsp?pages=<%=(currentPage-1)%>">首页</A>
<%}
for(int i=1;i<=allPage;i++)
{
//显示出1、2、3、4……到最后一页的链接
out.println("<a href=https://www.jb51.net/admin_show.jsp?pages="+i+">"+i+"</a>");
}
%>
<%if(currentPage<allPage){%>
<!--如果不在最后一页,则显示出“末页”链接-->
<A HREF="https://www.jb51.net/admin_show.jsp?pages=<%=(currentPage+1)%>">末页</A>
<%}%></td>
</tr>
</table>
}//then end of the class


3、总结
这个实现分页显示的程序中,有几个算法和实现方法是比较固定且经典的,对没写过分页程序的人来说,应该有所启发。

您可能感兴趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wzfxsw.html