Oralce数据库巡检SQL脚本

:2024年11月13日 超哥的IT私房菜
分享到:

Oracle数据库巡检SQL脚本检查表空间使用情况、索引、约束、日志、实例状态、表空间状态、数据文件状态等。性能最差的前10条SQL语句和一些扩展异常的对象需要特别关注。

Oralce数据库巡检SQL脚本

1 检查表空间使用情况

2 检查是否有 offline 状态的表空间

3 在线日志是否存在小于 50M 的及状态不正常

4 检查锁阻塞

5 查看是否有僵死进程

6 检查是否有失效索引

7 检查不起作用的约束

8 缓冲区命中率

9 数据字典命中率

10 库缓存命中率

11 内存中的排序

12 磁盘中的排序

13 临时空间使用率

14 检查ORACLE实例状态

15 检查ORACLE表空间的状态

16 检查ORACLE所有数据文件状态

17 检查所有回滚段状态

18 检查一些扩展异常的对象

19 DISK READ最高的SQL语句的获取

20 性能最差的前10条SQL

21 检查运行很久的SQL

22 检查碎片程度高的表

23 检查死锁及处理

24 失效的触发器

25 失败的JOB

Oralce数据库巡检SQL脚本

1 检查表空间使用情况

SELECT B.TABLESPACE_NAME      TABLESPACE,

   A.EXTENT_MANAGEMENT    EXT_MGT,

   A.SEGMENT_SPACE_MANAGEMENT SEG_MGT,

   A.STATUS,

   A.LOGGING,

   B.TOTAL,

   B.FREE,

   B.USED_PCT

 FROM DBA_TABLESPACES A,

    (SELECT D.TABLESPACE_NAME TABLESPACE_NAME,

       ROUND((D.SUMBYTES / 1024 / 1024 / 1024), 2) || 'GB' TOTAL,

       ROUND(DECODE(F.SUMBYTES, NULL, 0, F.SUMBYTES) / 1024 / 1024 / 1024,

           2) || 'GB' FREE,

       ROUND((D.SUMBYTES - DECODE(F.SUMBYTES, NULL, 0, F.SUMBYTES)) * 100 /

          D.SUMBYTES,

           2) || '%' USED_PCT

     FROM (SELECT TABLESPACE_NAME, SUM(BYTES) SUMBYTES

         FROM DBA_FREE_SPACE

         GROUP BY TABLESPACE_NAME) F,

        (SELECT TABLESPACE_NAME,    

            SUM(BYTES) SUMBYTES

         FROM DBA_DATA_FILES

         GROUP BY TABLESPACE_NAME) D

     WHERE F.TABLESPACE_NAME(+) = D.TABLESPACE_NAME

     ORDER BY D.TABLESPACE_NAME) B

WHERE A.TABLESPACE_NAME = B.TABLESPACE_NAME;

2 检查是否有 offline 状态的表空间

SELECT FILE_ID AS ID,

   RELATIVE_FNO "FNO",

   ROUND(BYTES / 1024 / 1024) AS MBYTES,

   ROUND(MAXBYTES / 1024 / 1024) MAXMBYTES,

   BLOCKS,

   MAXBLOCKS,

   AUTOEXTENSIBLE "AUTO",

   INCREMENT_BY "INC",

   ROUND(USER_BYTES / 1024 / 1024) "NOW_MB",

   USER_BLOCKS,

    STATUS,

   ONLINE_STATUS "ONLINE_S"

 FROM DBA_DATA_FILES;

3 在线日志是否存在小于 50M 的及状态不正常

SELECT A.GROUP#, A.STATUS, A.BYTES, B.MEMBER, A.ARCHIVED

 FROM V$LOG A, V$LOGFILE B

WHERE A.GROUP# = B.GROUP#;

4 检查锁阻塞

SELECT DECODE(REQUEST, 0, '阻塞者:', '等待者:') || SID SID,

   ID1,

   ID2,

   LMODE,

   REQUEST,

   TYPE

 FROM V$LOCK

WHERE (ID1, ID2, TYPE) IN

    (SELECT ID1, ID2, TYPE FROM V$LOCK WHERE REQUEST > 0)

ORDER BY ID1, REQUEST;

5 查看是否有僵死进程

SELECT SPID FROM V$PROCESS WHERE ADDR NOT IN (SELECT PADDR FROMV$SESSION);

6 检查是否有失效索引

SELECT OWNER, A.INDEX_NAME, A.INDEX_TYPE, A.STATUS

 FROM DBA_INDEXES A

WHERE STATUS = 'UNUSABLE';

SELECT A.INDEX_NAME, A.PARTITION_NAME, A.TABLESPACE_NAME, A.STATUS

 FROM DBA_IND_PARTITIONS A

WHERE STATUS = 'UNUSABLE';

7 检查不起作用的约束

SELECT OWNER, CONSTRAINT_NAME, TABLE_NAME, CONSTRAINT_TYPE, STATUS

 FROM DBA_CONSTRAINTS

WHERE STATUS = 'DISABLE'

  AND CONSTRAINT_TYPE = 'P';

8 缓冲区命中率

缓冲命中率应大于90%。

SELECT (1 - (SUM(DECODE(NAME, 'PHYSICAL READS', VALUE, 0)) /

    (SUM(DECODE(NAME, 'DB BLOCK GETS', VALUE, 0)) +

    SUM(DECODE(NAME, 'CONSISTENT GETS', VALUE, 0))))) * 100 "HIT RATIO"

 FROM V$SYSSTAT;

9 数据字典命中率

数据字典命中率应大于 95%。

SELECT (1 - (SUM(GETMISSES) / SUM(GETS))) * 100 "HIT RATIO" FROM V$ROWCACHE;

10 库缓存命中率

库缓存命中率应大于 95%。

SELECT SUM(PINS) / (SUM(PINS) + SUM(RELOADS)) * 100 "HIT RATIO" FROMV$LIBRARYCACHE;

11 内存中的排序

如果存在大量的磁盘排序,则表明检查目前系统中消耗大量磁盘的 SQL 是否已经经过调整。

SELECT NAME, VALUE FROM V$SYSSTAT WHERE NAME LIKE '%SORTS%';

12 磁盘中的排序

检查使用磁盘排序的会话信息,可以定位执行了大量磁盘排序的会话。

SELECT B.NAME, A.SID, A.VALUE

 FROM V$SESSTAT A, V$STATNAME B

WHERE A.STATISTIC# = B.STATISTIC#

  AND B.NAME = 'SORTS (DISK)'

  AND A.VALUE > 0

  AND ROWNUM < 10

ORDER BY A.VALUE DESC;

13 临时空间使用率

SELECT * FROM V$TEMP_SPACE_HEADER;

14 检查ORACLE实例状态

其中“STATUS”表示ORACLE当前的实例状态,必须为“OPEN”;“DATABASE_STATUS”表示ORACLE当前数据库的状态,必须为“ACTIVE”。

SELECT INSTANCE_NAME, HOST_NAME, STARTUP_TIME, STATUS, DATABASE_STATUS FROM V$INSTANCE;

15 检查ORACLE表空间的状态

输出结果中STATUS应该都为ONLINE。

SELECT TABLESPACE_NAME, STATUS FROM DBA_TABLESPACES;

16 检查ORACLE所有数据文件状态

输出结果中“STATUS”应该都为“ONLINE”。

SELECT NAME, STATUS FROM V$DATAFILE;

输出结果中“STATUS”应该都为“AVAILABLE”。

SELECT FILE_NAME, STATUS FROM DBA_DATA_FILES;

17 检查所有回滚段状态

输出结果中所有回滚段的“STATUS”应该为“ONLINE”。

SELECT SEGMENT_NAME, STATUS FROM DBA_ROLLBACK_SEGS;

18 检查一些扩展异常的对象

如果有记录返回,则这些对象的扩展已经快达到它定义时的最大扩展值,对于这些对象要修改它的存储结构参数。

SELECT SEGMENT_NAME,

   SEGMENT_TYPE,

   TABLESPACE_NAME,

    (EXTENTS / MAX_EXTENTS) * 100 PERCENT

 FROM SYS.DBA_SEGMENTS

WHERE MAX_EXTENTS != 0

  AND (EXTENTS / MAX_EXTENTS) * 100 >= 95

ORDER BY PERCENT;

19 DISK READ最高的SQL语句的获取

SELECT SQL_TEXT

 FROM (SELECT * FROM V$SQLAREA ORDER BY DISK_READS)

WHERE ROWNUM <= 5;

20 性能最差的前10条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;

21 检查运行很久的SQL

SELECT USERNAME,

   SID,

   OPNAME,

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

   TIME_REMAINING,

   SQL_TEXT

 FROM V$SESSION_LONGOPS, V$SQL

WHERE TIME_REMAINING <> 0

  AND SQL_ADDRESS = ADDRESS

  AND SQL_HASH_VALUE = HASH_VALUE;

22 检查碎片程度高的表

SELECT SEGMENT_NAME TABLE_NAME, COUNT(*) EXTENTS

 FROM DBA_SEGMENTS

WHERE OWNER NOT IN ('SYS', 'SYSTEM')

GROUP BY SEGMENT_NAME

HAVING COUNT(*) = (SELECT MAX(COUNT(*))

           FROM DBA_SEGMENTS

          GROUP BY SEGMENT_NAME);

23 检查死锁及处理

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;

24 失效的触发器

SELECT OWNER, TRIGGER_NAME, TABLE_NAME, STATUS

 FROM DBA_TRIGGERS

WHERE STATUS = 'DISABLED';

25 失败的JOB

SELECT JOB, WHAT, LAST_DATE, NEXT_DATE, FAILURES, BROKEN

 FROM DBA_JOBS

WHERE SCHEMA_USER = 'USER';

点赞,你的认可是我创作的动力!
收藏,你的青睐是我努力的方向!
评论,你的意见是我进步的财富!

PS:因为公众号平台更改了推送规则,如果不想错过内容,记得读完点一下“在看”,加个“星标”,这样每次新文章推送才会第一时间出现在你的订阅列表里。点“在看”支持我吧!

原文来源:https://mp.weixin.qq.com/s/Fdtc7hZx9yJbj2WZvLuOAQ

[我要纠错]
文:宋聪乔&发表于江苏
关键词: Oralce 数据库 巡检 脚本 检查表

来源:本文内容搜集或转自各大网络平台,并已注明来源、出处,如果转载侵犯您的版权或非授权发布,请联系小编,我们会及时审核处理。
声明:江苏教育黄页对文中观点保持中立,对所包含内容的准确性、可靠性或者完整性不提供任何明示或暗示的保证,不对文章观点负责,仅作分享之用,文章版权及插图属于原作者。

点个赞
0
踩一脚
0

您在阅读:Oralce数据库巡检SQL脚本

Copyright©2013-2024 JSedu114 All Rights Reserved. 江苏教育信息综合发布查询平台保留所有权利

苏公网安备32010402000125 苏ICP备14051488号-3技术支持:南京博盛蓝睿网络科技有限公司

南京思必达教育科技有限公司版权所有   百度统计

最热文章
最新文章
  • 卡尔蔡司镜片优惠店,镜片价格低
  • 苹果原装手机壳