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

数据库 Oracle
Oracle绑定变量的实质其实就是用来替代sql语句里常量的替代变量。绑定变量能使每次提交的sql语句都完全一样,以下是相关内容的介绍。

在实际相关应用操作过程中的具体操作中***能使得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绑定变量的相关内容介绍,望你能有所收获。

【编辑推荐】

  1. 在Oracle 处理日期中对日期语言的设置
  2. 在Oracle 数据类型中如何使用dump函数
  3. Oracle备份恢复与批处理文件实操
  4. Oracle reports提供的六种风格报表格式
  5. Oracle reports工具的使用
责任编辑:佚名 来源: 博客园
相关推荐

2010-03-31 15:03:54

Oracle执行

2010-04-06 16:36:55

Oracle绑定变量

2010-04-01 14:35:36

Oracle绑定变量

2011-08-18 14:25:26

OracleEXPLAIN PLA

2009-11-16 13:47:35

Oracle SQL语

2009-11-16 17:55:58

Oracle SQL语

2010-04-27 09:28:55

绑定变量

2010-04-02 15:53:36

Oracle绑定变量

2010-09-08 17:35:25

SQL表变量

2009-11-06 17:13:24

Oracle SQL语

2010-04-13 15:04:16

Oracle优化

2009-11-05 18:07:33

Oracle导出sql

2009-11-06 17:21:36

验证Oracle SQ

2010-04-13 14:36:17

Oracle性能检测

2011-04-15 09:26:20

Oraclemerge语句

2010-05-05 14:27:34

Oracle SQL语

2012-02-02 15:36:21

Hibernate

2010-04-02 14:46:54

Oracle当前连接数

2010-04-20 15:22:34

Oracle SQL

2009-01-14 09:28:12

OracleSQL10g
点赞
收藏

51CTO技术栈公众号