|
4.过程中的参数会自动转化为绑定变量
SQL> edit
已写入 file afiedt.buf
1 create or replace procedure proc_test(p_id int, p_name varchar2)
2 is
3 begin
4 insert into tt values(p_id , p_name);
5 commit;
6* end;
SQL> /
过程已创建。
SQL> alter session set sql_trace=true;
会话已更改。
SQL> exec proc_test(200,'test');
PL/SQL 过程已成功完成。
SQL> alter session set sql_trace=false;
会话已更改。
--trace file:
alter session set sql_trace=true
END OF STMT
EXEC #3:c=0,e=749,p=0,cr=0,cu=0,mis=1,r=0,dep=0,og=1,tim=7393908487
=====================
PARSING IN CURSOR #1 len=35 dep=0 uid=31 oct=47 lid=31 tim=7403000735 hv=526484776
ad='6687b0b8'
BEGIN proc_test(200,'test'); END;
END OF STMT
PARSE #1:c=0,e=2584,p=0,cr=0,cu=0,mis=1,r=0,dep=0,og=1,tim=7403000727
=====================
PARSING IN CURSOR #6 len=33 dep=1 uid=31 oct=2 lid=31 tim=7403001293 hv=2874748229
ad='668e9cd8'
INSERT INTO TT VALUES(:B2 , :B1 )
END OF STMT
PARSE #6:c=0,e=246,p=0,cr=0,cu=0,mis=1,r=0,dep=1,og=1,tim=7403001286
=====================
另外也可以直观的观察:
SQL> exec proc_test(200,'test');
PL/SQL 过程已成功完成。
SQL> select sql_text from v$sql where sql_text like '%proc_test%';
SQL_TEXT
--------------------------------------------------------------------------------
BEGIN proc_test(200,'test'); END;
SQL>
在sqlplus里执行过程不能观察出来
下面在plsql developer执行一次过程之后再来看执行的情况
SQL> select sql_text from v$sql where sql_text like '%proc_test%';
SQL_TEXT
--------------------------------------------------------------------------------
begin -- Call the procedure proc_test(p_id => _id, p_name => :
p_name); end;
SQL>
很显然oracle在执行过程时把参数转化为绑定变量了,其实从plsql developer中执行过程时的语法就能
看出来:
begin
-- Call the procedure
proc_test(p_id => _id,
p_name => _name);
end;
在输入参数列表框上面的执行语法就是这样的。
[ 本帖最后由 warehouse 于 2008-4-4 00:37 编辑 ] |
|