Oracle之绑定变量 2
绑定变量(bind variable)我们经常在写plsql中用到,那我们承接上一节的来看看在plsql中静态sql和动态sql在绑定变量的区别
declare
v_value_a varchar2(100);
v_value_b varchar2(100);
v_name varchar2(50);
begin
v_value_a := 'SMITH';
select e.enameinto v_name from scott.emp e where e.ename = v_value_a;
v_value_b := 'ALLEN';
select e.enameinto v_name from scott.emp e where e.ename = v_value_b;
end;
/
查询v$sql
select * from v$sql d where d.SQL_TEXT like '%%';
这里看到只产生了一条sql_id,oracle会自动把变量v_value_a,v_value_b换成绑定变量:B1.
再来看看动态sql
PLSQL_1:
declare
v_value_a varchar2(100);
v_value_b varchar2(100);
v_name varchar2(50);
begin
v_value_a := 'SMITH';
v_value_b := 'ALLEN';
execute immediate 'select e.ename from scott.emp e where e.ename = :xxx'
using v_value_a;
execute immediate 'select e.ename from scott.emp e where e.ename = :yyy'
using v_value_b;
end;
/
查询v$sql
select * from v$sql d where d.SQL_TEXT like '%%';
这里可以看到动态sql就是以执行sql为文本进行解析的,如果两个sql有不同就是不同的sql语句。
2.获取绑定变量的值
那我们可以得到绑定的变量的值吗?通过v$sql_bind_capture就可以查询到
SQL_1:
select d.NAME, d.POSITION, d.SQL_ID, value_string
from v$sql_bind_capture d
where d.SQL_ID in
(select sql_id from v$sql v where v.SQL_TEXT like '%%')
这时我们看到绑定变量的值是上文看到的v_value_a和v_value_b的值。
接着往下走,改变v_value_a的值:
v_value_a := 'CLARK';
执行PLSQL_1,SQL_1
绑定变量的值并没有发生变化,这时为什么呢?
v$sql_bind_capture这个视图是一个快照视图,并不会保存所有执行过的SQL的绑定变量,只会记录最近一次捕获到的绑定值,而已每次捕获都是有间隔时间的。ORACLE为我们提供了一个隐含参数_cursor_bind_capture_interval(默认900s),这个就是控制绑定变量抓取频率的参数。
如果绑定变量是DATE类型则无法直接查看到的。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341