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)
参考着吧