数据库分页显示记录

这个分页困扰了我有好几天,不过最终还是解决了!现在实现这个功能编写一次代码就可以准确无误的运行!很熟练了,嘿嘿!下面来看看吧!

我是通过在jsp里面调用JavaBean来实现这个功能的,这样主要的好处是将显示和代码分离了,对于后台人员方便了很多!
首先要先声明四个必须的变量
记录总数,每页的记录,总页数,当前页。
还有一个接受参的变量时String类型的当前页,这个变量用来判断是不是第一次访问该页面!
现在先给出一个在纯jsp页面里实现这个功能的代码吧 我会在每部分代码的后面解释出相应的功能 这些代码不能去记,要去理解。
<body>
<%Connection con =null;
Statement stmt = null;
ResultSet res = null;
String name = "sa";
String pwd = "";
String url = "jdbc:microsoft:sqlserver://localhost:1433;databasename=user";
String driver="com.microsoft.jdbc.sqlserver.SQLServerDriver";
上面的代码是初始化连接数据库是所需要的参数
int pageSize = 3;
int rowCount;
int pageCount;
int nowPage;
int i,j;//标记显示过的记录数
String currentPage;
上面就是所声明的必须变量
currentPage = request.getParameter("page");
if(currentPage==null){
nowPage = 1;
}else{
nowPage = Integer.parseInt(currentPage);
}
if(nowPage==0){
nowPage = 1;
}
这里是判断是不是第一次访问该页面,并且对当前页nowPage进行了初始化
Class.forName("");
con = DriverManager.getConnection(url,name,pwd);
这里是加载驱动和连接数据库的代码
String sql = "select count(*) from user_infor";
stmt = con.createStatement();
res = stmt.executeQuery(sql);
res.next();
rowCount = res.getInt(1);
res.close();
上面的这个代码是获取记录的总条数,我感觉这个方法挺巧妙。开始我就没有想到,我本来想用ResultSet对象的last方法来这,可是驱动不支持这个方法,没办法,只能换了!
if(rowCount%pageSize==0){
pageCount = rowCount/pageSize;
}else{
pageCount = rowCount/pageSize+1;
}
这个是初始化总页数这个变量
String s = "select * from user_infor";
res = stmt.executeQuery(s);
i = (nowPage-1)*pageSize;
for(j=0;j<i;j++){
res.next();
}
上面的这段代码是将查询记录的指针移动到将要显示的下一页的第一条记录,这段代码理解起来不是很难,不会的多看看!
%>
<p align=center>jsp分页查询</p>
<table border = "1px" align=center>
<%i = 0;
while(i<pageSize&&res.next()){%>
<tr>
<td width="60px" align =center ><%=res.getString(1) %></td>
<td width="60px" align =center><%=res.getString(2) %></td>
<td width="60px" align =center><%=res.getString(3) %></td>
</tr>

<%i++;}
%>
这里就是从数据库里面调数据了,不用解释
</table>
<table border="0px" align=center>
<tr>
<td>共<%=rowCount%>条记录</td>
<td>共<%=pageCount%>页</td>
<%if(nowPage>1){ %>
<td><a href="index.jsp?page=<%=nowPage-1 %>">上一页</a></td>
<%}%>
<td>第<%=nowPage %>页</td>
<%if(nowPage<pageCount){ %>
<td><a href="index.jsp?page=<%=nowPage+1 %>">下一页</a></td>
<%} %>
</tr>
</table>
</body>
这的代码是连接到本页,然后将当前页这个参数传递到currentPage这个变量,来循环对nowPage这个变量赋值,来达到分页的效果。

到此,分页的功能就结束了,其实很简单,理解了一点都不难!

你可能感兴趣的:(sql,jsp,jdbc,Microsoft,J#)