PL/SQL的存储编译问题 30
请高手指点PROCEDURE如下:createorreplaceprocedurewxlup_cj(sinnumber)isbeginwhiles<=17loopupda...
请高手指点
PROCEDURE如下:
create or replace procedure wxlup_cj
(s in number)is
begin
while s <= 17
loop
update IDC_U_YJSJW.YJSJW_PY_CJ t
set t.kclb = (select a.kclbdm
from IDC_U_YJSJW.YJSJW_PY_DM_KCLB a
where a.kclbmc = (select b.tzkclb
from IDC_U_YJSJW.YJSJW_PY_CJ0 b
where b.nu = 's'));
s:=s+1;
END loop;
end;
编译时会提示
Compilation errors for PROCEDURE IDC_U_YJSJW.WXLUP_CJ
Error: PLS-00363: expression 'S' cannot be used as an assignment target
Line: 12
Text: s:=s+1;
Error: PL/SQL: Statement ignored
Line: 12
Text: s:=s+1;
procedure能编译 但执行时会提示
ORA-01008: not all variables bound
另:execute procedure的命令是execute wxlup_cj(1)还是execute wxlup_cj(:1)?
谢谢 展开
PROCEDURE如下:
create or replace procedure wxlup_cj
(s in number)is
begin
while s <= 17
loop
update IDC_U_YJSJW.YJSJW_PY_CJ t
set t.kclb = (select a.kclbdm
from IDC_U_YJSJW.YJSJW_PY_DM_KCLB a
where a.kclbmc = (select b.tzkclb
from IDC_U_YJSJW.YJSJW_PY_CJ0 b
where b.nu = 's'));
s:=s+1;
END loop;
end;
编译时会提示
Compilation errors for PROCEDURE IDC_U_YJSJW.WXLUP_CJ
Error: PLS-00363: expression 'S' cannot be used as an assignment target
Line: 12
Text: s:=s+1;
Error: PL/SQL: Statement ignored
Line: 12
Text: s:=s+1;
procedure能编译 但执行时会提示
ORA-01008: not all variables bound
另:execute procedure的命令是execute wxlup_cj(1)还是execute wxlup_cj(:1)?
谢谢 展开
展开全部
这样就应该可以了create or replace procedure wxlup_cj
(s in out number)is
(s in out number)is
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
in关键字的参数是只读的,是不可以更新的。
所以你应该再声明一个变量,然后把参数值赋值给这个变量,然后来控制循环。
不过楼上说的,加上out关键字也可以。只是那样的话,外面传进来的变量也被更新了。如果你传入一个hard code进去,程序还是会有异常。
所以你应该再声明一个变量,然后把参数值赋值给这个变量,然后来控制循环。
不过楼上说的,加上out关键字也可以。只是那样的话,外面传进来的变量也被更新了。如果你传入一个hard code进去,程序还是会有异常。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询