|
这个分页困扰了我有好几天,不过最终还是解决了!现在实现这个功能编写一次代码就可以准确无误的运行!很熟练了,嘿嘿!下面来看看吧!
我是通过在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这个变量赋值,来达到分页的效果。
到此,分页的功能就结束了,其实很简单,理解了一点都不难!
在这里说些题外话!
我感觉我够仁慈了,好多东西都是自己总结出来的!本来这些东西可以有老师教的。可是我没有老师,只能自学!这可以说是弯路,也可以说是好处!
说是弯路是因为本来我可以直接学到经验,而不必去摸索着一点点获取。这样使我进步的进度很慢。
说是好处是因为这是我自己总结出来的,我经过了思考,这些思想已经深深的刻进了脑海中。是不会忘掉了!
万事有利也有弊。就是这样。我在这里将我自己总结的东西全部没有回避的告诉大家,我已经很仁慈了。可是为什么生活中总是会有些人瞧不上你,是因为什么。
因为嫉妒吗?我告诉你没有必要。因为我是一个什么都不会做的人,没有必要嫉妒。
我发现有不少人在背后说我的不好,我真的不明白,为什么要这样?如果我真的是一个有很多缺点的人,我不会在乎这些,可是我已经做到仁至义尽,为什么结局会是这样!
我真的对大学失望到了极点,等到我有一天功成名就,飞黄腾达的时候,我相信你们的态度会变的!但是那个时候我不会瞧你一眼,因为现在我已经看到了面具背后的真相!
写这篇日志,我有很多感慨,我每次总结了东西,都毫无保留的分享给可能会需要它,用到它的人!就算我不好,最起码这一时刻,我的心是善良的!希望你们祝福我,谢谢!!! |
|