Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1031350
  • 博文数量: 159
  • 博客积分: 3063
  • 博客等级: 中校
  • 技术积分: 2703
  • 用 户 组: 普通用户
  • 注册时间: 2012-04-01 01:51
文章分类

全部博文(159)

文章存档

2013年(48)

2012年(111)

分类: Oracle

2013-06-10 16:21:55

1、查一下这些视图的定义你就能理解,它们的源都是一个。 
SELECT view_definition FROM v$fixed_view_definition WHERE view_name='GV$SQL'; 
SELECT view_definition FROM v$fixed_view_definition WHERE view_name='GV$SQL_AREA'; 
2、实际上最模糊的是v$sql与v$sqlarea,区别与联系除biti说的还有: 
a、v$sql_area相当于是按INST_ID, KGLNAOBJ, KGLHDPAR, KGLNAHSH, KGLNATIM, GLOBTS0,GLOBT19, KGLOBTS1, KGLOBT20,DECODE(KGLOBT33, 1, 'Y', 'N'),KGLHDCLT这些列的自v$sql的group by,也就是说v$sql的每一行表示的是每一个sql语句的一个versiion,而v$sqlarea存放的是相同语句不同version一个汇总。 
b、 v$sql与v$sqlarea的源都是一个:X$KGLCURSOR 
c、实际调优中建议使用v$sql,相对来说比v$sqlarea快,而且还不会产生share pool latch的争用。 
3、因v$sql及v$sqlarea存放着统计信息在调优时使用居多,但其sql是不全的,如果想获得完整的sql就要用v$sqltext了。 
v$sqlarea --------- 存储的SQL 和一些相关的信息,比如累计的执行次数,逻辑读,物理读等统计信息 
v$sql ---------- 存储的是具体的SQL 和执行计划相关信息,实际上,v$sqlarea 可以看做 v$sql 根据 sqltext 等 做了 group by 之后的信息 
实际上,看起来同样的一句SQL ,往往具有不同的执行计划 
如果是不同的数据库用户,那么相应的涉及的 对象 可能都不一样,注意v$sql 中 
OBJECT# NUMBER 
OBJECT_OWNER VARCHAR2(30) 
OBJECT_NAME VARCHAR2(64) 
OPTIMIZER VARCHAR2(40) 
即使是相同的数据库用户,若 session 的优化模式、session 级的参数 等不一样,执行计划也能不同。所以即使相同的sql,也可能具有不同的执行计划! 
v$sql join to v$sql_plan 就代表了具体的sql的执行计划,通过下面3个字段做连接 
ADDRESS RAW(4) 
HASH_VALUE NUMBER 
CHILD_NUMBER NUMBER 
而v$SQLAREA 忽略了 执行计划 等差异,只是在形式上sql文本看起来一样!相当于做了个聚合,是多个不同执行计划的sql的聚合和累计信息 
阅读(1575) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~