转通过v$sqlarea,v$sql查询最占用资源的查询
来源:互联网 发布:淘宝店铺美工接单 编辑:程序博客网 时间:2024/06/03 19:22
通过v$sqlarea,v$sql查询最占用资源的查询
(2011-09-01 22:22:09)转载▼
标签:
杂谈
-----------------------
v$sqlarea,v$sql
-----------------------
v$sqlarea,v$sql
-----------------------
从V$SQLAREA中查询最占用资源的查询
select b.username username,a.disk_reads reads,
a.executions exec,a.disk_reads/decode(a.executions,0,1,a.executions) rds_exec_ratio,
a.sql_text Statement
fromv$sqlarea a,dba_users b
where a.parsing_user_id=b.user_id
and a.disk_reads > 100000
order by a.disk_reads desc;
from
where a.parsing_user_id=b.user_id
order by a.disk_reads desc;
用buffer_gets列来替换disk_reads列可以得到占用最多内存的sql语句的相关信息。
V$SQL是内存共享SQL区域中已经解析的SQL语句。
列出使用频率最高的5个查询:
select sql_text,executions
from (select sql_text,executions,
rank() over
(order by executions desc) exec_rank
from v$sql)
where exec_rank <=5;
from (select sql_text,executions,
where exec_rank <=5;
消耗磁盘读取最多的sql top5:
select disk_reads,sql_text
from (select sql_text,disk_reads,
dense_rank() over
(order by disk_reads desc) disk_reads_rank
from v$sql)
where disk_reads_rank <=5;
select disk_reads,sql_text
from (select sql_text,disk_reads,
where disk_reads_rank <=5;
找出需要大量缓冲读取(逻辑读)操作的查询:
select buffer_gets,sql_text
from (select sql_text,buffer_gets,
dense_rank() over
(order by buffer_gets desc) buffer_gets_rank
from v$sql)
where buffer_gets_rank<=5;
from (select sql_text,buffer_gets,
where buffer_gets_rank<=5;
V$SQLAREA
本视图持续跟踪所有shared pool中的共享cursor,在shared pool中的每一条SQL语句都对应一列。本视图在分析SQL语句资源使用方面非常重要。
V$SQLAREA中的信息列
HASH_VALUE:SQL语句的Hash值。
ADDRESS:SQL语句在SGA中的地址。
这两列被用于鉴别SQL语句,有时,两条不同的语句可能hash值相同。这时候,必须连同ADDRESS一同使用来确认SQL语句。
PARSING_USER_ID:为语句解析第一条CURSOR的用户
VERSION_COUNT:语句cursor的数量
KEPT_VERSIONS:
SHARABLE_MEMORY:cursor使用的共享内存总数
PERSISTENT_MEMORY:cursor使用的常驻内存总数
RUNTIME_MEMORY:cursor使用的运行时内存总数。
SQL_TEXT:SQL语句的文本(最大只能保存该语句的前1000个字符)。
MODULE,ACTION:使用了DBMS_APPLICATION_INFO时session解析第一条cursor时的信息
V$SQLAREA中的其它常用列
SORTS: 语句的排序数
CPU_TIME: 语句被解析和执行的CPU时间
ELAPSED_TIME: 语句被解析和执行的共用时间
PARSE_CALLS: 语句的解析调用(软、硬)次数
EXECUTIONS: 语句的执行次数
INVALIDATIONS: 语句的cursor失效次数
LOADS: 语句载入(载出)数量
ROWS_PROCESSED: 语句返回的列总数
V$SQLAREA中的连接列Column View Joined Column(s)
HASH_VALUE, ADDRESS V$SESSION SQL_HASH_VALUE, SQL_ADDRESS
HASH_VALUE, ADDRESS V$SQLTEXT, V$SQL, V$OPEN_CURSOR HASH_VALUE, ADDRESS
SQL_TEXT V$DB_OBJECT_CACHE NAME
示例:
1.查看消耗资源最多的SQL:
2.查看某条SQL语句的资源消耗:
查找前10条性能差的sql语句
说明:
EXECUTIONS表示同一条SQL语句一共执行了多少次,SORTS表示排序的次数,DISK_READS表示物理读的数量。
DISK_READS NUMBER
The sum of the number of disk reads over all child cursors
SORTS NUMBER
Sum of the number of sorts that were done for all the child cursors
EXECUTIONS NUMBER
Total number of executions, totalled over all the child cursors
分析性能差的sql
查询共享池中已经解析过的SQL语句及其相关信息
--EXECUTIONS 所有子游标的执行这条语句次数
--DISK_READS 所有子游标运行这条语句导致的读磁盘次数
--BUFFER_GETS 所有子游标运行这条语句导致的读内存次数
--Hit_radio 命中率
--Reads_per_run 每次执行读写磁盘数
笼统的说EXECUTIONS,BUFFER_GETS,Hit_radio越高表示读内存多,磁盘少是比较理想的状态,因此越高越好
另外两个越高读磁盘次数越多,因此低点好
选出最占用资源的查询
本视图持续跟踪所有shared pool中的共享cursor,在shared pool中的每一条SQL语句都对应一列。本视图在分析SQL语句资源使用方面非常重要。
V$SQLAREA中的信息列
HASH_VALUE:SQL语句的Hash值。
ADDRESS:SQL语句在SGA中的地址。
这两列被用于鉴别SQL语句,有时,两条不同的语句可能hash值相同。这时候,必须连同ADDRESS一同使用来确认SQL语句。
PARSING_USER_ID:为语句解析第一条CURSOR的用户
VERSION_COUNT:语句cursor的数量
KEPT_VERSIONS:
SHARABLE_MEMORY:cursor使用的共享内存总数
PERSISTENT_MEMORY:cursor使用的常驻内存总数
RUNTIME_MEMORY:cursor使用的运行时内存总数。
SQL_TEXT:SQL语句的文本(最大只能保存该语句的前1000个字符)。
MODULE,ACTION:使用了DBMS_APPLICATION_INFO时session解析第一条cursor时的信息
V$SQLAREA中的其它常用列
SORTS: 语句的排序数
CPU_TIME: 语句被解析和执行的CPU时间
ELAPSED_TIME: 语句被解析和执行的共用时间
PARSE_CALLS: 语句的解析调用(软、硬)次数
EXECUTIONS: 语句的执行次数
INVALIDATIONS: 语句的cursor失效次数
LOADS: 语句载入(载出)数量
ROWS_PROCESSED: 语句返回的列总数
V$SQLAREA中的连接列Column View Joined Column(s)
HASH_VALUE, ADDRESS V$SESSION SQL_HASH_VALUE, SQL_ADDRESS
HASH_VALUE, ADDRESS V$SQLTEXT, V$SQL, V$OPEN_CURSOR HASH_VALUE, ADDRESS
SQL_TEXT V$DB_OBJECT_CACHE NAME
示例:
1.查看消耗资源最多的SQL:
Sql代码
- SELECT
hash_value, executions, buffer_gets, disk_reads, parse_calls - FROM
V$SQLAREA - WHERE
buffer_gets OR> 10000000 disk_reads > 1000000 - ORDER
BY buffer_gets DESC;+ 100 * disk_reads
2.查看某条SQL语句的资源消耗:
Sql代码
- SELECT
hash_value, buffer_gets, disk_reads, executions, parse_calls - FROM
V$SQLAREA - WHERE
hash_Value AND= 228801498 address 'CBD8E4B0');= hextoraw(
查找前10条性能差的sql语句
Sql代码
- SELECT
* FROM( selectPARSING_USER_ID,EXECUTIONS,SORTS,COMMAND_TYPE,DISK_READS,sql_text FROMv$sqlarea - order
BY disk_reads DESC) whereROWNUM<10 ;
EXECUTIONS表示同一条SQL语句一共执行了多少次,SORTS表示排序的次数,DISK_READS表示物理读的数量。
DISK_READS NUMBER
The sum of the number of disk reads over all child cursors
SORTS NUMBER
Sum of the number of sorts that were done for all the child cursors
EXECUTIONS NUMBER
Total number of executions, totalled over all the child cursors
分析性能差的sql
Sql代码
- SELECT
EXECUTIONS , DISK_READS, BUFFER_GETS, - ROUND((BUFFER_GETS-DISK_READS)/BUFFER_GETS,2)
Hit_radio, - ROUND(DISK_READS/EXECUTIONS,2)
Reads_per_run, - SQL_TEXT
- FROM
V$SQLAREA - WHERE
EXECUTIONS>0 - AND
BUFFER_GETS >0 - AND
(BUFFER_GETS-DISK_READS)/BUFFER_GETS < 0.8
--EXECUTIONS 所有子游标的执行这条语句次数
--DISK_READS 所有子游标运行这条语句导致的读磁盘次数
--BUFFER_GETS 所有子游标运行这条语句导致的读内存次数
--Hit_radio 命中率
--Reads_per_run 每次执行读写磁盘数
笼统的说EXECUTIONS,BUFFER_GETS,Hit_radio越高表示读内存多,磁盘少是比较理想的状态,因此越高越好
另外两个越高读磁盘次数越多,因此低点好
选出最占用资源的查询
Sql代码
- select
b.username exec,username,a.disk_reads reads,a.executions -
a.disk_reads/decode(a.executions,0,1,a.executions) rds_exec_ratio, -
a.sql_text statement -
v$sqlarea a,dba_users b -
a.parsing_user_id=b.user_id -
a.disk_reads>100000
本视图包括Shared pool中SQL语句的完整文本,一条SQL语句可能分成多个块被保存于多个记录内。
0 0
- 转通过v$sqlarea,v$sql查询最占用资源的查询
- 通过v$sqlarea,v$sql查询最占用资源的查询
- 通过v$sqlarea,v$sql查询最占用资源的查询
- 通过v$sqlarea,v$sql查询最占用资源的查询
- 通过v$sqlarea,v$sql查询最占用资源的查询
- 通过v$sqlarea,v$sql查询最占用资源的查询 ORACLE性能
- 通过v$sqlarea,v$sql查询最占用资源的查询
- 根据SQL_ID在V$SQLAREA,V$SQL里查询不到数解决方法
- v$sqlarea,v$sql,v$sqltext的区别和联系
- v$sqlarea,v$sql,v$sqltext的区别
- v$sql,v$sqlarea,v$sqltext的区别
- V$SQLTEXT,V$SQL,V$SQLAREA的区别
- 视图 v$sql,v$sqlarea,$sqltext,v$sqltext_with_newlines 的差异
- Oracle的v$sql,v$sqlarea,v$sqltext
- v$sqlarea,v$sql,v$sqltext的区别
- v$sql和v$sqlarea
- [转]v$sqlarea,v$sql,v$sqltext提供的sql语句区别?
- v$sql,v$sqlarea,v$sqltext区别
- [PYTHON]
- Yii2学习笔记(八):文件上传Upload
- 第一个任务
- mac常用操作
- 指针学习总结
- 转通过v$sqlarea,v$sql查询最占用资源的查询
- Eclipse离线安装ADt
- spring学习笔记
- 帮助命令
- 关于冯诺依曼和哈佛结构的几点理解
- c语言程序内存模型
- Android系统的定制
- Mysql InnoDB行锁实现方式
- Android项目Tab类型主界面大总结 Fragment+TabPageIndicator+ViewPager