资深而专注的郑州网络公司                                   郑州网站建设 | 网站优化 | 洛阳网络公司 | 洛阳网站建设 | 网络公司   
郑州网络公司 咨询热线:0371-63653120 63658758  客服QQ 757700863 335050586
      网站优化推广案例中心客服中心加盟合作联系我们付款方式
首 页 域名注册 虚拟主机 数据库空间 Jsp 空间 主机托管 VPS 主机 主机租用 企业邮局 网站建设
会员登陆
用户名:
密 码:
客服中心
JSP分页技术实现
作者:无   加入时间:2008-3-7 11:14:16   点击次数:227

目前比较广泛使用的分页方式是将查询结果缓存在HttpSession或有状态bean中,翻页的时候从缓存中取出一页数据显示。这种方法有两个主要的缺点:一是用户可能看到的是过期数据;二是如果数据量非常大时第一次查询遍历结果集会耗费很长时间,并且缓存的数据也会占用大量内存,效率明显下降。
  其它常见的方法还有每次翻页都查询一次数据库,从ResultSet中只取出一页数据(使用rs.last();rs.getRow()获得总计录条数,使用rs.absolute()定位到本页起始记录)。这种方式在某些数据库(如oracle)的JDBC实现中差不多也是需要遍历所有记录,实验证明在记录数很大时速度非常慢。
  至于缓存结果集ResultSet的方法则完全是一种错误的做法。因为ResultSet在Statement或Connection关闭时也会被关闭,如果要使ResultSet有效势必长时间占用数据库连接。

  因此比较好的分页做法应该是每次翻页的时候只从数据库里检索页面大小的块区的数据。这样虽然每次翻页都需要查询数据库,但查询出的记录数很少,网络传输数据量不大,如果使用连接池更可以略过最耗时的建立数据库连接过程。而在数据库端有各种成熟的优化技术用于提高查询速度,比在应用服务器层做缓存有效多了。

  在oracle数据库中查询结果的行号使用伪列ROWNUM表示(从1开始)。例如 select * from employee where rownum<10 返回前10条记录。但因为rownum是在查询之后排序之前赋值的,所以查询employee按birthday排序的第100到120条记录应该这么写:

select * from (
select my_table.*, rownum as my_rownum from (
select name, birthday from employee order by birthday
) my_table where rownum <120
) where my_rownum>=100


  mySQL可以使用LIMIT子句:
    select name, birthday from employee order by birthday LIMIT 99,20
  DB2有rownumber()函数用于获取当前行数。
  SQL Server没研究过,可以参考这篇文章:http://www.csdn.net/develop/article/18/18627.shtm

  在Web程序中分页会被频繁使用,但分页的实现细节却是编程过程中比较麻烦的事情。大多分页显示的查询操作都同时需要处理复杂的多重查询条件,sql语句需要动态拼接组成,再加上分页需要的记录定位、总记录条数查询以及查询结果的遍历、封装和显示,程序会变得很复杂并且难以理解。因此需要一些工具类简化分页代码,使程序员专注于业务逻辑部分。下面是我设计的两个工具类:
  PagedStatement 封装了数据库连接、总记录数查询、分页查询、结果数据封装和关闭数据库连接等操作,并使用了PreparedStatement支持动态设置参数。
  RowSetPage 参考PetStore的page by page iterator模式, 设计RowSetPage用于封装查询结果(使用OracleCachedRowSet缓存查询出的一页数据,关于使用CachedRowSet封装数据库查询结果请参考JSP页面查询显示常用模式)以及当前页码、总记录条数、当前记录数等信息, 并且可以生成简单的HTML分页代码。
  PagedStatement 查询的结果封装成RowsetPage。

  下面是简单的使用示例:

1.
2. //DAO查询数据部分代码:
3. …
4. public RowSetPage getEmployee(String gender, int pageNo) throws Exception{
5. String sql="select emp_id, emp_code, user_name, real_name from employee where gender =?";
6. //使用Oracle数据库的分页查询实现,每页显示5条
7. PagedStatement pst =new PagedStatementOracleImpl(sql, pageNo, 5);
8. pst.setString(1, gender);
9. return pst.executeQuery();
10. }
11.
12.
13. //Servlet处理查询请求部分代码:
14.
15. …
16. int pageNo;
17. try{
18. //可以通过参数pageno获得用户选择的页码
19. pageNo = Integer.parseInt(request.getParameter("pageno") );
20. }catch(Exception ex){
21. //默认为第一页
22. pageNo=1;
23. }
24. String gender = request.getParameter("gender" );
25. request.setAttribute("empPage", myBean.getEmployee(gender, pageNo) );
26. …
27.
28. //JSP显示部分代码
29. <%@ page import = "page.RowSetPage"%>
30. …
31.
37. …
38.


39.
40. 性别:
41. ">
42.
43. <%
44. RowSetPage empPage = (RowSetPage)request.getAttribute("empPage");
45. if (empPage == null ) empPage = RowSetPage.EMPTY_PAGE;
46. %>
47. …
48.
49.
50. <%
51. javax.sql.RowSet empRS = (javax.sql.RowSet) empPage.getRowSet();
52. if (empRS!=null) while (empRS.next() ) {
53. %>
54.
55.
56.
57.
58.
59.
60. <%
61. }// end while
62. %>
63.
64. <%
65. //显示总页数和当前页数(pageno)以及分页代码。
66. //此处doQuery为页面上提交查询动作的javascript函数名, pageno为标识当前页码的参数名
67. %>
68.
69.
70.
ID 代码 用户名 姓名
<%= empRS.getString("EMP_ID")%> <%= empRS.getString("EMP_CODE")%> <%= empRS.getString("USER_NAME")%> <%= empRS.getString("REAL_NAME")%>
<%= empPage .getHTML("doQuery", "pageno")%>

上一篇: 没有了
下一篇: 学习网站建设中一些容易被忽视的问题
客服中心
域名注册帮助 虚拟主机帮助
数据库空间 JSP 空间帮助
主机托管帮助 主机租用帮助
企业邮局帮助 网站建设帮肋
协议文件下载 代理客户帮助
新闻中心
公司动态
网站公告
业界新闻
新站发布
最新客户
洛嘉海兰德车业有限公司
郑州芘芘秀婴儿拍摄专家
上海三宜办公家具有限公司
洛阳宇通汽车有限公司
洛阳花都金柜集团有限公司
中国机动车检测网
北易三轮摩托车有限公司
关于我们 | 代理申请 | 付款方式 | 客户管理 | 友情链接 | 网站导航

版权所有 2008 三易网络(郑州)科技开发有限公司
服务热线:0371-63653120   63658758 地址:郑州市金水区丰庆路2号
QQ在线客服: 757700863  335050586   Email:web@68cwd.com
http://www.68cwd.com http://www.zdwx.com.cn http://www.zdwx.com

豫ICP备06008228号