asp调用oracle存储过程
① asp 调用oracle存储过程有返回记录集时经常是出现未指定错误'80004005'
Microsoft JET Database Engine (0x80004005)未指定的错误解决1、系统可能没有注册msjetoledb40.dll,解决办法是 点 开始--->运行, 输入 regsvr32 msjetoledb40.dll, 回车即可;2、数据库所在文1、系统可能没有注册msjetoledb40.dll,解决办法是 点 开始--->运行, 输入 regsvr32 msjetoledb40.dll, 回车即可;2、数据库所在文件夹权限 打开办法是:打开我的电脑,然后点菜单上的“文件夹选项”--->查看,然后把“使用简单文件夹共享(推荐)”前面的钩去掉,然后点“确认”;接下来回到需要打开权限的文件夹(数据库存放的文件夹),右键---> 属性--->安全,然后点“添加”--->"高级"--->立即查找--->然后在下面的地方选择“everyone”--->确定--->点刚才加入的"everyone",然后在下面的大框编辑everyone权限为完全控制,保存即可。3、需要打开guest用户 打开方法:我的电脑--->控制面板--->管理工具---->计算机管理--->本地用户和组---用户---找到"guest",双击,然后把弹出来的狂上的“帐户已停用”前的钩去掉,保存即可。4、temp(临时文件夹)权限 打开办法:windows--->temp,单击右键选择-属性,你就会看到一个叫做“安全”的选项,添加一个everyone,权限设置为完全控制,再将你正在使用windows的用户也设置为完全控制。试试吧,就这几个问题
出现错误的这个几率大些
1.查看数据库连接语句没有发现错误;
2.查看文件夹的权限已经全部给了everyone;
3.打开数据库的同时,系统会在临时文件夹 %SystemRoot%/temp/ 下创建临时文件,而 %systemRoot%/temp/ 的权限不够解决:%SystemRoot%/temp/ 的权限加上(IUSER_电脑名的读写) 此错是WINDOWS目录下没有TEMP文件夹导致出错,建一个TEMP文件夹后则一切正常.
4.TEMP文件最好也把权限设置为everyone
② asp.net调用oracle存储过程【输入字符串错误】
OracleParameter p2 = new OracleParameter("name_", OracleType.VarChar);        p1.Direction = ParameterDirection.Output;       
 p1.Value = "w";        
这里类型错了吧,定义的应该是int,你这又再进行string类型的赋值了
③ asp调用oracle存储过程并返回结果集
你可以花点时间看一下简单的资料,这样希望可以将问题解决,^_^
游标FOR循环  
在大多数时候我们在设计程序的时候都遵循下面的步骤:  
1、打开游标  
2、开始循环  
3、从游标中取值  
4、检查那一行被返回  
5、处理  
6、关闭循环  
7、关闭游标  
    可以简单的把这一类代码称为游标用于循环。但还有一种循环与这种类型不相同,这就是FOR循环,用于FOR循环的游标按照正常的声明方式声明,它的优点在于不需要显式的打开、关闭、取数据,测试数据的存在、定义存放数据的变量等等。游标FOR循环的语法如下:  
FOR record_name IN  
 (corsor_name[(parameter[,parameter]...)]  
 | (query_difinition)  
LOOP  
  statements  
END LOOP;  
下面我们用for循环重写上面的例子:  
DECALRE  
CURSOR c_dept IS SELECT deptno,dname FROM dept ORDER BY deptno;  
CURSOR c_emp (p_dept VARACHAR2) IS  
 SELECT ename,salary  
 FROM emp  
 WHERE deptno=p_dept  
 ORDER BY ename  
v_tot_salary EMP.SALARY%TYPE;  
BEGIN  
   FOR r_dept IN c_dept LOOP  
     DBMS_OUTPUT.PUT_LINE('Department:'|| r_dept.deptno||'-'||r_dept.dname);  
     v_tot_salary:=0;  
     FOR r_emp IN c_emp(r_dept.deptno) LOOP  
    DBMS_OUTPUT.PUT_LINE('Name:' || v_ename || 'salary:' || v_salary);   
    v_tot_salary:=v_tot_salary+v_salary;  
     END LOOP;  
     DBMS_OUTPUT.PUT_LINE('Toltal Salary for dept:'|| v_tot_salary);  
  END LOOP;  
END;  
在游标FOR循环中使用查询  
    在游标FOR循环中可以定义查询,由于没有显式声明所以游标没有名字,记录名通过游标查询来定义。  
DECALRE  
 v_tot_salary EMP.SALARY%TYPE;  
BEGIN  
  FOR r_dept IN (SELECT deptno,dname FROM dept ORDER BY deptno) LOOP  
     DBMS_OUTPUT.PUT_LINE('Department:'|| r_dept.deptno||'-'||r_dept.dname);  
     v_tot_salary:=0;  
     FOR r_emp IN (SELECT ename,salary  
               FROM emp  
               WHERE deptno=p_dept  
               ORDER BY ename) LOOP  
       DBMS_OUTPUT.PUT_LINE('Name:'|| v_ename||' salary:'||v_salary);  
       v_tot_salary:=v_tot_salary+v_salary;  
     END LOOP;  
  DBMS_OUTPUT.PUT_LINE('Toltal Salary for dept:'|| v_tot_salary);  
  END LOOP;  
END;  
游标中的子查询  
    语法如下:  
     
CURSOR C1 IS SELECT * FROM emp  
  WHERE deptno NOT IN (SELECT deptno  
   FROM dept  
   WHERE dname!='ACCOUNTING');  
可以看出与SQL中的子查询没有什么区别。  
游标中的更新和删除  
    在PL/SQL中依然可以使用UPDATE和DELETE语句更新或删除数据行。显式游标只有在需要获得多行数据的情况下使用。PL/SQL提供了仅仅使用游标就可以执行删除或更新记录的方法。  
UPDATE或DELETE语句中的WHERE CURRENT OF子串专门处理要执行UPDATE或DELETE操作的表中取出的最近的数据。要使用这个方法,在声明游标时必须使用FOR UPDATE子串,当对话使用FOR UPDATE子串打开一个游标时,所有返回集中的数据行都将处于行级(ROW-LEVEL)独占式锁定,其他对象只能查询这些数据行,不能进行UPDATE、DELETE或SELECT...FOR            UPDATE操作。  
语法:  
    FOR UPDATE [OF [schema.]table.column[,[schema.]table.column]..  
    [nowait]  
     
    在多表查询中,使用OF子句来锁定特定的表,如果忽略了OF子句,那么所有表中选择的数据行都将被锁定。如果这些数据行已经被其他会话锁定,那么正常情况下ORACLE将等待,直到数据行解锁。  
在UPDATE和DELETE中使用WHERE CURRENT OF子串的语法如下:  
WHERE{CURRENT OF cursor_name|search_condition}  
例:  
DELCARE  
CURSOR c1 IS SELECT empno,salary  
 FROM emp  
 WHERE comm IS NULL  
 FOR UPDATE OF comm;  
v_comm NUMBER(10,2);  
BEGIN  
   FOR r1 IN c1 LOOP  
     IF r1.salary<500 THEN  
       v_comm:=r1.salary*0.25;  
     ELSEIF r1.salary<1000 THEN  
       v_comm:=r1.salary*0.20;  
     ELSEIF r1.salary<3000 THEN  
       v_comm:=r1.salary*0.15;  
     ELSE  
         v_comm:=r1.salary*0.12;  
     END IF;  
   UPDATE emp;  
   SET comm=v_comm  
   WHERE CURRENT OF c1l;  
   END LOOP;  
END
呵呵,希望能有帮助,^_^
④ 如何在ASP中调用Oracle存储过程
调用不了,这个数据库太复杂了
⑤ 如何在ASP中调用Oracle的存储过程求答案
age number(4),
gender char(1)
) 添加一条约束于gender,alter table test
add constraint gender_chk check (gender in ('m','f','M','F')) 并且添加默认值于gender,alter table test
modify (gender default 'm') 添加数据:insert into test values
('刀锋',21,'m')
insert into test values
('柳飞雪',14,'f') call lzbbs.del('1')
程序包或函数DEL处于无效状态 begindel('1');end; ERROR 位于第 2 行:
ORA-06550: 第 2 行, 第 1 列:
PLS-00905: 对象 LZBBS.DEL 无效
ORA-06550: 第 2 行, 第 1 列:
PL/SQL: Statement ignored
使用ASP访问Oracle的存储过程:set cmd=Server.CreateObject("ADODB.Command")
cmd.ActiveConnection=conn
'cmd.CommandText="{call jcptdb.IsPermit(?,?,(resultset 1,out1))}"
cmd.parameters.append paracmd(0)="1"cmd.execute OraOLEDB 错误'80040e14'ORA-06550: 第 1 行, 第 13 列: PLS-00905: 对象 LZBBS.DEL 无效 ORA-06550: 第 1 行, 第 7 列: PL/SQL: Statement ignored/test.asp,行 92
⑥ asp.net调用oracle的存储过程
Parameters是SQL参数类.你可以单独创建这个类的实例,再将其赋值给cmd的Parameters属性.这个是因为有的SQL语句或者存储过程有一些输入和输出参数.
你给的代码中的TbName是一个参数实例的名称
OracleType.VarChar是定义这个参数的Oracle数据类型,其中的50是定义这个字段的长度为50个VarChar.
⑦ 如何在ASP中调用Oracle的存储过程
如何在ASP中调用Oracle的存储过程
age
number(4),
gender
char(1)
)
添加一条约束于gender,alter
table
test
add
constraint
gender_chk
check
(gender
in
('m','f','M','F'))
并且添加默认值于gender,alter
table
test
modify
(gender
default
'm')
添加数据:insert
into
test
values
⑧ 如何用asp调用oracle9存储过程。需要例子加80分
<%
dim sp_common
Set sp_common = Server.CreateObject("ADODB.Command") 
 with sp_common      
  .ActiveConnection = conn  
  .CommandText = "cd_update_log"
  .Parameters.Append .CreateParameter("@inputremark", adVarChar, adParamInput,50,"联通.Ye")
  .Parameters.Append .CreateParameter("@msg", adInteger, adParamOutput)
 .execute
 end with 
 
msg=sp_common("@msg")
response.write msg
response.end
%>
表
create table CD_BILL_LOG
 (
   BILL_ID      NUMBER,
   DEAL_EMP_ID  NUMBER,
   REACH_DATE   DATE,
   DONE_DATE    DATE,
   BILL_STATUS  VARCHAR2(10),
   DEAL_DEPT_ID NUMBER,
   SIGN         NUMBER,
   REMARK       VARCHAR2(50)
 )
 ;
存储过程
create or replace procere 
cd_update_log(inputremark varchar2,msg out float)
 as
 begin
 
   update cd_bill_log a 
   set a.remark =inputremark   --to_char(sysdate,'mi:ss') 
   where a.bill_id=45;
    msg:=1;
   commit;
end;
⑨ 求解asp调oracle存储过程
SQLstr={call package.procere(?,{output1})}
.Parameters.Append .CreateParameter("@inputremark", adVarChar, adParamInput,50,"联通.Ye")
  .Parameters.Append .CreateParameter("@msg", adInteger, adParamOutput)
参考着吧
