oracle之SQL_ID 1

在Oralce里,一个sql语句执行时会生成不少信息:
算法

  • SQL惟一标识sql

  • SQL文本信息数据库

  • 绑定变量信息ide

  • 执行计划和游标信息oop

  • 统计信息性能

  • 性能信息优化

  • 其余信息.例如sql来源,状态等
    spa


SQL_IDblog

    在Oracle中,SQL优化器是负责解析sql的(包括<a>直接执行的sql和<b>存储过程当中的sql),<b>中的sql在提交sql优化器解析前,会进行一些预处理,包括大小写,空格,注释的处理等。图片

    在解析sql时,sql优化器会分配一个ID(子游标),惟一标识一个sql(存储在v$sql视图内)。相同的sql文本sql_id是同样的(对应v$sqlarea中的数据,称它为父游标),即便是不一样的数据库实例中,这个之后在介绍。其余视图经过这个id引用这个sql,在9i中对应的是hash_value这个字段,11g中v$sql有字段old_hash_value对应9i的hash_value,sql_id和hash_value是经过必定的算法计算出来的。


1.直接执行的sql:

  在sql_window下执行 

select /*test*/* from scott.emp e where e.empno = 10; 
select /*test*/* from scott.emp e where e.empno =  10;
select /*test*/* from scott.emp E where e.empno =  10;

 查询他们的sql信息

select * from v$sql v where v.SQL_TEXT like '%/*test*/%';

wKioL1fMMZbBV6MwAAF6kl2c2kE025.png-wh_50

能够看到若是两个sql文本之间只要有任何的不一样,就会生成不一样的sql_id


2.存储过程当中的sql:

  分静态sql和动态sql两种,动态sql和第一种直接执行的sql同样,咱们关注一下静态sql

declare
  v number;
begin
  select /*+test1*/e.sal into v from scott.emp e where e.empno = 7369; 
  select /*+test1*/e.sal into v from scott.emp e where e.empno =  7369;
  select /*+test1*/e.sal into v from scott.emp E  where e.empno =  7369; 
  
end;
/

  执行后,查询sql信息,这里应该使用提示/*+xxx*/,注释会被过滤掉

wKiom1fMNlnBPl2wAAFQre3OB28926.png-wh_50

从图中能够看出,三个sql语句只生成了一个sql_id,说明plsql提交到sql优化器的时候作了一些预处理。


若是使用绑定变量呢?咱们来看看有什么变化

declare
  v dbms_sql.Number_Table;
  xx number;
begin
  v(1) := 7369;
  v(1) := 7499;
  v(1) := 7521;

  for i in v.first .. v.last loop
    select /*+test2*/e.sal into xx from scott.emp e where e.empno = v(i);
  end loop;
end;
/

咱们来看看sql_id状况

wKioL1fMOAjBYDHoAAFggtxCBTY033.png-wh_50

咱们看到也是只有一条sql语句的sql_id信息。e.empno = v(i) 被替换成了 绑定变量:B,当sql被提交到内存执行的时候,才会替换为具体的值并执行返回结果。

相关文章
相关标签/搜索