Oracle查看锁表情况(oracle查看锁表的sql)

Oracle查看锁表情况(oracle查看锁表的sql)p style margin left 0 在本节主要检查 Oracle 数据库性能情况 包含 检查数据库的等待事件 检查死锁及处理 检查 cpu I O 内存性能 查看是否有僵死进程 检查行链接 迁移 p

大家好,我是讯享网,很高兴认识大家。



 <p style="margin-left:0;">在本节主要检查Oracle数据库性能情况&#xff0c;包含&#xff1a;检查数据库的等待事件&#xff0c;检查死锁及处理&#xff0c;检查cpu、I/O、内存性能&#xff0c;查看是否有僵死进程&#xff0c;检查行链接/迁移&#xff0c;定期做统计分析&#xff0c;检查缓冲区命中率&#xff0c;检查共享池命中率&#xff0c;检查排序区&#xff0c;检查日志缓冲区&#xff0c;总共十个部分。</p> 

讯享网

4.1. 检查数据库的等待事件

set pages 80

set lines 120

col event for a40

select sid, event, p1, p2, p3, WAIT_TIME, SECONDS_IN_WAIT

  from v\(session_wait</p> <p style="margin-left:0;"> where event not like &#39;SQL%&#39;</p> <p style="margin-left:0;">   and event not like &#39;rdbms%&#39;;</p> <p style="margin-left:0;"></p> <p style="margin-left:0;">如果数据库长时间持续出现大量像latch free&#xff0c;enqueue&#xff0c;buffer busy waits&#xff0c;db file sequential read&#xff0c;db file scattered read等等待事件时&#xff0c;需要对其进行分析&#xff0c;可能存在问题的语句。</p> <p style="margin-left:0;"></p> <p style="margin-left:0;">4.2. Disk Read最高的SQL语句的获取</p> <p style="margin-left:0;">SELECT SQL_TEXT</p> <p style="margin-left:0;">FROM (SELECT * FROM V\)SQLAREA ORDER BY DISK_READS)

WHERE ROWNUM &lt;= 5;

4.3. 查找前十条性能差的sql

SELECT *

FROM (SELECT PARSING_USER_ID

EXECUTIONS,

SORTS,

COMMAND_TYPE,

DISK_READS,

SQL_TEXT

FROM V\(SQLAREA</p> <p style="margin-left:0;">ORDER BY DISK_READS DESC)</p> <p style="margin-left:0;">WHERE ROWNUM &lt; 10;</p> <p style="margin-left:0;"></p> <p style="margin-left:0;"></p> <p style="margin-left:0;">4.4. 等待时间最多的5个系统等待事件的获取</p> <p style="margin-left:0;"></p> <p style="margin-left:0;">SELECT *</p> <p style="margin-left:0;">  FROM (SELECT *</p> <p style="margin-left:0;">          FROM V\)SYSTEM_EVENT

         WHERE EVENT NOT LIKE ‘SQL%’

         ORDER BY TOTAL_WAITS DESC)

 WHERE ROWNUM &lt;= 5;

4.5. 检查运行很久的SQL

COLUMN USERNAME FORMAT A12

COLUMN OPNAME FORMAT A16

COLUMN PROGRESS FORMAT A8

SELECT USERNAME,

       SID,

       OPNAME,

       ROUND(SOFAR * 100 / TOTALWORK, 0) || ‘%’ AS PROGRESS,

       TIME_REMAINING,

       SQL_TEXT

  FROM V\(SESSION_LONGOPS, V\)SQL

 WHERE TIME_REMAINING &lt;&gt; 0

   AND SQL_ADDRESS = ADDRESS

   AND SQL_HASH_VALUE = HASHVALUE;

4.6. 检查消耗CPU最高的进程

SET LINE 240

SET VERIFY OFF

COLUMN SID FORMAT 999

COLUMN PID FORMAT 999

COLUMN S# FORMAT 999

COLUMN USERNAME FORMAT A9 HEADING “ORA USER”

COLUMN PROGRAM FORMAT A29

COLUMN SQL FORMAT A60


讯享网

COLUMN OSNAME FORMAT A9 HEADING “OS USER”

SELECT P.PID PID,

       S.SID SID,

       P.SPID SPID,

       S.USERNAME USERNAME,

       S.OSUSER OSNAME,

       P.SERIAL# S_#,

       P.TERMINAL,

       P.PROGRAM PROGRAM,

       P.BACKGROUND,

       S.STATUS,

       RTRIM(SUBSTR(A.SQL_TEXT, 1, 80)) SQLFROM V\(PROCESS P,</p> <p style="margin-left:0;">       V\)SESSION S,

       V\(SQLAREA A WHERE P.ADDR &#61; S.PADDR AND S.SQL_ADDRESS &#61; A.ADDRESS(&#43;) AND P.SPID LIKE &#39;%&amp;1%&#39;;</p> <p style="margin-left:0;"></p> <p style="margin-left:0;"></p> <p style="margin-left:0;">4.7. 检查碎片程度高的表</p> <p style="margin-left:0;"></p> <p style="margin-left:0;">SELECT segment_name table_name, COUNT(*) extents</p> <p style="margin-left:0;">  FROM dba_segments</p> <p style="margin-left:0;"> WHERE owner NOT IN (&#39;SYS&#39;, &#39;SYSTEM&#39;)</p> <p style="margin-left:0;"> GROUP BY segment_name</p> <p style="margin-left:0;">HAVING COUNT(*) &#61; (SELECT MAX(COUNT(*))</p> <p style="margin-left:0;">                     FROM dba_segments</p> <p style="margin-left:0;">                    GROUP BY segment_name);</p> <p style="margin-left:0;"></p> <p style="margin-left:0;"></p> <p style="margin-left:0;">4.8. 检查表空间的I/O比例</p> <p style="margin-left:0;"></p> <p style="margin-left:0;">SELECT DF.TABLESPACE_NAME NAME,</p> <p style="margin-left:0;">       DF.FILE_NAME       &#34;FILE&#34;,</p> <p style="margin-left:0;">       F.PHYRDS           PYR,</p> <p style="margin-left:0;">       F.PHYBLKRD         PBR,</p> <p style="margin-left:0;">       F.PHYWRTS          PYW,</p> <p style="margin-left:0;">       F.PHYBLKWRT        PBW</p> <p style="margin-left:0;">  FROM V\)FILESTAT F, DBA_DATA_FILES DF

 WHERE F.FILE# = DF.FILE_ID

 ORDER BY DF.TABLESPACE_NAME; 

4.9. 检查文件系统的I/O比例

SELECT SUBSTR(A.FILE#, 1, 2) “#”,

       SUBSTR(A.NAME, 1, 30) “NAME”,

       A.STATUS,

       A.BYTES,

       B.PHYRDS,

       B.PHYWRTS

  FROM V\(DATAFILE A, V\)FILESTAT B

 WHERE A.FILE# = B.FILE#; 

4.10.检查死锁及处理

查询目前锁对象信息:

select sid,

       serial#,

       username,

       SCHEMANAME,

       osuser,

       MACHINE,    

       terminal,

       PROGRAM,

       owner,

       object_name,

       object_type,

       o.object_id

  from dba_objects o, v\(locked_object l, v\)session s

 where o.object_id = l.object_id

   and s.sid = l.session_id; 

oracle级kill掉该session:

alter system kill session ‘&sid,&serial#’;

操作系统级kill掉session:

#&gt;kill -9 pid

小讯
上一篇 2025-04-30 19:07
下一篇 2025-05-07 11:17

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/182457.html