浅谈SQL Server 2000下JDBC查询分页解决方案

开发 后端
本文之所以要把SQL Server 2000 JDBC查询分页单独来说说,又两个地方还是值得一提,一者是SQL Server 2000要实现数据库分页是比较麻烦的事情。二者是JDBC查询出多个ResultSet 的取法。

先在项目的classpath中添加msbase.jar,mssqlserver.jar,msutil.jar 怎么来的就不多废话了。需要说的是我***用的SQL Server 2005 JDBC查询驱动sqlJDBC.jar放到项目中,后来的程序是报错的。回头想想,报错有理,SQL Server 2005 已经支持rownum 分页了。

先说说SQL Server 2000的分页的实现,目前实现方法大概是那三种。我个人还是喜欢使用存储过程,原因是使用非常方便,至于使用的存储过程,这里还是放出来看看,估计大家用的都大同小异。

  1. IF NOT EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[dbo].[Pr_QueryByPage]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1)  
  2. BEGIN  
  3. EXEC dbo.sp_executesql @statement = N'create    procedure  [dbo].[Pr_QueryByPage]    
  4. @sqlstr  nvarchar(4000),  --查询sql    
  5. @currentpage  int, --第页记录条数    
  6. @pagesize  int --每页显示记录   
  7. as    
  8. set  nocount  on    
  9. declare  @P1  int, --P1是游标的ID    
  10. @rowcount  int    
  11. exec  sp_cursoropen  @P1  output,@sqlstr,@scrollopt=1,@ccopt=1,@rowcount=@rowcount  output    
  12. select  ceiling(1.0*@rowcount/@pagesize)  as TotalPage,@rowcount as [RowCount]   
  13. set  @currentpage=(@currentpage-1)*@pagesize+1    
  14. exec  sp_cursorfetch  @P1,16,@currentpage,@pagesize      
  15. exec  sp_cursorclose  @P1    
  16. set  nocount  off  '   
  17. END  
  18. GO 

这个存储过程的实现,使用了三个系统存储过程sp_cursoropen ,sp_cursorfetch ,sp_cursorclose 从字面上的意思大概是他叫结果集使用游标打开,然后读取其中的@pageSize条记录,所以单从查询上来讲,性能是不及使用select top 之类的实现。

使用起来非常容易,exec Pr_QueryByPage 'select * from yourtable',1,10  就可以了麻烦的是他返回的是三张表。***张表是查询的表,但是没有记录。第二个表一行两列,***个列是总页数,第二个列是总记录条数。第三张表才是需要的数据。这就造成了取的时候有点小麻烦,因为之前只知道,在.net中可以直接fill(DataSet),然后DataSet里面可取DataTable。但是在JDBC里面我映像中ResultSet 只能容一张表。后来找了一些资料,原来PreparedStatement,CallableStatement,Statement都支持查询返回多个ResultSet ,好了,非常好。 下面是我使用CallableStatemnt取到的结果集。

  1. CallableStatement cs = conn.prepareCall("exec Pr_QueryByPage 'select * from ckdmzd',1,10");  
  2.             ResultSet rs = null;  
  3.             /**  
  4.             * execute returns :  
  5.             *    true : returns ResultSet(s)  
  6.             *  false: returns rows affected  
  7.             */  
  8.             boolean hasResultSet = cs.execute();  
  9.             if(hasResultSet){  
  10.                 /**  
  11.                 * skip the first ResultSet  
  12.                 */  
  13.                 rs=cs.getResultSet();  
  14.                 /**  
  15.                 * second ResultSet : pageCount & recordCount  
  16.                 */  
  17.                 if(cs.getMoreResults()){  
  18.                     rs=cs.getResultSet();  
  19.                     while(rs.next()){  
  20.                         String pageCount=rs.getString(1);  
  21.                         String recordCount=rs.getString(2);  
  22.                     }  
  23.                 }  
  24.                 /**  
  25.                 * the thrid one is the paged result  
  26.                 */  
  27.                 if(cs.getMoreResults()){  
  28.                     rs=cs.getResultSet();  
  29.                     while(rs.next()){  
  30.                         // do somthing with ResultSet  
  31.                     }  
  32.                 }  
  33.             } 

这样就实现了分页,网上很多人测试了,这个方法的性能不及别的方法,这里我要指出的是,别的方法是不能返回总的记录条数的。而要知道总的记录条数,通常需要select count(*) from ( your sql) 这两次查询叫起来的时间未必会少。

JDBC查询总结

使用上述方法实现SQL Server 2000 JDBC查询分页,使用方便,性能还说的过去。我不知道SQL Server 2005 的查询性能是否又提升。

【编辑推荐】

  1. 使用JDBC的五个精华功能
  2. Tomcat5+MySQL JDBC连接池配置
  3. 在Weblogic中实现JDBC的功能
  4. 详解JDBC与Hibernate区别
  5. JDBC连接MySQL数据库关键四步
  6. 浅谈JDBC DAO的设计理念
责任编辑:彭凡 来源: pin5i.com
相关推荐

2009-07-17 17:41:25

JDBC连接SQL S

2010-11-10 15:23:55

SQL SERVER

2010-10-22 14:20:35

SQL SERVER连

2021-10-04 09:14:18

ElasticSear深度分页

2010-06-17 15:33:16

SQL Server

2010-06-30 14:36:49

SQL Server

2010-06-18 10:34:38

SQL Server

2009-07-15 15:18:01

JDBC连接SQL S

2011-08-23 16:23:13

OracleMySQLSQL Server

2009-07-22 13:32:24

JDBC SQL

2009-04-16 13:57:28

SQL Server 全面分析扩展解决方案

2011-03-21 13:44:38

SQL ServerSQL Server2分页

2017-04-13 11:20:37

图片宽度解决方案前端

2009-07-23 13:37:45

JDBC连接SQL S

2010-06-17 15:24:51

SQL SERVER

2010-09-13 13:19:16

Sql Server分

2009-07-09 15:06:09

SQL Server

2009-07-22 13:49:40

JSP JDBC

2010-07-21 13:53:41

SQL Server分

2018-08-21 09:03:00

SQLServer服务器
点赞
收藏

51CTO技术栈公众号