用Oracle绑定变量替代sql语句里常量

http://database.51cto.com/art/201004/192426.htm


在实际相关应用操作过程中的具体操作中唯一能使得Oracle 能重复的利用执行计划的相关方法就是用绑定变量的方法。其实Oracle绑定变量的实质就是用于替代sql语句中的常量的替代变量。

Oracle 中,对于一个提交的sql语句,存在两种可选的解析过程, 一种叫做硬解析,一种叫做软解析.

一个硬解析需要经解析,制定执行路径,优化访问计划等许多的步骤.硬解释不仅仅耗费大量的cpu,更重要的是会占据重要的们闩(latch)资源,严重的影响系统的规模的扩大(即限制了系统的并发行), 而且引起的问题不能通过增加内存条和cpu的数量来解决。

之所以这样是因为门闩是为了顺序访问以及修改一些内存区域而设置的,这些内存区域是不能被同时修改。当一个sql语句提交后,Oracle 会首先检查一下共享缓冲池(shared pool)里有没有与之完全相同的语句,如果有的话只须执行软分析即可,否则就得进行硬分析。

而唯一使得Oracle 能够重复利用执行计划的方法就是采用绑定变量。绑定变量的实质就是用于替代sql语句中的常量的替代变量。绑定变量能够使得每次提交的sql语句都完全一样。

绑定变量只是起到占位的作用,同名的绑定变量并不意味着在它们是同样的,在传递时要考虑的是传递的值与绑定变量出现顺序的对位,而不是绑定变量的名称。

 
  
  1. create table t (a varchar2(20),b varchar2(20)); 

如何使用Oracle绑定变量

 
  
  1. declare  
  2. v_sql varchar2(50);  
  3. begin  
  4. for i in 1..100000 loop  
  5. v_sql :'insert into t values (:1,:2)';  
  6. execute immediate v_sql using 'a'||i,'b'||i;  
  7. end loop;  
  8. commit;  
  9. end;  
  10. /  

清表

 
  
  1. truncate table t; 

不使用绑定变量

 
  
  1. declare  
  2. begin  
  3. for i in 1..100000 loop  
  4. insert into t values ('a'||i,'b'||i);  
  5. end loop;  
  6. commit;  
  7. end;  
  8. /  

你可能感兴趣的:(Oracle)