当前位置: 首页 > 图文教程 > 网络编程 > ASP > ASP调用ORACLE存储过程并返回结果集

ASP
ASP调用ORACLE存储过程并返回结果集
用ASP实现网页BBS
关于Global.asa文件的深入研究与session变量失效提示的具体方法
简易ASP+注册系统
防护手册:如何防止ASP木马在服务器上运行
用Visual Basic实现多画面播放功能之二
如何增强ASP程序性能(1)
如何增强ASP程序性能(2)
如何增强ASP程序性能(3)
ASP备份数据库
二十八条改善 ASP 性能和外观的技巧
在Form域中Post大于100K的数据
如何使用ASP制作模似动态生长的表单?
Microsoft IIS 真的如此「不安全」吗?(1)
Microsoft IIS 真的如此「不安全」吗?(2)
Microsoft IIS 真的如此「不安全」吗?(3)
Microsoft IIS 真的如此「不安全」吗?(4)
Microsoft IIS 真的如此「不安全」吗?(5)
关于页面和代码分离
ServerVariables 对路径的操作

ASP调用ORACLE存储过程并返回结果集


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 19 ::
收藏到网摘: n/a

       看过网上好多ASP调用ORACLE的方法,但是没有特好特直接的东西,所以总结各家的东西最后得出的一个自己需要的方法,感觉也比较大众所以特此发布
  
  ###################################################
  oracle的存储过程
  ###################################################
  
  --创建包头
  create or replace package pck_as
  as
   type t_product_id is table of number
   index by binary_integer;
   type t_serial_no is table of varchar(300)
   index by binary_integer;
   type t_buy_date is table of date
   index by binary_integer;
  
   procedure allsfc
   (
   product_id out t_product_id,
   serial_no out t_serial_no,
   buy_date out t_buy_date
   );
  
   --procedure allsfc1;
  end pck_as;
  
  
  --创建包体
  create or replace package body pck_as
  as
   procedure allsfc
   (
   product_id out t_product_id,
   serial_no out t_serial_no,
   buy_date out t_buy_date
   )
   is
   cursor cur_sfc_tbl_product_reg is
   select product_id,serial_no,buy_date from sfc_tbl_product_reg;
  
   i number default 1;
  
   begin
   for onrecord in cur_sfc_tbl_product_reg
   loop
   product_id(i) := onrecord.product_id;
   serial_no(i) := onrecord.serial_no;
   buy_date(i) := onrecord.buy_date;
   i := i + 1;
   end loop;
   end;
  end;
  
  
  
  
  ###################################################
  ASP的调用
  ###################################################
  <html>
  <head>
  <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
  <title>无标题文档</title>
  </head>
  
  <body>
  <%
  dim str_ora
  dim objconn_ora
  str_ora = "Driver={Microsoft ODBC for Oracle};Server=ora192;uid=dwuser;pwd=family.samsung.com.cn"
  set objconn_ora = server.CreateObject("adodb.connection")
  objconn_ora.connectionstring = str_ora
  objconn_ora.CursorLocation = 3
  objconn_ora.open
  
  dim strsql
  set rs1 = server.CreateObject("ADODB.RecordSet")
  strsql = "{call pck_as.allsfc({resultset 90000, product_id, serial_no, buy_date})}"
  set objcomm1 = server.CreateObject("adodb.command")
  objcomm1.activeconnection = objconn_ora
  objcomm1.commandtype = 1
  objcomm1.commandtext = strsql
  set rs1 = objcomm1.execute
  
  
  while not rs1.eof
   response.Write(rs1(0) & "|" & rs1(1) & "|" & rs1(2) & "|<BR>")
   rs1.movenext
  wend
  %>
  </body>
  </html>