加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Oracle之绑定变量 2

发布时间:2020-12-12 18:50:46 所属栏目:百科 来源:网络整理
导读:绑定变量( bind variable )我们经常在写plsql中用到,那我们承接上一节的来看看在plsql中静态sql和动态sql在绑定变量的区别 declarev_value_avarchar2(100);v_value_bvarchar2(100);v_namevarchar2(50);beginv_value_a:='SMITH';selecte.ename/*+test*/intov

绑定变量(bind variable)我们经常在写plsql中用到,那我们承接上一节的来看看在plsql中静态sql和动态sql在绑定变量的区别

declare
v_value_avarchar2(100);
v_value_bvarchar2(100);
v_namevarchar2(50);
begin
v_value_a:='SMITH';
selecte.ename/*+test*/intov_namefromscott.empewheree.ename=v_value_a;
v_value_b:='ALLEN';
selecte.ename/*+test*/intov_namefromscott.empewheree.ename=v_value_b;
end;
/

查询v$sql

select*fromv$sqldwhered.SQL_TEXTlike'%/*+test*/%';

wKiom1fWwtfzvdAuAABUe2R8PL4069.png-wh_50

这里看到只产生了一条sql_id,oracle会自动把变量v_value_a,v_value_b换成绑定变量:B1.


再来看看动态sql

PLSQL_1:
declare
v_value_avarchar2(100);
v_value_bvarchar2(100);
v_namevarchar2(50);
begin
v_value_a:='SMITH';

v_value_b:='ALLEN';

executeimmediate'selecte.ename/*+sql*/fromscott.empewheree.ename=:xxx'
usingv_value_a;

executeimmediate'selecte.ename/*+sql*/fromscott.empewheree.ename=:yyy'
usingv_value_b;
end;
/

查询v$sql

select*fromv$sqldwhered.SQL_TEXTlike'%/*+sql*/%';

wKiom1fWxH_RXDQdAACPRV8qgI0965.png-wh_50

这里可以看到动态sql就是以执行sql为文本进行解析的,如果两个sql有不同就是不同的sql语句。


2.获取绑定变量的值

那我们可以得到绑定的变量的值吗?通过v$sql_bind_capture就可以查询到

SQL_1:
selectd.NAME,d.POSITION,d.SQL_ID,value_string
fromv$sql_bind_captured
whered.SQL_IDin
(selectsql_idfromv$sqlvwherev.SQL_TEXTlike'%/*+sql*/%')

wKioL1fidubQRzHdAAB3vUyhBUs165.png-wh_50

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

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

v_value_a:='CLARK';

执行PLSQL_1,SQL_1

wKioL1fieRnyhxdeAAB00-JZ78c283.png-wh_50

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

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

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读