网站建设
  简约型网页设计套餐998
  实惠型网站建设套餐2580
  综合型网站制作套餐4980
  网站改版与网站维护
  行业网站建设方案
  大型网站建设解决方案
  企业网站建设流程
  帝网科技网站设计与网站制作
建站FAQ
·网站空间问题解答
·企业邮箱问题解答
 
酷站欣赏
·房产酷站(379)
·综合门户(8 9)
·建筑装饰(603)
·手机通讯(354)
·生活购物(376)
·医疗保健(199)
·文化摄影(602)
·休闲体育(399)
>>更多酷站欣赏
网站优化
·Google(谷歌)优化   ·百度(BaiDu)优化
·雅虎(Yahoo)优化    ·Alexa排名优化   
·Google AdSense   ·DMOZ目录提交  
建站知识
·网站建设知识·网站名词解释·网站运营知识
·网络营销知识·搜索引擎知识·实用技术文摘
网站推广
百度网站推广 google网站推广
搜狐网站推广 网易网站推广
新浪网站推广   雅虎网站推广
  您当前位置: 当前位置:帝网科技 >> web开发 >> JSP专栏 >> 浏览文章
 
 
JSP初级教程--JSP初学者入门之五
作者:佚名 来源:帝网科技 日期:2010年03月12日 点击数:


  第五章 jsp分页功能的实现

  经过上面的学习我渐渐熟悉了对数据库的操作,留言板的功能也不断的完善,随着留言的增加信息的目录越来越长了,现在需要实现一个分页功能了,我尝试自己解决这个问题。

  1、我应该把它的关键部分封装成一个bean,使它尽可能的能够重用;

  2、通过资料了解有两种数据库查询方案:一、一次取得所有资料,然后在指定的页显示指定的资料;二、分次查询数据库,每次只获得本页的数据。考虑到数据库中记录数越多,方案一所占的服务器资源就越多(将所有的记录都放到内存中,假如有50万条记录的话……@$^*%@#),所以应该采用方案二;

  3、首先要知道目标数据库里共有多少条记录(select count(*) from 表名),然后确定每页显示多少条记录,再根据它计算一共分多少页(最大页数)显示,这部分由bean1(在我的代码里就随便起个名叫PageBean)实现;获取当前要显示第几页的请求,查询本页要显示哪些条记录,将每条记录的内容作为一组数据返回给显示页面,这部分由bean2(CountBean)实现;显示页面(.jsp文件)显示各条记录的内容。

  到这里我发现有两个难点:(1)查询从第m条到第n条记录的SQL语句不会写,通过在网上查找资料,这个问题得到解决;(2)bean2返回给显示页面的值是个二维的数组,这个数组怎么传呢?于是不得不上网翻书查找资料,最终发现由Vector(向量)来解决,由于没有工具书,无法针对Vector进一步学习,就只好分析代码,好在最后分析明白了——到目前为止,也只是明白了那段代码,仍然无法做到能够应用。

  下面是这三个文件的代码:

  -----------------------------------------PageBean.java-----------------------------------------------

  //该bean用于实现分页功能时得到总的记录数和最大的页数

  package ringz.javabeans;

  import java.io.*;

  import java.sql.*;

  public class PageBean

  {

  private int maxRowCount;//最大记录数

  private int onePageRowCount;//每页显示的记录数

  private int maxPageCount;//最大页数

  private String classforname;

  private String servanddb;

  private String sql;

  //

  //得到关于目标数据库的搜索条件

  public void setSql(String s1,String s2,String sql)

  {

  this.classforname=s1;

  this.servanddb=s2;

  this.sql=sql;

  }

  //得到onePageRowCount

  public void setOnePageRowCount(int counts)

  {

  onePageRowCount=counts;

  }

  //计算maxRowCount并返回

  public int getMaxRowCount()throws Exception

  {

  try

  {

  Class.forName(classforname);//载入驱动程式类别

  Connection con=DriverManager.getConnection(servanddb);//建立数据库连接

  Statement stmt=con.createStatement();//建立Statement变量

  ResultSet rs=stmt.executeQuery(sql);

  if (rs.next())

  maxRowCount=rs.getInt(1);

  rs.close();

  stmt.close();

  con.close();

  return maxRowCount;

  }//try

  catch (Exception e)

  {

  e.printStackTrace();

  throw e;

  }

  }//getMaxRowCount()

  相关文章
 
·如何建立JSP操作以提高数据库访问效率
·servlet 生成静态HTML的方法
·使用JSP实现简易的SQL报表
·浅析Servlet和Jsp中的多国语言显示
·JSP/Servlet/JSF:自定义标签的另类体
·使用JSP+javascript打造二级级联下
·实例:JSP结合XML+XSLT将输出转换HTML
·JSP教程:JSP页面跳转的实战规则
·关于JSP中的offsetparent
·JSP中errorPage设置方法
·JSP用bean获取各种参数
·JSP基础知识教程
·在Eclipse中部署Tomcat,并运行JSP
·jsp教程:深入浅出URL编码
·JSP技术优缺点深入分析(2)
·Jsp环境下ajax乱码问题的解决方法
·JSP技术优缺点深入分析(1)
·jsp上传组件smartupload介绍
·JSP中文字符乱码处理的2种方法
·jsp入门:Jsp运行原理
 
 

公司环境 | 合作伙伴 | 人才招聘 | 付款方式 | 关于我们

地址:广州市天河区中山大道中120号D805 电话:020-82529556 传真:020-82529556
广州帝网网络科技有限公司 版权所有 粤ICP备08119341号