Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 741|回复: 0

数据库分页显示记录--自我总结+感慨

[复制链接]

该用户从未签到

发表于 2011-10-16 17:16:43 | 显示全部楼层 |阅读模式
这个分页困扰了我有好几天,不过最终还是解决了!现在实现这个功能编写一次代码就可以准确无误的运行!很熟练了,嘿嘿!下面来看看吧!

我是通过在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这个变量赋值,来达到分页的效果。
  
到此,分页的功能就结束了,其实很简单,理解了一点都不难!

在这里说些题外话!
我感觉我够仁慈了,好多东西都是自己总结出来的!本来这些东西可以有老师教的。可是我没有老师,只能自学!这可以说是弯路,也可以说是好处!
说是弯路是因为本来我可以直接学到经验,而不必去摸索着一点点获取。这样使我进步的进度很慢。
说是好处是因为这是我自己总结出来的,我经过了思考,这些思想已经深深的刻进了脑海中。是不会忘掉了!
万事有利也有弊。就是这样。我在这里将我自己总结的东西全部没有回避的告诉大家,我已经很仁慈了。可是为什么生活中总是会有些人瞧不上你,是因为什么。
因为嫉妒吗?我告诉你没有必要。因为我是一个什么都不会做的人,没有必要嫉妒。
我发现有不少人在背后说我的不好,我真的不明白,为什么要这样?如果我真的是一个有很多缺点的人,我不会在乎这些,可是我已经做到仁至义尽,为什么结局会是这样!
我真的对大学失望到了极点,等到我有一天功成名就,飞黄腾达的时候,我相信你们的态度会变的!但是那个时候我不会瞧你一眼,因为现在我已经看到了面具背后的真相!

写这篇日志,我有很多感慨,我每次总结了东西,都毫无保留的分享给可能会需要它,用到它的人!就算我不好,最起码这一时刻,我的心是善良的!希望你们祝福我,谢谢!!!
回复

使用道具 举报

该用户从未签到

发表于 2011-11-1 18:40:47 | 显示全部楼层
祝福你。。 有些人有些事没必要太在乎。自己问心无愧、心安理得就行了,何必纠结于那些擦肩而过的过客呢??
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

GMT+8, 2024-5-3 05:37 , Processed in 0.403051 second(s), 47 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表