Oracle的v$sql,v$sqlarea,v$sqltext

Oracle v$sql,v$sqlarea,v$sqltext

 

一:查看有哪些V$sql开头的动态性能视图

SELECT FROM DICT WHERE A.TABLE_NAME LIKE '%V$SQL%';

 

二:v$sql v$sqlareav$sqltext 区别

通常有人喜欢问v$sql,v$sqlarea,v$sqltext这三个视图的区别,一般还真很少注意这个(这个很重要么?),看看就晓得了:

首先:SELECT from v$fixed_view_definition WHERE a.VIEW_NAME='V$SQL';

然后SELECT from v$fixed_view_definition WHERE a.VIEW_NAME='GV$SQL';

 

SELECT from v$fixed_view_definition WHERE a.VIEW_NAME='GV$SQLAREA';

 

SELECT from v$fixed_view_definition WHERE a.VIEW_NAME='GV$SQLTEXT';

 

这里可以看到每个视图的定义,可以发现者三个视图分别基于下面三个表:

x$kglcursor_child

x$kglcursor_child_sqlid

x$kglna

 

--------v$sqltext
存储的是完整的SQL,SQL被分割存放

SQL> desc v$sqltext
Name                                      Null?    Type
----------------------------------------- -------- ----------------------------
ADDRESS                                            RAW(4)    ---------
HASH_VALUE                                         NUMBER   ---------  和 address 一起唯一标志一条sql
COMMAND_TYPE                                       NUMBER
PIECE                                              NUMBER   ----------  分片之后的顺序编号
SQL_TEXT                                           VARCHAR2(64)   --------------  注意长度



-------v$sqlarea   

----存储的SQL 和一些相关的信息,比如累计的执行次数,逻辑读,物理读等统计信息


------V$SQLAREA 列出了共享SQL区(Shared SQL Area)中的SQL统计信息,这些SQL按照SQL文本的不同,每条会记录一行统计数据。注意这里所说的是“按照SQL文本”来进行区分,也就是说这个视图的信息可以看作是根据SQL_TEXT进行的一次汇总统计。

 

Column

Datatype

Description

SQL_TEXT

VARCHAR2(1000)

当前指针的前1000个字符

VERSION_COUNT

NUMBER

Cache中这个父指针下存在的子指针的数量

EXECUTIONS

NUMBER

总的执行次数,包含所有子指针执行次数的汇总

DISK_READS

NUMBER

所有子指针的Disk Reads总和

BUFFER_GETS

NUMBER

所有子指针的Buffer Gets总和

OPTIMIZER_MODE

VARCHAR2(10)

SQL执行的优化器模式

HASH_VALUE

NUMBER

父指针的Hash Value




 ------v$sql    

---  存储的是具体的SQL 和执行计划相关信息,实际上,v$sqlarea 可以看做 v$sql 根据 sqltext 等 做了 group by 之后的信息

 

Column

Datatype

Descrption

SQL_TEXT

VARCHAR2(1000)

当前SQL指针的前1000个字符(也就是说这里记录的SQL是不完整的)

EXECUTIONS

NUMBER

执行次数

DISK_READS

NUMBER

这个子指针Disk Read的次数

BUFFER_GETS

NUMBER

这个子指针的Buffer Gets数量

OPTIMIZER_MODE

VARCHAR2(10)

SQL执行的优化器模式

OPTIMIZER_COST

NUMBER

SQL执行成本

HASH_VALUE

NUMBER

在Library Cache中父指针的Hash Value值

 


v$sql里面找不到完整的sql的时候,则需要从v$sqlarea中找或者拼v$sqltextsql



实际上,看起来同样的一句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的聚合和累计信息

总结:

 

 

1V$SQL,V$SQLAREA 源都是一个
2、实际上最模糊的是v$sqlv$sqlarea, 

av$sql_area相当于是按INST_ID, KGLNAOBJ, KGLHDPAR, KGLNAHSH, KGLNATIM, GLOBTS0,GLOBT19, KGLOBTS1, KGLOBT20,DECODE(KGLOBT33, 1, 'Y', 'N'),KGLHDCLT这些列的自v$sqlgroup by,也就是说v$sql的每一行表示的是每一个sql语句的一个version,而v$sqlarea存放的是相同语句不同version一个汇总。

b、 v$sqlv$sqlarea的源都是一个:X$KGLCURSOR

c、实际调优中建议使用v$sql,相对来说比v$sqlarea快,而且还不会产生share pool latch的争用。

3、因v$sqlv$sqlarea存放着统计信息在调优时使用居多,但其sql_text是不全的,如果想获得完整的sql就要用v$sqltext了。

示例:


1.查看消耗资源最多的SQL
SELECT HASH_VALUE, EXECUTIONS, BUFFER_GETS, DISK_READS, PARSE_CALLS

  FROM V$SQLAREA

 WHERE BUFFER_GETS 10000000

    OR DISK_READS 1000000

 ORDER BY BUFFER_GETS 100 DISK_READS DESC;

 

2.查看某条SQL语句的资源消耗:
SELECT HASH_VALUE, BUFFER_GETS, DISK_READS, EXECUTIONS, PARSE_CALLS

  FROM V$SQLAREA

 WHERE HASH_VALUE 228801498

   AND ADDRESS HEXTORAW('CBD8E4B0');

 

示例:已知hash_value:3111103299,查询sql语句:
select from v$sqltext
where hash_value='3111103299'
order by piece 

 

 

 

 

 

转自:http://www.cnblogs.com/sopost/archive/2012/06/03/2532826.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果您想查看Oracle数据库中执行过的SQL语句历史信息,可以通过以下两种方法实现: 方法一:查看V$SQL和V$SQLTEXT视图 1. 连接到Oracle数据库实例,并使用sysdba权限登录。 2. 执行以下查询语句查看V$SQL视图中的SQL语句信息: ``` SELECT * FROM V$SQL; ``` 该视图包含了所有执行过的SQL语句的信息,包括SQL语句的文本、执行次数、执行时间、执行计划等。 3. 如果需要查看SQL语句的具体内容,可以通过查询V$SQLTEXT视图实现: ``` SELECT * FROM V$SQLTEXT WHERE SQL_ID = 'your_sql_id'; ``` 其中,your_sql_id是需要查看的SQL语句的ID,可以在V$SQL视图中找到。 方法二:使用Oracle SQL Developer 1. 打开Oracle SQL Developer工具,并连接到需要查看SQL历史信息的数据库实例。 2. 在左侧的导航栏中选择“Reports” -> “Standard Reports”。 3. 在弹出的窗口中选择“SQL” -> “Top SQL”或“SQL History”,即可查看执行次数最多的SQL语句或执行历史信息。 4. 如果需要查看SQL语句的具体内容,可以在查询结果中选择需要查看的SQL语句,右键选择“View SQL”,即可查看SQL语句的具体内容。 注意:如果您需要在Oracle数据库中保存SQL执行历史信息,可以通过配置auditing功能实现。在开启此功能后,Oracle数据库会记录所有用户在数据库中执行的SQL语句信息,并保存在数据库的AUD$表中。但是,请注意开启此功能可能会影响数据库性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值