【转】查询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 ...
随机推荐
- eclipse安装spring的插件
第一步:插件下载 http://spring.io/tools/sts/all 安装包链接 第二步:插件安装 第三步:安装成功检测
- Servlet和CGI的区别
Servlet被服务器实例化后,容器运行其init方法,请求到达时运行其service方法,service方法自动派遣运行与请求对应的doXXX方法(doGet,doPost)等,当服务器决定将实例销 ...
- 盘点8种CSS实现垂直居中水平居中的绝对定位居中技术
Ⅰ.绝对定位居中(Absolute Centering)技术 我们经常用margin:0 auto来实现水平居中,而一直认为margin:auto不能实现垂直居中--实际上,实现垂直居中仅需要声明元素 ...
- python爬虫小项目实战
- 安装和卸载windows服务 bat
1. 安装 windows服务 C:\Windows\Microsoft.NET\Framework64\v4.0.30319\installutil [服务路径](例:C:\\test\myt ...
- final和包装类
==================================================================================================== ...
- python基础八
面向对象的好处 更容易扩展.提高代码使用效率,使你的代码组织性更强, 更清晰,更适合复杂项目的开发 封装 把功能的实现细节封装起来,只暴露调用接口 继承 多态 接口的继承 定义 类 ===> ...
- Linux下查看磁盘与目录的容量——df、du
df:列出文件系统的整体磁盘使用量: du:评估文件系统的磁盘使用量(常用于评估目录所占容量) df参数: -a:列出所有的文件系统,包括系统特有的/proc等文件系统 -k:以KB的容量显示各文件系 ...
- appium for hybrid app 处理webview
之前研究了一段时间的appium for native app 相应的总结如下: appium测试环境搭建 :ht ...
- android adb 命令详解
ADB (Android Debug Bridge) 是android SDK中的工具,需要先配置环境变量才能使用.起调试桥的作用,可以管理安卓设备.(也叫debug工具) ---------查看设 ...