- 7
- 0
- 约2.55万字
- 约 22页
- 2016-08-02 发布于安徽
- 举报
JSP分页技术实现.doc
title:?JSP分页技术实现summary:使用工具类实现通用分页处理author:?evan_zhaoemail:?evan_zhao@ 目前比较广泛使用的分页方式是将查询结果缓存在HttpSession或有状态bean中,翻页的时候从缓存中取出一页数据显示。这种方法有两个主要的 缺点:一是用户可能看到的是过期数据;二是如果数据量非常大时第一次查询遍历结果集会耗费很长时间,并且缓存的数据也会占用大量内存,效率明显下降。 其它常见的方法还有每次翻页都查询一次数据库,从ResultSet中只取出一页数据(使用rs.last();rs.getRow()获得总计录条 数,使用rs.absolute()定位到本页起始记录)。这种方式在某些数据库(如oracle)的JDBC实现中差不多也是需要遍历所有记录,实验证 明在记录数很大时速度非常慢。 至于缓存结果集ResultSet的方法则完全是一种错误的做法。因为ResultSet在Statement或Connection关闭时也会被关闭,如果要使ResultSet有效势必长时间占用数据库连接。 因此比较好的分页做法应该是每次翻页的时候只从数据库里检索页面大小的块区的数据。这样虽然每次翻页都需要查询数据库,但查询出的记录数很少,网络传输 数据量不大,如果使用连接池更可以略过最耗时的建立数据库连接过程。而在数据库端有各种成熟的优化技术用于提高查询速度,比在应用服务器层做缓存有效多 了。 在oracle数据库中查询结果的行号使用伪列ROWNUM表示(从1开始)。例如 select?*?from?employee?where?rownum10?返回前10条记录。但因为rownum是在查询之后排序之前赋值 的,所以查询employee按birthday排序的第100到120条记录应该这么写:[pre]????????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[/pre] mySQL可以使用LIMIT子句: select?name,?birthday?from?employee?order?by?birthday?LIMIT?99,20 DB2有rownumber()函数用于获取当前行数。 SQL?Server没研究过,可以参考这篇文章:/develop/article/18/18627.shtm 在Web程序中分页会被频繁使用,但分页的实现细节却是编程过程中比较麻烦的事情。大多分页显示的查询操作都同时需要处理复杂的多重查询条件,sql语 句需要动态拼接组成,再加上分页需要的记录定位、总记录条数查询以及查询结果的遍历、封装和显示,程序会变得很复杂并且难以理解。因此需要一些工具类简化 分页代码,使程序员专注于业务逻辑部分。下面是我设计的两个工具类: PagedStatement??封装了数据库连接、总记录数查询、分页查询、结果数据封装和关闭数据库连接等操作,并使用了PreparedStatement支持动态设置参数。 RowSetPage??参考PetStore的page?by?page?iterator模式,?设计RowSetPage用于封装查询结果(使用OracleCachedRowSet缓存查询出的一页数据,关于使用CachedRowSet封装数据库查询结果请参考JSP页面查询显示常用模式)以及当前页码、总记录条数、当前记录数等信息,?并且可以生成简单的HTML分页代码。 PagedStatement?查询的结果封装成RowsetPage。 下面是简单的使用示例:????//DAO查询数据部分代码:????…????public?RowSetPage?getEmployee(String?gender,?int?pageNo)?throws?Exception{????????String?sql=select?emp_id,?emp_code,??user_name,?real_name?from?employee?where?gender?=?;???????//使用Oracle数据库的分页查询实现,每页显示5条????????PagedStatement?pst?=new?PagedStatementOracl
原创力文档

文档评论(0)