温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Oracle之绑定变量 2

发布时间:2020-06-05 19:51:26 来源:网络 阅读:573 作者:xiaofeng520ct 栏目:关系型数据库

绑定变量(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.ename/*+test*/into v_name from scott.emp e where e.ename = v_value_a;
    v_value_b := 'ALLEN';
    select e.ename/*+test*/into 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 '%/*+test*/%';

Oracle之绑定变量 2

这里看到只产生了一条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/*+sql*/ from scott.emp e where e.ename = :xxx' 
    using v_value_a;
    
    execute immediate 'select e.ename/*+sql*/ 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*/%';

Oracle之绑定变量 2

这里可以看到动态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 '%/*+sql*/%')

Oracle之绑定变量 2

这时我们看到绑定变量的值是上文看到的v_value_a和v_value_b的值。

接着往下走,改变v_value_a的值:

v_value_a := 'CLARK';

执行PLSQL_1,SQL_1

Oracle之绑定变量 2

绑定变量的值并没有发生变化,这时为什么呢?

  • v$sql_bind_capture这个视图是一个快照视图,并不会保存所有执行过的SQL的绑定变量,只会记录最近一次捕获到的绑定值,而已每次捕获都是有间隔时间的。ORACLE为我们提供了一个隐含参数_cursor_bind_capture_interval(默认900s),这个就是控制绑定变量抓取频率的参数。

  • 如果绑定变量是DATE类型则无法直接查看到的。


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI