【转】查询oracle比较慢的session和sql
-查询最慢的sql
select * from (
select parsing_user_id,executions,sorts
command_type,disk_reads,sql_text from v$sqlarea order by disk_reads desc
)where rownum<10
--查询对应session
select SE.SID,SE.SERIAL#,PR.SPID,
SE.USERNAME,SE.STATUS,SE.TERMINAL,
SE.PROGRAM,SE.MODULE,
SE.SQL_ADDRESS,ST.EVENT,
ST.P1TEXT,SI.PHYSICAL_READS,SI.BLOCK_CHANGES from v$session se,v$session_wait
st,
v$sess_io si,v$process pr
where st.SID=se.SID and st.SID=si.SID
AND SE.PADDR=PR.ADDR
AND SE.SID>6
AND ST.WAIT_TIME=0
AND ST.EVENT NOT LIKE '%SQL%'
ORDER BY PHYSICAL_READS DESC;
SELECT sql_address FROM V$SESSION SS,V$SQLTEXT TT
WHERE SS.SQL_HASH_VALUE=TT.HASH_VALUE AND SID=439;
v$sqltext:存储的是完整的SQL,SQL被分割
v$sqlarea:存储的SQL 和一些相关的信息,比如累计的执行次数,逻辑读,物理读等统计信息(统计)
v$sql:内存共享SQL区域中已经解析的SQL语句。(即时)
根据sid查找完整sql语句:
select sql_text from v$sqltext a where
a.hash_value = (select sql_hash_value from v$session b where b.sid =
'&sid' )
order by piece asc
select a.CPU_TIME,--CPU时间 百万分之一(微秒)
a.OPTIMIZER_MODE,--优化方式
a.EXECUTIONS,--执行次数
a.DISK_READS,--读盘次数
a.SHARABLE_MEM,--占用shared pool的内存多少
a.BUFFER_GETS,--读取缓冲区的次数
a.COMMAND_TYPE,--命令类型(3:select,2:insert;6:update;7delete;47:pl/sql程序单元)
a.SQL_TEXT,--Sql语句
a.SHARABLE_MEM,
a.PERSISTENT_MEM,
a.RUNTIME_MEM,
a.PARSE_CALLS,
a.DISK_READS,
a.DIRECT_WRITES,
a.CONCURRENCY_WAIT_TIME,
a.USER_IO_WAIT_TIME
from SYS.V_$SQLAREA a
WHERE PARSING_SCHEMA_NAME = 'CHEA_FILL'--表空间
order by a.CPU_TIME desc
引用:http://jenniferok.iteye.com/blog/700985
从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
from v$sqlarea a,dba_users b
where a.parsing_user_id=b.user_id
and a.disk_reads > 100000
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;
消耗磁盘读取最多的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 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;
v$sqlarea字段定义:http://happyhou.blog.sohu.com/60494432.html
|
SQL_TEXT |
VARCHAR2(1000) |
First thousand characters of the SQL text for the |
|
SQL_ID |
VARCHAR2(13) |
SQL identifier of the parent cursor in the library |
|
SHARABLE_MEM |
NUMBER |
Amount of shared memory used by a cursor. If multiple |
|
PERSISTENT_MEM |
NUMBER |
Fixed amount of memory used for the lifetime of an open |
|
RUNTIME_MEM |
NUMBER |
Fixed amount of memory required during execution of a |
|
SORTS |
NUMBER |
Sum of the number of sorts that were done for all the |
|
VERSION_COUNT |
NUMBER |
Number of child cursors that are present in the cache |
|
LOADED_VERSIONS |
NUMBER |
Number of child cursors that are present in the cache |
|
OPEN_VERSIONS |
NUMBER |
The number of child cursors that are currently open |
|
USERS_OPENING |
NUMBER |
Number of users that have any of the child cursors open |
|
FETCHES |
NUMBER |
Number of fetches associated with the SQL statement |
|
EXECUTIONS |
NUMBER |
Total number of executions, totalled over all the child |
|
END_OF_FETCH_COUNT |
NUMBER |
Number of times this cursor was fully executed since the |
|
USERS_EXECUTING |
NUMBER |
Total number of users executing the statement over all |
|
LOADS |
NUMBER |
Number of times the object was loaded or reloaded |
|
FIRST_LOAD_TIME |
VARCHAR2(19) |
Timestamp of the parent creation time |
|
INVALIDATIONS |
NUMBER |
Total number of invalidations over all the child |
|
PARSE_CALLS |
NUMBER |
Sum of all parse calls to all the child cursors under |
|
DISK_READS |
NUMBER |
Sum of the number of disk reads over all child cursors |
|
DIRECT_WRITES |
NUMBER |
Sum of the number of direct writes over all child |
|
BUFFER_GETS |
NUMBER |
Sum of buffer gets over all child cursors |
|
APPLICATION_WAIT_TIME |
NUMBER |
Application wait time |
|
CONCURRENCY_WAIT_TIME |
NUMBER |
Concurrency wait time |
|
CLUSTER_WAIT_TIME |
NUMBER |
Cluster wait time |
|
USER_IO_WAIT_TIME |
NUMBER |
User I/O Wait Time |
|
PLSQL_EXEC_TIME |
NUMBER |
PL/SQL execution time |
|
JAVA_EXEC_TIME |
NUMBER |
Java execution time |
|
ROWS_PROCESSED |
NUMBER |
Total number of rows processed on behalf of this SQL |
|
COMMAND_TYPE |
NUMBER |
Oracle command type definition |
|
OPTIMIZER_MODE |
VARCHAR2(25) |
Mode under which the SQL statement was executed |
|
PARSING_USER_ID |
NUMBER |
User ID of the user that has parsed the very first |
|
PARSING_SCHEMA_ID |
NUMBER |
Schema ID that was used to parse this child cursor |
|
KEPT_VERSIONS |
NUMBER |
Number of child cursors that have been marked to be |
|
ADDRESS |
RAW(4 | 8) |
Address of the handle to the parent for this cursor |
|
HASH_VALUE |
NUMBER |
Hash value of the parent statement in the library cache |
|
OLD_HASH_VALUE |
NUMBER |
Old SQL hash value |
|
MODULE |
VARCHAR2(64) |
Contains the name of the module that was executing at |
|
MODULE_HASH |
NUMBER |
Hash value of the module that is named in the MODULEcolumn |
|
ACTION |
VARCHAR2(64) |
Contains the name of the action that was executing at |
|
ACTION_HASH |
NUMBER |
Hash value of the action that is named in the ACTIONcolumn |
|
SERIALIZABLE_ABORTS |
NUMBER |
Number of times the transaction fails to serialize, |
|
CPU_TIME |
NUMBER |
CPU time (in microseconds) used by this cursor for |
|
ELAPSED_TIME |
NUMBER |
Elapsed time (in microseconds) used by this cursor for |
|
IS_OBSOLETE |
VARCHAR2(1) |
Indicates whether the cursor has become obsolete (Y ) or not (N ). This can happen if the number |
|
CHILD_LATCH |
NUMBER |
Child latch number that is protecting the cursor |
|
PROGRAM_ID |
NUMBER |
Program identifie |
原文地址:http://blog.csdn.net/sxhong/article/details/18262663
【转】查询oracle比较慢的session和sql的更多相关文章
- 查询oracle比较慢的session和sql
注:本文来源:sxhong <查询oracle比较慢的session和sql> ---查询最慢的sql select * from ( select parsing_user_id,e ...
- 性能优化-查询最耗CPU的SESSION与SQL
在linux 系统中 用top命令查出CPU最高的SPID,再将SPID给存储过程,可以查出该进程的SQLTEXT create or replace procedure pro_get_sqltex ...
- 使用PLSQL Developer和DbVisualizer、SQLDBx查询oracle数据库时出现乱码
使用PLSQL Developer和DbVisualizer查询oracle数据库时,出现查询数据中文乱码情况. 查看了一下数据库编码格式select * from v$nls_parameters; ...
- oracle的会话(session)
会话(session)是oracle服务器对数据库连接用户记录的一种手段. oracle提供了v_$session的视图存储当前数据库的会话,查询时用v_$session 或v$session sql ...
- 查询Oracle正在执行的sql语句
--查询Oracle正在执行的sql语句及执行该语句的用户 SELECT b.sid oracleID, b.username 登录Oracle用户名, b.serial#, spid 操作系统ID, ...
- 如何查询Oracle性能监控
1.监控等待事件select event,sum(decode(wait_time,0,0,1)) prev, sum(decode(wait_time,0,1,0)) curr,count(*)fr ...
- oracle系统表v$session、v$sql字段说明
在本视图中,每一个连接到数据库实例中的 session都拥有一条记录.包括用户 session及后台进程如 DBWR, LGWR, arcchiver等等. V$SESSION中的常用列 V$SESS ...
- 查询Oracle正在执行的sql语句及kill被锁的表
查询Oracle正在执行的sql语句及执行该语句的用户SELECT b.sid oracleID, b.username 登录Oracle用户名, b.serial#, spid 操作系统ID, pa ...
- 查询oracle中所有用户信息 禁用用户
----查询oracle中所有用户信息 ----1.查询数据库中的表空间名称 ----1)查询所有表空间 select tablespace_name from dba_tablespaces; se ...
随机推荐
- [NOIP2016]愤怒的小鸟
题目描述 Kiana最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于(0,0)处,每次Kiana可以用它向第一象限发射一只红色的小鸟,小鸟们的飞行轨迹均为形 ...
- HTML5 Canvas 绘图
首先要注意: <canvas> 元素不被一些老的浏览器所支持, 但被支持于Firefox 1.5+, Opera 9+, 新版本的Safari, Chrome, 以及Internet Ex ...
- GridLayout 使用
上次做了一个小键盘,请见:PopupWindow 使用. 效果是这样的: 可以看到,上面的按键是不一样大小的.因为是用LinearLayout布局,用的Button样式也是默认的.数字键和文字键的大小 ...
- bzoj4398:福慧双修
学习了一下最短路的姿势,这个建图方法好妙啊,虽然不会证明正确性…… #include <bits/stdc++.h> #define N 220000 #define INF 100000 ...
- 1.44tft
https://item.taobao.com/item.htm?spm=a230r.1.14.107.pBOVu5&id=16660981098&ns=1&abbucket= ...
- ArrayList和HashSet的Contains()方法(转)
来源: ArrayList和HashSet的Contains()方法 笔试题: package com.champion.test.exam; import java.util.ArrayList; ...
- sublime text3 常用插件安装
1.Package Control 按Ctrl+~调出console(或者view>show console) 粘贴以下代码到底部命令行并回车: import urllib.request,os ...
- Robot Framework用户手册 (版本:3.0)
版权信息:诺基亚网络和解决中心 本翻译尊重原协议,仅用于个人学习使用 1.开始: 1.1 介绍: Robot Framework是一个基于Python的,为终端测试和验收驱动开发(ATDD)的可扩展的 ...
- leveldb 性能、使用场景评估
最近有个业务写远远大于读,读也集中在最近写入,这不很适合采用leveldb存储么,leveldb业界貌似ssdb用得挺广,花了两天时间就ssdb简单做下测试,以下总结. ssdb 是leveldb的r ...
- [MySQL]索引类型总结和使用技巧以及注意事项
一.普通索引 这是最基本的索引,它没有任何限制.它有以下几种创建方式: 1.创建索引 CREATE INDEX [indexName] ON [mytable] ([column][(length)] ...