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("分类号标准编号标准名称文件路径");  
  24.        while(rs.next()){  
  25.          out.print("" + rs.getString("flh") + "");  
  26.          out.print("" + rs.getString("bzbh") + "");  
  27.          out.print("" + rs.getString("bzmc") + "");  
  28.          out.print("" + rs.getString("path") + rs.getString("filenames") + rs.getString("ext") + "");  
  29.        }  
  30.      out.print("");  
  31.      rs.close();  
  32.      stmt.close();  
  33.      conn.close();  
  34.    }  
  35.    catch (Exception e) {  
  36.      System.out.println("错误如下:
    " + 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 @dt= substring(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数据

新闻名称:Jsp调用Sybase数据库存储过程返回记录集
当前地址:http://www.mswzjz.cn/qtweb/news38/171988.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能