189 8069 5689

oracle之SQL_ID1

在Oralce里,一个sql语句执行时会生成很多信息:

创新互联公司是一家集网站建设,平阳企业网站建设,平阳品牌网站建设,网站定制,平阳网站建设报价,网络营销,网络优化,平阳网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。

  • SQL唯一标识

  • SQL文本信息

  • 绑定变量信息

  • 执行计划和游标信息

  • 统计信息

  • 性能信息

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

SQL_ID

    在Oracle中,SQL优化器是负责解析sql的(包括直接执行的sql和存储过程中的sql),中的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*/%';

oracle之SQL_ID 1

可以看到如果两个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*/,注释会被过滤掉

oracle之SQL_ID 1

从图中可以看出,三个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情况

oracle之SQL_ID 1

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


标题名称:oracle之SQL_ID1
标题路径:
http://cdxtjz.cn/article/psisgd.html

联系我们

您好HELLO!
感谢您来到成都网站建设公司,若您有合作意向,请您为我们留言或使用以下方式联系我们, 我们将尽快给你回复,并为您提供真诚的设计服务,谢谢。
  • 电话:028- 86922220 18980695689
  • 商务合作邮箱:631063699@qq.com
  • 合作QQ: 532337155
  • 成都网站设计地址:成都市青羊区锣锅巷31号五金站写字楼6楼

小谭建站工作室

成都小谭网站建设公司拥有多年以上互联网从业经验的团队,始终保持务实的风格,以"帮助客户成功"为已任,专注于提供对客户有价值的服务。 我们已为众企业及上市公司提供专业的网站建设服务。我们不只是一家网站建设的网络公司;我们对营销、技术、管理都有自己独特见解,小谭建站采取“创意+综合+营销”一体化的方式为您提供更专业的服务!

小谭观点

相对传统的成都网站建设公司而言,小谭是互联网中的网站品牌策划,我们精于企业品牌与互联网相结合的整体战略服务。
我们始终认为,网站必须注入企业基因,真正使网站成为企业vi的一部分,让整个网站品牌策划体系变的深入而持久。