Jsp调用Sybase数据库存储过程返回记录集_Sybase_数据库_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 数据库 > Sybase > Jsp调用Sybase数据库存储过程返回记录集

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

 2013/8/10 4:58:06    程序员俱乐部  我要评论(0)
  • 摘要:Sybase数据库存储过程我们经常会用到,下面就为您介绍Jsp调用Sybase数据库存储过程返回记录集的方法,希望对您学习使用Sybase数据库存储过程方面能有所帮助。源代码如下:<%@pagecontentType="text/html;charset=GB2312"%><%@pageimport="javax.naming.*"%><%@pageimport="javax.sql.*"%><
  • 标签:数据库 数据 过程 存储过程 Sybase Sybase数据库 ASE JS

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

源代码如下:

    class="dp-xml">
  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.  

发表评论
用户名: 匿名