Oracle常用的诊断语句

--1.数据池命中率
--db_pool命中率(要求:95%左右):
select 100 -
       100 * ((select value from v$sysstat where name = ‘physical reads‘)) /
       ((select value from v$sysstat where name = ‘consistent gets‘) +
       (select value from v$sysstat where name = ‘db block gets‘))
  from dual;

select *
  from V$PARAMETER
 where name in (‘sga_max_size‘,
                ‘db_cache_size‘,
                ‘shared_pool_size‘,
                ‘pga_aggregate_target‘);

--2.查找前十条性能差的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;

SELECT sql_text, hash_value, executions, buffer_gets, disk_reads, parse_calls
 FROM V$SQLAREA
WHERE buffer_gets > 10000000 OR disk_reads > 1000000
ORDER BY buffer_gets + 100 * disk_reads DESC; 

--3.根据unix上Top命令看到的PID,查找对应的SQl
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)) SQL
  FROM v$process P, v$session S, v$sqlarea A
 WHERE P.addr = s.paddr
   AND S.sql_address = a.address(+)
   AND P.spid LIKE ‘%CPU最高的进程对应的PID%‘;

--4.察看IO情况:
select
    df.name 文件名,
    fs.phyrds 读次数,
    fs.phywrts 写次数,
    (fs.readtim/decode(fs.phyrds,0,-1,fs.phyrds)) 读时间,
    (fs.writetim/decode(fs.phywrts,0,-1,fs.phywrts)) 写时间
from  v$datafile df,
    v$filestat fs
where df.file#=fs.file#
order by df.name;

--5.表空间察看
SELECT UPPER(F.TABLESPACE_NAME) "表空间名",
       D.TOT_GROOTTE_MB "表空间大小(M)",
       D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空间(M)",
       TO_CHAR(ROUND((D.TOT_GROOTTE_MB - F.TOTAL_BYTES) / D.TOT_GROOTTE_MB * 100, 2), ‘990.99‘) "使用比",
       F.TOTAL_BYTES "空闲空间(M)",
       F.MAX_BYTES "最大块(M)"
FROM (SELECT TABLESPACE_NAME,
        ROUND(SUM(BYTES) / (1024 * 1024), 2) TOTAL_BYTES,
        ROUND(MAX(BYTES) / (1024 * 1024), 2) MAX_BYTES
    FROM SYS.DBA_FREE_SPACE GROUP BY TABLESPACE_NAME) F,
       (SELECT DD.TABLESPACE_NAME,ROUND(SUM(DD.BYTES) / (1024 * 1024), 2) TOT_GROOTTE_MB FROM SYS.DBA_DATA_FILES DD
 GROUP BY DD.TABLESPACE_NAME) D WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME
ORDER BY 4 DESC;

-- 数据表总行数排序
select   t.table_name, t.num_rows, t.*
from     user_tables t
where t.num_rows > 0
order by t.num_rows desc

-- 普通表数据大小排序
select segment_name,  trunc(bytes/1024/1024)
from user_segments
where segment_type = ‘TABLE‘
order by bytes desc;

-- 含LOB类型表的数据大小
SELECT A.TABLE_NAME,
       A.COLUMN_NAME,
       trunc(B.BYTES / 1024 / 1024),
       B.SEGMENT_NAME,
       B.SEGMENT_TYPE,
       B.TABLESPACE_NAME,
       B.BLOCKS,
       B.EXTENTS
  FROM USER_LOBS A, USER_SEGMENTS B
WHERE A.SEGMENT_NAME = B.SEGMENT_NAME
ORDER BY B.BYTES DESC;

-- 数据表总的数据大小占用
select  rowSize + nvl(lobSize, 0) dataSize, t1.*, t2.*
from (
          select segment_name,  trunc(bytes/1024/1024) rowSize
          from user_segments
          where segment_type = ‘TABLE‘
    ) t1 left join (   

          SELECT A.TABLE_NAME,
                 A.COLUMN_NAME,
                 trunc(B.BYTES / 1024 / 1024) lobSize,
                 B.SEGMENT_NAME,
                 B.SEGMENT_TYPE,
                 B.TABLESPACE_NAME,
                 B.BLOCKS,
                 B.EXTENTS
            FROM USER_LOBS A, USER_SEGMENTS B
          WHERE A.SEGMENT_NAME = B.SEGMENT_NAME
    ) t2 on t1.segment_name = t2.table_name
order by rowSize + nvl(lobSize, 0) desc

--6.运行时间很长的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;

--7.锁相关的查询
select ‘kill -9 ‘||PS.SPID,
‘alter system kill session ‘‘‘||vs.sid||‘,‘||vs.serial#||‘‘‘;‘,
/*       DECODE(V$LOCK.TYPE, ‘TM‘, ‘TABLE LOCK‘, ‘TX‘, ‘ROW LOCK‘, NULL) LOCK_LEVEL,*/
       Decode(VL.LOCKED_MODE,0,‘[0] none‘,
                      1,‘[1] null 空‘,
                      2,‘[2] Row-S 行共用(RS):共用表鎖,sub share ‘,
                      3,‘[3] Row-X 行獨佔(RX):用於行的修改,sub exclusive ‘,
                      4,‘[4] Share 共用鎖(S):阻止其他DML操作,share‘,
                      5,‘[5] S/Row-X 共用行獨佔(SRX):阻止其他事務操作,share/sub exclusive ‘,
                      6,‘[6] exclusive 獨佔(X):獨立訪問使用,exclusive ‘,
                      ‘[‘||VL.LOCKED_MODE||‘] Other Lock‘) LockMode,
PS.SPID,OS_USER_NAME,VS.PROGRAM,VS.MACHINE,ORACLE_USERNAME,OBJECT_NAME,vs.LOGON_TIME ,
Vs.status,vs.MODULE
from  V$LOCKED_OBJECT VL ,DBA_OBJECTS OB ,V$SESSION VS ,v$process PS
WHERE VL.OBJECT_ID = OB.OBJECT_ID
AND   VL.SESSION_ID = VS.SID
AND   Ps.ADDR = Vs.PADDR

select ‘kill -9 ‘||PS.SPID,
‘alter system kill session ‘‘‘||vs.sid||‘,‘||vs.serial#||‘‘‘;‘,
/*       DECODE(V$LOCK.TYPE, ‘TM‘, ‘TABLE LOCK‘, ‘TX‘, ‘ROW LOCK‘, NULL) LOCK_LEVEL,*/
       Decode(VL.LOCKED_MODE,0,‘[0] none‘,
                      1,‘[1] null 空‘,
                      2,‘[2] Row-S 行共用(RS):共用表鎖,sub share ‘,
                      3,‘[3] Row-X 行獨佔(RX):用於行的修改,sub exclusive ‘,
                      4,‘[4] Share 共用鎖(S):阻止其他DML操作,share‘,
                      5,‘[5] S/Row-X 共用行獨佔(SRX):阻止其他事務操作,share/sub exclusive ‘,
                      6,‘[6] exclusive 獨佔(X):獨立訪問使用,exclusive ‘,
                      ‘[‘||VL.LOCKED_MODE||‘] Other Lock‘) LockMode,
       PS.SPID,OS_USER_NAME,VS.PROGRAM,VS.MACHINE,ORACLE_USERNAME,OBJECT_NAME,vs.LOGON_TIME ,
       Vs.status,vs.MODULE, vs.SQL_ID, st.SQL_TEXT
from  V$LOCKED_OBJECT VL ,DBA_OBJECTS OB ,V$SESSION VS ,v$process PS, v$sqlarea st
WHERE VL.OBJECT_ID = OB.OBJECT_ID
      AND VL.SESSION_ID = VS.SID
      AND Ps.ADDR = Vs.PADDR
      and vs.SQL_ID = st.SQL_ID
      AND VS.USERNAME = ‘LC019999‘

select    st.SQL_FULLTEXT, vs.*
from      v$session vs
     join v$sql st on vs.SQL_ID = st.SQL_ID
where     vs.USERNAME = ‘scott‘
      and st.SQL_TEXT like ‘%%‘

--8.产生kill会话的Sql语句
select A.SID,
       B.SPID,
       A.SERIAL#,
       a.lockwait,
       A.USERNAME,
       A.OSUSER,
       a.logon_time,
       a.last_call_et / 3600 LAST_HOUR,
       A.STATUS,
       ‘orakill ‘ || sid || ‘ ‘ || spid HOST_COMMAND,
       ‘alter system kill session ‘‘‘ || A.sid || ‘,‘ || A.SERIAL# || ‘‘‘‘ SQL_COMMAND
  from v$session A, V$PROCESS B
 where A.PADDR = B.ADDR
   AND SID > 6;

-- 最近10分钟最消耗CPU的SQL语句:
select sql_text
from (
        select sql_id,count(*) as cn
        from v$active_session_history
        where sample_time > sysdate - 10/24/60
            and session_type <> ‘BACKGROUND‘
            and SESSION_STATE = ‘ON CPU‘
        group by sql_id
        order by cn desc
    ) ash, v$sql s
where ash.sql_id=s.sql_id;

-- 最近10分钟最消耗IO的SQL语句:
select sql_text
from (
        select sql_id,count(*) as cn
        from v$active_session_history
        where sample_time > sysdate - 10/24/60
            and session_type <> ‘BACKGROUND‘
            and WAIT_CLASS=‘User I/O‘
        group by sql_id
        order by cn desc
    ) ash, v$sql s
where ash.sql_id=s.sql_id;

--清空缓存,Command window执行:
  Alter system flush shared_pool;


--analyze table 更新统计信息:
  analyze table my_table compute statistics;


--删除数据后,释放数据空间
  alter table my_table enable row movement;
  alter table my_table shrink space cascade;
  alter table my_table disable row movement;


获取指定SQL在内存中的执行计划:
select sql_id,child_number,sql_text from v$sql where sql_text like ‘select count(1) from emp a where a.dept_no =%‘;
select * from table(DBMS_XPLAN.DISPLAY_CURSOR(‘sql_id‘,0)); 

1、PL/SQL Developer 中使用F5
2、explain plan for select count(1) from emp a where a.dept_no=5;
     select * from table(dbms_xplan.display());
3、sqlplus中使用 set autotrace traceonly exp;
时间: 2024-12-13 15:43:29

Oracle常用的诊断语句的相关文章

oracle 常用相关sql 语句

一.oracle 常用相关sql 语句 1. 连接数据库       su - oracle -c " sqlsplus 用户/密码     注:首次登陆用  sqlplus / as sysdba            注: 关闭数据库:注:shutdown可加关闭选项,从最温和到最粗暴的行为选项为(shutdown.shutdown transactional.shutdown immediate.shutdown abort)                 shutdown:关闭,等待每

Oracle 常用的修改语句

一.表Table 测试表:MY_TEST_TABLE -- Create table create table MY_TEST_TABLE ( A VARCHAR2(30), B NUMBER(10) default 1, C DATE ) tablespace BOSSWG_CFG pctfree 10 initrans 1 maxtrans 255 storage ( initial 64K minextents 1 maxextents unlimited ); -- Add commen

[标]ORACLE常用的一些语句记录

--查询实际的统计信息select     num_rows,blocks,empty_blocks,avg_space,avg_row_len,sample_size, last_analyzed     from   dba_tables where   upper(table_name)= upper('T_HS_InivBalanceExpEntry'); --SQL语句次数和取数select SQL_TEXT,executions,fetches from v$sql where pa

Oracle常用监控sql语句

1.监控事例的等待: select event,sum(decode(wait_time,0,0,1)) prev, sum(decode(wait_time,0,1,0)) curr,count(*) from v$session_wait  group by event order by 4; 2.回滚段的争用情况: select name,waits,gets,waits/gets ratio from v$rollstat a,v$rollname b where a.usn=b.usn

oracle 常用select sql语句

本人认为很实用的几条语句 1)select ... from ...into... 2)insert into ...select ... 3)select ...from ...left join ...on ... 4)case...when...then ...else ... end Java代码 select * from directory_type where (case when create_date is null then  sysdate  else create_dat

Oracle常用的sql语句

--1.查询系统表空间信息 SELECT * FROM SYS.DBA_TABLESPACES; --2.查询表空间所在路径信息 select * from dba_data_files; --3.查询用户所属表空间 select u.username as 用户名,u.default_tablespace as 所属表空间 from dba_users u; --4.创建表空间 create tablespace GUEST logging datafile 'D:\oracle\oradat

Oracle常用的查询语句

SELECT * from user_views where view_name='v$session': SELECT * FROM ALL_USERS where username like 'S%': select * from v$database: select username,profile from dba_users;: select * from dba_profiles where profile='DEFAULT': SELECT * from v$archive_des

oracle 常用安装脚本以及步骤

oracle 常用脚本以及语句 一.oracle 安装10G 单机初始化环境: #!/bin/bash #关闭selinuxsed -i 's\SELINUX=enforcing\SELINUX=disabled\' /etc/selinux/configsetenforce 0 #关闭防火墙service iptables stopchkconfig iptables off #配置/etc/hosts文件 添加cat >> /etc/hosts<<EOF 172.16.0.19

Oracle 常用语句整理

Oracle 常用语句整理 最近做了份大型数据库作业.遇到了一些问题,在网上找的很是辛苦,于是,将一些常用的语句记录下来,方便大家学习.都是一些基本的东西.如果忘了,可以来看看. 1.创建临时表空间 create temporary tablespace car_data //car_data,表空间名 tempfile 'C:\Users\Administrator\Desktop\car_data.dbf'//表空间路径 size 50m autoextend on next 50m max