Jsp调用Sybase数据库存储过程返回记录集

数据库
在Jsp开发时,经常会用到调用Sybase数据库存储过程返回记录集,下文就为您举例说明该功能的实现方法,供您参考借鉴。

Sybase数据库存储过程我们经常会用到,下面就为您介绍Jsp调用Sybase数据库存储过程返回记录集的方法,希望对您学习使用Sybase数据库存储过程方面能有所帮助。

源代码如下:

  1. <%@page contentType="text/html;charset=GB2312"%> 
  2. <%@page import="javax.naming.*"%> 
  3. <%@page import="javax.sql.*"%> 
  4. <%@page import="java.sql.*"%> 
  5. <%  
  6.    int n = 20;  
  7.    Connection conn = null;  
  8.    CallableStatement stmt = null;  
  9.    ResultSet rs = null;  
  10.    Context ctx = null;  
  11.    try {  
  12.      ctx = new InitialContext();  
  13.    //获取连接池对象  
  14.      DataSource ds = (DataSource) ctx.lookup("JNDITEST_150");//JNDITEST_150是weblogic数据源的名字  
  15.    //String strSql_p="GetDataByPage @SqlStr=\"select * from bzlist\", @PageSize=20, @CurrentPage=1";  
  16.    String sproc="{?=call GetDataByPage(?,?,?)}";  
  17.      conn = ds.getConnection();  
  18.      stmt=conn.prepareCall(sproc);  
  19.      stmt.setString(2,"select * from bzlist");  
  20.      stmt.setInt(3,20);  
  21.      stmt.setInt(4,1);   
  22.      rs=stmt.executeQuery();   
  23.       out.print("<Table border=1><tr><th>分类号<th>标准编号<th>标准名称<th>文件路径</tr>");  
  24.        while(rs.next()){  
  25.          out.print("<tr><td>" + rs.getString("flh") + "</td>");  
  26.          out.print("<td>" + rs.getString("bzbh") + "</td>");  
  27.          out.print("<td>" + rs.getString("bzmc") + "</td>");  
  28.          out.print("<td>" + rs.getString("path") + rs.getString("filenames") + rs.getString("ext") + "</td></tr>");  
  29.        }  
  30.      out.print("</table>");  
  31.      rs.close();  
  32.      stmt.close();  
  33.      conn.close();  
  34.    }  
  35.    catch (Exception e) {  
  36.      System.out.println("错误如下:<br>" + e);  
  37.      e.printStackTrace();  
  38.    }  
  39. %> 
  40.  

-----------------------------------------------------存储过程如下:

  1. CREATE PROCEDURE GetDataByPage   
  2. (   
  3.      --创建一个分页读取过程   
  4. @SqlStr          varchar(8000), --SQL语句   
  5. @PageSize        int,    --每页记录数   
  6. @CurrentPage     int     --当前页数   
  7. )   
  8. AS   
  9. DECLARE @FirstRec int, @LastRec int, @dt varchar(10) --页起始行,页结束行,生成临时表的随机数   
  10. BEGIN   
  11.  
  12. SELECT @FirstRec = (@CurrentPage - 1) * @PageSize --计算页起始行   
  13. SELECT @LastRec = (@CurrentPage * @PageSize + 1) --计算页结束行   
  14.     
  15. SELECT @dtsubstring(convert(varchar,rand()),3,10) --一个字符型的随机数   
  16.  

--将搜索结果放入临时表中,表名随机生成,在' FROM '前插入'INTO '+随机临时表名 

  1. SELECT @SqlStr = stuff(@SqlStr, charindex(' FROM ',upper(@SqlStr)), 6 ,' INTO tempdb..Paging'+@dt+' FROM ')   
  2. EXECUTE (@SqlStr)   

 
--为临时表增加id号 

  1. SELECT @SqlStr = 'ALTER TABLE tempdb..Paging'+@dt+' ADD TEMPDB_ID numeric(10) IDENTITY PRIMARY KEY'   
  2. EXECUTE (@SqlStr)   

 
--计算临时表中的记录数 

  1. --SELECT @SqlStr = 'SELECT Count(*) From tempdb..Paging'+@dt   
  2. --EXECUTE (@SqlStr)   

 
--选取记录号在起始行和结束行中间的记录 

  1. SELECT @SqlStr = 'SELECT * FROM tempdb..Paging'+@dt+' WHERE TEMPDB_ID > '+convert(varchar,@FirstRec)+' and TEMPDB_ID < '+convert(varchar,@LastRec)   
  2. EXECUTE (@SqlStr)   

 
--删除临时表

  1. SELECT @SqlStr = 'DROP TABLE tempdb..Paging'+@dt   
  2. EXECUTE (@SqlStr)    
  3.      
  4. END  

----------------------------------------------------另外写了个取记录数的存储过程:

  1. CREATE PROCEDURE xdztest.GetDataCount  
  2. (  
  3.      @SqlStr varchar(8000)  
  4. )  
  5. AS  
  6. BEGIN  
  7. EXECUTE (@SqlStr)  
  8. END  
  9.    
  10.  

 

 

 

【编辑推荐】

sybase分页存储过程的实现

活用Sybase超级用户密码

Sybase数据灾难方案浅析

Sybase数据库引擎运行方法简介

Oracle数据库如何正确访问SYBASE数据

责任编辑:段燃 来源: 互联网
相关推荐

2009-12-28 09:50:32

ADO数据库

2011-02-25 17:47:44

数据库存储编写

2011-08-29 15:52:19

SQL ServerMybatis存储过程

2009-12-28 10:22:52

ADO Records

2009-12-24 16:32:00

ADO 记录集

2010-05-07 13:03:01

Oracle通过存储过

2011-05-17 15:30:27

Oracle数据库ADO

2011-08-15 15:14:54

SQL Server存储过程异常处理

2010-10-26 14:40:31

oracle存储过程

2009-11-11 16:44:47

ADO记录集

2011-08-25 09:31:43

JDBC调用Oracl

2011-08-23 10:14:09

JDBC更新计数行调用存储过程SQL Server

2017-09-03 15:41:31

数据库存储分布式

2010-11-29 09:45:30

Sybase分页

2010-10-26 14:27:30

oracle存储过程

2010-04-30 14:22:43

Oracle通过

2010-11-29 15:25:39

Sybase存储过程

2010-11-29 09:12:46

sybase分页存储过

2009-09-11 15:12:26

LINQ执行存储过程

2011-08-25 09:17:31

Java调用存储过程返回一行或多行结果集
点赞
收藏

51CTO技术栈公众号