绑定变量(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;
- /
@L_403_1@
这里看到只产生了一条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;
- /
这里可以看到动态sql就是以执行sql为文本进行解析的,如果两个sql有不同就是不同的sql语句。
2.获取绑定变量的值
那我们可以得到绑定的变量的值吗?通过v$sql_bind_capture就可以查询到
这时我们看到绑定变量的值是上文看到的v_value_a和v_value_b的值。
接着往下走,改变v_value_a的值:
- v_value_a:='CLARK';
绑定变量的值并没有发生变化,这时为什么呢?