zoukankan      html  css  js  c++  java
  • healthcheck

    -- =============================================================================
    -- USAGE  : sqlplus / as sysdba @healthcheck.sql                        
    --                                                                             
    -- TEST   : This script has been successfully tested on these platforms:                                       
    --                              
    --          Linux , Windows , AIX , Solaris 
    --          Oracle Database(Include RAC) 10gR2,11gR2                              
    --                                                                             
    -- NOTE   : Please test this script in ur development environment 
    --          before attempting to run it in production.          
    -- ==============================================================================
    prompt This script must be run as a user with SYSDBA privileges.
    prompt This process can take several minutes to complete.
    prompt
    prompt >> Creating database report... 
     
    define reportHeader="<font size=+3 color="blue"><b>Database Health Check Report</b></font><hr>Copyright (c) 2015 Stephen Zhao. All rights reserved.<p--------------------------------------------------------------------------+
    -- +----------------------------------------------------------------------------+
    -- |                           Script Settings                                  |
    -- +----------------------------------------------------------------------------+
     
    set termout       off
    set echo          off
    set feedback      off
    set heading       off
    set verify        off
    set wrap          on
    set trimspool     on
    set serveroutput  on
    set escape        on
     
    set linesize 300 pagesize 50000
    set long     2000000000
     
    alter session set nls_date_format = 'YYYY-MM-DD HH24:MI:SS';
    alter session set nls_date_language = english;
     
    clear buffer computes columns breaks
     
    define filename=Healthcheck
     
    -- +----------------------------------------------------------------------------+
    -- |                   Gather Database Report Information                       |
    -- +----------------------------------------------------------------------------+
     
    set heading on
     
    clear computes columns breaks
     
    column name       new_value _dbname     noprint
    column spool_time new_value _spool_time noprint
    column spooltime  new_value _spooltime  noprint
     
    select name,to_char(sysdate,'YYYYMMDDHH24MISS') as "spool_time", 
           to_char(sysdate,'YYYY-MM-DD HH24:MI:SS') as "spooltime"
      from v$database;
     
    define _rpt_db_name=&_dbname
     
    define _rpt_spool_time="&_spooltime"
     
    column tablespace_name new_value tablespace_name noprint
    column file_name       new_value file_name       noprint
     
    select max(length_tbs) "tablespace_name",max(length_file) as "file_name"
      from (
            select case when nvl(max(length(tablespace_name)),0) < 10 then 10 else max(length(tablespace_name)) end length_tbs,
                   case when nvl(max(length(file_name)),0)       < 9  then 9  else max(length(file_name))       end length_file 
              from dba_data_files
            union all
            select case when nvl(max(length(tablespace_name)),0) <10 then 10 else max(length(tablespace_name)) end length_tbs,
                   case when nvl(max(length(file_name)),0)       < 9 then 9  else max(length(file_name))       end length_file
              from dba_temp_files
           );
     
    set markup html on spool on preformat off entmap on -
    head '-
      <title>Database Health Check Snapshot for DB:&_rpt_db_name,Snap Time:&_rpt_spool_time</title>-
     <style type="text/css"> -
        body               {font:9pt Arial,Helvetica,sans-serif; color:black; background:White;} -
        p                  {font:2pt Arial,Helvetica,sans-serif; color:black; background:White;} -
        table              {font:9pt Arial,Helvetica,sans-serif; color:Black; padding:0px 0px 0px 0px;padding-left:2px; padding-right:2px; margin:0px 0px 0px 0px;300;overflow:auto;} -
        table.t_600px      {font:9pt Arial,Helvetica,sans-serif; color:Black; background-color:white; padding:0px 0px 0px 0px;padding-left:2px; padding-right:2px; margin:0px 0px 0px 0px;600;overflow:auto;} -
        table.t_200px      {font:9pt Arial,Helvetica,sans-serif; color:Black; padding:0px 0px 0px 0px;padding-left:2px; padding-right:2px; margin:0px 0px 0px 0px;200;overflow:auto;} -
        tr                 {font:9pt Arial,Helvetica,sans-serif; color:Black; background-color:white; padding:0px 0px 0px 0px;padding-left:2px; padding-right:2px; margin:0px 0px 0px 0px;white-space:nowrap} -
        td                 {font:9pt Arial,Helvetica,sans-serif; color:Black; padding:0px 0px 0px 0px;padding-left:2px; padding-right:2px; margin:0px 0px 0px 0px;white-space:nowrap} -
        tr:nth-child(2n+1) { font-family: Helvetica, "Hiragino Sans GB", 微软雅黑, "Microsoft YaHei UI", SimSun, SimHei, arial, sans-serif; font-size: 16px; font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 27.2px; widows: 1;">    th                 {font:bold 9pt Arial,Helvetica,sans-serif; color:white; background:#0066cc;padding-left:4px; padding-right:4px;padding-bottom:2px;white-space:nowrap;} -
        h1                 {font:bold 20pt Arial,Helvetica,Geneva,sans-serif; color:#336699; border-bottom:1px solid gray; margin-top:0pt; margin-bottom:0pt; padding:0px 0px 0px 0px;} -
        h2                 {font:bold 10pt Arial,Helvetica,Geneva,sans-serif; color:#336699; background-color:White; margin-top:4pt; margin-bottom:0pt;} -
        a                  {font:bold 8pt Arial,Helvetica,sans-serif;color:#663300; vertical-align:top;margin-top:0pt; margin-bottom:0pt;} -
        li                 {font: 8pt Arial,Helvetica,Geneva,sans-serif; color:black; background:White;} -
      </style>' -
    body  'bgcolor="c0c0c0"'-
    table  'border_collapse: collapse;border="0";cellpadding="0";cellspacing="1"' 
     
    spool '&filename._&_dbname._&_spool_time..html'
     
    set markup html on entmap off
     
    prompt <h1>Oracle Database Health Check Snapshot</h1>
    -- prompt <hr size="2" color="Gray" align="right" noshade/>
     
    -- +----------------------------------------------------------------------------+
    -- |                         Database Summary Information                       |
    -- +----------------------------------------------------------------------------+
     
    -- setup html mark(table) attribute,define table's width to 600px
     
    set markup html table 'class="t_600px"'
     
    -- Display Database Summary Information
     
    clear columns breaks computes
     
    break on name on dbid on version on rac
     
    column name            format a10              heading 'Name'         print entmap off
    column dbid            format 9999999999999999 heading 'DBID'         print entmap off
    column instance_name   format a15              heading 'Instance'     print entmap off
    column instance_number format 999              heading 'Inst Num'     print entmap off
    column startup_time    format a19              heading 'Startup Time' print entmap off
    column version         format a15              heading 'Release'      print entmap off
    column rac             format a5               heading 'RAC'          print entmap off
     
    select d.name,               
           d.dbid,          
           i.instance_name, 
           i.instance_number,
           i.startup_time,
           i.version,
           i.rac    
      from v$database d,
           (  select instance_name,
                     instance_number,
                     startup_time,
                     version,
                     parallel rac
                from gv$instance) i
            order by i.instance_number;
     
     
    -- Display Host Summary Information
     
    clear columns breaks computes 
     
    column instance_name   format a15        heading 'Instance'    print entmap off
    column host_name       format a25        heading 'Host Name'   print entmap off
    column platform_name   format a99        heading 'Platform'    print entmap off
    column cpus            format 9,999      heading 'CPUs'        print entmap off
    column physical_memory format 999,990.99 heading  'Memory(GB)' print entmap off
     
    select i.instance_name,
           i.host_name,                       
           d.platform_name,
           o1.cpus,
           round(o2.physical_memory/1024/1024/1024,2) physical_memory
      from gv$instance i,
      (select platform_name from v$database) d, 
      (select inst_id,value cpus from gv$osstat where osstat_id=0) o1,
      (select inst_id,value physical_memory from gv$osstat where osstat_id=1008) o2  
     where i.inst_id = o1.inst_id and o1.inst_id = o2.inst_id;         
     
    -- setup html mark(table) attribute,define table's attribute use style
     
    set markup html table 'border_collapse: collapse;border="0";cellpadding="0";cellspacing="1"'
     
    -- ==============================================================================
    --                               Main Report Index                                  
    -- ==============================================================================
    -- Define Main Report Index
     
    prompt <a name="top"></a>
    prompt <font size="+2" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Main Report Index</b></font>
    prompt <ul>-
    <li><a href='#overview'>Database Information</a></li>-
    <li><a href='#storage'>Storage Statistics</a></li>-
    <li><a href='#undo'>Undo Segments</a></li>-
    <li><a href='#memory'>Memory Statistis</a></li>-
    <li><a href='#secutiry'>Security Information</a></li>-
    <li><a href='#object'>Object Information</a></li>-
    <li><a href='#job'>Schedule/Job</a></li>-
    <li><a href='#backup'>Backup Detail</a></li>-
    <li><a href='#performance'>Performance Statistics</a></li>-
    <li><a href='#parameter'>Init. Parameter</a></li>-
    </ul>-
    <hr size="1" color="Gray" noshade/>
     
    -- ==============================================================================
    --                                   Overview                                  
    -- ==============================================================================
     
    prompt <a name="overview"></a>-
    <font size="+2" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Database Information</b></font>
    prompt <ul>-
    <li><a href='#11'>Database Overview</a></li>-
    <li><a href='#12'>Instance Overview</a></li>-
    <li><a href='#13'>Session Overview</a></li>-
    <li><a href='#14'>Version</a></li>-
    <li><a href='#15'>PSU Registry History</a></li>-
    <li><a href='#16'>Database Registry</a></li>-
    <li><a href='#17'>Database Options</a></li>-
    <li><a href='#18'>Controlfile</a></li>-
    <li><a href='#19'>Online Redo Logfiles</a></li>-
    <li><a href='#101'>Logfile Switch</a></li>-
    <li><a href='#102'>SCN Health Check</a></li>-
    <li><a href='#103'>High Water Mark Statistics</a></li>-
    </ul>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                               Database Overview                            |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="11"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Database Overview</b></font>
     
    clear columns breaks computes
     
    column name             format a12                heading 'DB Name'          print entmap off  
    column dbid             format 999999999999       heading 'DBID'             print entmap off  
    column db_unique_name   format a15                heading 'DB Unique Name'   print entmap off  
    column created          format a19                heading 'Create Date'      print entmap off
    column platform_name    format a50                heading 'Platform'         print entmap off
    column current_scn      format 9999999999999999   heading 'Current SCN'      print entmap off  
    column log_mode         format a25                heading 'Log Mode'         print entmap off  
    column open_mode        format a15                heading 'Open Mode'        print entmap off  
    column force_logging    format a13                heading 'Force Logging'    print entmap off  
    column flashback_on     format a12                heading 'Flashback On'     print entmap off 
    column controlfile_type format a16                heading 'Controlfile Type' print entmap off  
    column dbtimezone       format a11                heading 'DB TimeZone'      print entmap off
     
    select name,
           dbid,
           db_unique_name,
           created,
           platform_name,
           current_scn,
           log_mode,
           open_mode,
           force_logging,
           flashback_on,
           controlfile_type,
           dbtimezone
      from v$database;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#overview">Back to Database Information</a>
    prompt <a href="#top">Back to Top</a>
    -- prompt <br />
      
    -- +----------------------------------------------------------------------------+
    -- |                               Instance Overview                            |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="12"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Instance Overview</b></font>
     
    clear columns breaks computes
     
     
    column instance_number format 9999999           heading 'Inst_Num'      print entmap off
    column instance_name   format a15               heading 'Instance Name' print entmap off
    column host_name       format a30               heading 'Host Name'     print entmap off
    column version         format a10               heading 'Release'       print entmap off
    column startup_time    format a19               heading 'Startup Time'  print entmap off
    column uptime          format 999,990.99        heading 'Up Days'       print entmap off
    column status          format a15               heading 'Status'        print entmap off
    column archiver        format a8                heading 'Archiver'      print entmap off
     
      select instance_number,
             instance_name,
             host_name,
             version,
             to_char (startup_time, 'YYYY-MM-DD HH24:MI:SS') "startup_time",
             round (sysdate - startup_time, 2) "uptime",
             status,
             archiver
        from gv$instance
    order by instance_number;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#overview">Back to Database Information</a>
    prompt <a href="#top">Back to Top</a>
    -- prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                               Session Overview                             |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="13"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Session Overview</b></font>
     
    clear columns breaks computes
     
    column inst_id format 999     heading 'Inst_ID'  print entmap off
    column count   format 999,999 heading 'Sessions' print entmap off
    column status  format a10     heading 'Status'   print entmap off
     
    break on inst_id on report
    --break on report
    compute sum label 'Total:' of count on report
     
      select inst_id,count(*) count,status
        from gv$session
    group by inst_id,status
    order by inst_id;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#overview">Back to Database Information</a>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                                   Version                                  |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="14"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Version</b></font>
     
    clear columns breaks computes
     
    column banner format a300 heading 'Banner' print entmap off
     
    select banner 
      from v$version;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#overview">Back to Database Information</a>
    prompt <a href="#top">Back to Top</a>
    -- prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                            PSU Registry History                            |
    -- +----------------------------------------------------------------------------+
     
    prompt<a name="15"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>PSU Registry History</b></font>
     
    clear columns breaks computes
     
    column action_time   format a19 heading 'Action Time'   print entmap off
    column action        format a8  heading 'Action'        print entmap off
    column namespace     format a9  heading 'Namespace'     print entmap off
    column version       format a10 heading 'Version'       print entmap off
    column id            format 999 heading 'ID'            print entmap off
    column comments      format a25 heading 'Comments'      print entmap off
    column bundle_series format a13 heading 'Bundle Series' print entmap off
     
    select * 
      from registry$history;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#overview">Back to Database Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                              Database Registry                             |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="16"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Database Registry</b></font>
     
    clear columns breaks computes
     
    column comp_name format a75 heading 'Comp_Name' print entmap off
    column version   format a15 heading 'Version'   print entmap off
    column status    format a10 heading 'Status'    print entmap off
     
    select comp_name, version, status 
      from dba_registry;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#overview">Back to Database Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
      
    -- +----------------------------------------------------------------------------+
    -- |                                Database Options                            |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="17"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Database Options</b></font>
     
    clear columns breaks computes
     
    column parameter format a75 heading 'Options' print entmap off
    column value     format a15 heading 'Value'   print entmap off
     
    select * from v$option;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#overview">Back to Database Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                                 Controlfile                                |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="18"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Controlfile</b></font>
     
    clear column breaks computes
     
    column name for a150        heading 'Name'       print entmap off
    column size for 999,999,999 heading 'Size_Bytes' print entmap off
     
    select name, block_size "size" 
      from v$controlfile;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#overview">Back to Database Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                           Online Redo Logfiles                             |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="19"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Online Redo Logfiles</b></font>
     
    clear column breaks computes
     
    break on thread# on group#
     
    column thread# format 999        heading 'Thread#' print entmap off
    column group#  format 999        heading 'Group#'  print entmap off
    column member  format a150       heading 'Member'  print entmap off
    column status  format a8         heading 'Status'  print entmap off
    column size    format 999,999    heading 'Size_MB' print entmap off
    column type    format a15        heading 'Type'    print entmap off
     
      select b.thread#,
             b.group#,
             a.member,
             b.status,
             (b.bytes / 1024 / 1024) as "size",
             decode(a.type,'ONLINE',a.type,'<div align="left"><font color="red">' || a.type || '</font></div>') type
        from v$logfile a, v$log b
       where a.group# = b.group#
    order by 1, 2;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#overview">Back to Database Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                            Redo Logfile Switch                             |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="101"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Logfile Switch</b></font>
     
    clear columns breaks computes
     
    column day   format a10     heading 'Day/Time'
    column H00   format 999     heading '00'      
    column H01   format 999     heading '01'      
    column H02   format 999     heading '02'      
    column H03   format 999     heading '03'      
    column H04   format 999     heading '04'      
    column H05   format 999     heading '05'      
    column H06   format 999     heading '06'      
    column H07   format 999     heading '07'      
    column H08   format 999     heading '08'      
    column H09   format 999     heading '09'      
    column H10   format 999     heading '10'      
    column H11   format 999     heading '11'      
    column H12   format 999     heading '12'      
    column H13   format 999     heading '13'      
    column H14   format 999     heading '14'      
    column H15   format 999     heading '15'      
    column H16   format 999     heading '16'      
    column H17   format 999     heading '17'      
    column H18   format 999     heading '18'      
    column H19   format 999     heading '19'      
    column H20   format 999     heading '20'      
    column H21   format 999     heading '21'      
    column H22   format 999     heading '22'      
    column H23   format 999     heading '23'      
    column total format 999,999 heading 'Total'   
     
    break on report
    compute sum label 'Total:' min label 'Min:' max label 'Max:' avg label 'Average:' of total on report
     
      select to_char (first_time, 'YYYY-MM-DD') day,
             sum (decode (to_char (first_time, 'HH24'), '00', 1, 0)) H00,
             sum (decode (to_char (first_time, 'HH24'), '01', 1, 0)) H01,
             sum (decode (to_char (first_time, 'HH24'), '02', 1, 0)) H02,
             sum (decode (to_char (first_time, 'HH24'), '03', 1, 0)) H03,
             sum (decode (to_char (first_time, 'HH24'), '04', 1, 0)) H04,
             sum (decode (to_char (first_time, 'HH24'), '05', 1, 0)) H05,
             sum (decode (to_char (first_time, 'HH24'), '06', 1, 0)) H06,
             sum (decode (to_char (first_time, 'HH24'), '07', 1, 0)) H07,
             sum (decode (to_char (first_time, 'HH24'), '08', 1, 0)) H08,
             sum (decode (to_char (first_time, 'HH24'), '09', 1, 0)) H09,
             sum (decode (to_char (first_time, 'HH24'), '10', 1, 0)) H10,
             sum (decode (to_char (first_time, 'HH24'), '11', 1, 0)) H11,
             sum (decode (to_char (first_time, 'HH24'), '12', 1, 0)) H12,
             sum (decode (to_char (first_time, 'HH24'), '13', 1, 0)) H13,
             sum (decode (to_char (first_time, 'HH24'), '14', 1, 0)) H14,
             sum (decode (to_char (first_time, 'HH24'), '15', 1, 0)) H15,
             sum (decode (to_char (first_time, 'HH24'), '16', 1, 0)) H16,
             sum (decode (to_char (first_time, 'HH24'), '17', 1, 0)) H17,
             sum (decode (to_char (first_time, 'HH24'), '18', 1, 0)) H18,
             sum (decode (to_char (first_time, 'HH24'), '19', 1, 0)) H19,
             sum (decode (to_char (first_time, 'HH24'), '20', 1, 0)) H20,
             sum (decode (to_char (first_time, 'HH24'), '21', 1, 0)) H21,
             sum (decode (to_char (first_time, 'HH24'), '22', 1, 0)) H22,
             sum (decode (to_char (first_time, 'HH24'), '23', 1, 0)) H23,
             count (*) total
        from v$log_history a
       where first_time >= sysdate - 30
    group by to_char (first_time, 'YYYY-MM-DD')
    order by to_char (first_time, 'YYYY-MM-DD');
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#overview">Back to Database Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                             SCN Health Check                               |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="102"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>SCN Health Check</b></font>
     
    clear columns breaks computes
     
    column Date_Time             format a19
    column scn               format 999999999999
    column Headroom              format 999999999999.0
    column Adjust_SCN            format 999999999999.0
    column ALL_SCN               format 999999999999.0
    column "SCN Headroom Health" format a21
     
    select tim "Date_Time",
           scn,
           round((chk16kscn-scn)/24/3600/16/1024,1) "Headroom",
           round((chk16kscn-scn)/1024/1024/1024,1) "Adjust_SCN",
           round(chk16kscn/1024/1024/1024,1) "ALL_SCN",
           case when round((chk16kscn-scn)/24/3600/16/1024,1) > 62 then 'SCN Headroom Is Good.'
                when round((chk16kscn-scn)/24/3600/16/1024,1) < 10 then '<div align="left"><font color="red">SCN Headroom Is Bad.</font></div>'
           end "SCN Headroom Health"
      from (
            select tim, scn,
            ((((to_number(to_char(tim,'YYYY'))-1988)*12*31*24*60*60) 
            + ((to_number(to_char(tim,'MM'))-1)*31*24*60*60) 
            + (((to_number(to_char(tim,'DD'))-1))*24*60*60) 
            + (to_number(to_char(tim,'HH24'))*60*60) 
            + (to_number(to_char(tim,'MI'))*60) 
            + (to_number(to_char(tim,'SS')))) * (16*1024)) chk16kscn
              from (select sysdate tim,dbms_flashback.get_system_change_number scn 
                      from v$instance 
                     where    version like '10.%' 
                           or version like '11.1%' 
                           or version like '11.2.0.1%'
                   )
           )
    union all 
    select tim "Date_Time",
           scn,
           round((chk32kscn-scn)/24/3600/32/1024,1) "Headroom",
           round((chk32kscn-scn)/1024/1024/1024,1) "Adjust_SCN",
           round(chk32kscn/1024/1024/1024,1) "ALL_SCN",
           case when round((chk32kscn-scn)/24/3600/32/1024,1) > 62 then 'SCN Headroom Is Good.'
                when round((chk32kscn-scn)/24/3600/32/1024,1) < 10 then '<div align="left"><font color="red">SCN Headroom Is Bad.</font></div>'
           end "SCN Headroom Health"
      from (
           select tim, scn,
           ((((to_number(to_char(tim,'YYYY'))-1988)*12*31*24*60*60) 
           + ((to_number(to_char(tim,'MM'))-1)*31*24*60*60) 
           + (((to_number(to_char(tim,'DD'))-1))*24*60*60) 
           + (to_number(to_char(tim,'HH24'))*60*60) 
           + (to_number(to_char(tim,'MI'))*60) 
           + (to_number(to_char(tim,'SS')))) * (32*1024)) chk32kscn
             from (select sysdate tim,dbms_flashback.get_system_change_number scn 
                     from v$instance 
                    where    version like '11.2.0.2%' 
                          or version like '11.2.0.3%' 
                          or version like '11.2.0.4%' 
                          or version like '12.%'
                  )
           );
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#overview">Back to Database Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
             
    -- +----------------------------------------------------------------------------+
    -- |                         High Water Mark Statistics                         |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="103"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>High Water Mark Statistics</b></font>
     
    clear columns breaks computes
      
    column name        format a50                   heading 'Statistic Name' print entmap off
    column version     format a10                   heading 'Version'        print entmap off
    column highwater   format 9,999,999,999,999,999 heading 'Highwater'      print entmap off
    column last_value  format 9,999,999,999,999,999 heading 'Last Value'     print entmap off
    column description format a150                  heading 'Description'    print entmap off
     
    select name, version, highwater, last_value, description 
      from dba_high_water_mark_statistics;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#overview">Back to Database Information</a>
    prompt <a href="#top">Back to Top</a>
    prompt <br />
     
    -- ==============================================================================
    --                                   Storage                                  
    -- ==============================================================================
     
    prompt <a name="storage"></a>
    prompt <font size="+2" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Storage Statistics</b></font>
    prompt <ul>-
    <li><a href='#21'>Tablespace Statistics</a></li>-
    <li><a href='#22'>Datafiles and Tempfiles Statistics</a></li>-
    <li><a href='#23'>Total Segments Size</a></li>-
    <li><a href='#24'>Top 10 Tables</a></li>-
    <li><a href='#25'>Top 10 Indexes</a></li>-
    </ul>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                                 Tablespace                                 |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="21"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Tablespace Statistics</b></font>
     
    clear columns breaks computes
     
    column tablespace_name          format "a&tablespace_name" heading 'Tablespace'               print entmap off
    column type                     format a9                  heading 'Type'                     print entmap off
    column status                                              heading 'Status'                   print entmap off
    column bigfile                  format a7                  heading 'Bigfile'                  print entmap off
    column total_mb                 format 999,999,990.00      heading 'Total_MB'                 print entmap off
    column free_mb                  format 999,999,990.00      heading 'Free_MB'                  print entmap off
    column used_mb                  format 999,999,990.00      heading 'Used_MB'                  print entmap off
    column "used%"                                             heading 'Used %'                   print entmap off
    column extent_management        format a10                 heading 'Extent Management'        print entmap off
    column segment_space_management format a13                 heading 'Segment Space Management' print entmap off
    column compute                  format a7                  heading 'Compute'                  print entmap off
     
    break on report
    compute count label 'Count:' of type                     on report
    compute sum   label 'Total:' of total_mb used_mb free_mb on report
     
    select a.tablespace_name,
           a.type,
           space total_mb,
           nvl (free_space, 0) free_mb,
           space - nvl (free_space, 0) used_mb,
           case
              when trunc ( (1 - nvl (free_space, 0) / space) * 100) >= 90
              then '<div align="right"><font color="red">' || to_char (round ( (1 - nvl (free_space, 0) / space) * 100, 2), '990.99') || '</font></div>'
              else '<div align="right">' || to_char (round ( (1 - nvl (free_space, 0) / space) * 100, 2), '990.99') || '</div>'
           end "used%",
           a.bigfile,
           decode(a.status,'ONLINE',a.status,'<div align="left"><font color="red">' || a.status || '</font></div>') status,
           a.extent_management,
           a.segment_space_management
      from (  select d.tablespace_name,
                     t.contents type,
                     t.status,
                     t.bigfile,
                     t.extent_management,
                     t.segment_space_management,
                     round (sum (bytes) / 1024 / 1024, 2) space
                from dba_data_files d, dba_tablespaces t
               where d.tablespace_name = t.tablespace_name
            group by d.tablespace_name,
                     t.contents,
                     t.status,
                     t.bigfile,
                     t.extent_management,
                     t.segment_space_management) a,
           (  select tablespace_name,
                     round (sum (bytes) / 1024 / 1024, 2) free_space
                from dba_free_space
            group by tablespace_name) b
     where a.tablespace_name = b.tablespace_name(+)
    union all
    select a.tablespace_name,
           a.type,
           space total_mb,
           nvl (free_space, 0) free_mb,
           nvl (used_space, 0) as used_mb,
           case
              when trunc ( (nvl (used_space, 0) / space) * 100) >= 90
              then '<div align="right"><font color="red">' || to_char (round ( (nvl (used_space, 0) / space) * 100, 2), '990.99') || '</font></div>'
              else '<div align="right">' || to_char (round ( (nvl (used_space, 0) / space) * 100, 2), '990.99') || '</div>'
           end "used%",
           a.bigfile,
           decode(a.status,'ONLINE',a.status,'<div align="left"><font color="red">' || a.status || '</font></div>') status,
           a.extent_management,
           a.segment_space_management
      from (  select d.tablespace_name,
                     t.contents type,
                     t.status,
                     t.bigfile,
                     t.extent_management,
                     t.segment_space_management,
                     round (sum (bytes) / 1024 / 1024, 2) space
                from dba_temp_files d, dba_tablespaces t
               where d.tablespace_name = t.tablespace_name
            group by d.tablespace_name,
                     t.contents,
                     t.status,
                     t.bigfile,
                     t.extent_management,
                     t.segment_space_management) a,
           (  select tablespace_name,
                     round (sum (bytes_used) / 1024 / 1024, 2) used_space,
                     round (sum (bytes_free) / 1024 / 1024, 2) free_space
                from v$temp_space_header
            group by tablespace_name) b
     where a.tablespace_name = b.tablespace_name(+)
    order by 6 desc;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#storage">Back to Strorage Statistics</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                          Datafiles And Tempfiles                            |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="22"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Datafiles And Tempfiles</b></font>
     
    clear columns breaks computes
           
    column tablespace_name format "a&tablespace_name" heading 'Tablespace'     print entmap
    column file_name       format "a&file_name"       heading 'File_Name'      print entmap
    column total_mb        format 999,999,990.00      heading 'Total_MB'       print entmap
    column max_mb          format 999,999,990.00      heading 'Max_MB'         print entmap
    column autoextensible  format a15                 heading 'Autoextensible' print entmap
    column status          format a15                 heading 'Status'         print entmap
     
    break on tablespace_name on report
    compute count label 'Count:' of file_name on report
    compute sum label 'Total:' of total_mb max_mb on report
     
    select tablespace_name,
           file_name,
           bytes / 1024 / 1024 total_mb,
           maxbytes / 1024 / 1024 max_mb,
           autoextensible,
           decode(online_status,'ONLINE',online_status,'SYSTEM',online_status,'<div align="left"><font color="red">' || online_status || '</font></div>') status
           from dba_data_files
    union all
    select a.tablespace_name,
           a.file_name,
           a.bytes / 1024 / 1024 total_mb,
           a.maxbytes / 1024 / 1024 max_mb,
           a.autoextensible,
           decode(b.status,'ONLINE',b.status,'<div align="left"><font color="red">' || b.status || '</font></div>') status
      from dba_temp_files a, v$tempfile b
     where a.file_id = b.file#;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#storage">Back to Strorage Statistics</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                                Segment Statistics                          |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="23"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Total Segments Size</b></font>
     
    set markup html table 'class="t_200px"'
     
    clear columns breaks computes
     
    column total_segments_mb format 999,999,990.99 heading 'Total Segments Size(MB)' print entmap off
     
    select '<div align="center">' || round (sum (bytes) / 1024 / 1024, 2) || '</div>' total_segments_mb
      from dba_segments;
     
    set markup html table 'border_collapse: collapse;border="0";cellpadding="0";cellspacing="1"'
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#storage">Back to Strorage Statistics</a>
    prompt <a href="#top">Back to Top</a>
     
     
    prompt <a name="24"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Top 10 Tables</b></font>
     
    clear columns breaks computes
     
    column owner       format a50            heading 'Owner'      print entmap off
    column table_name  format a50            heading 'Table_Name' print entmap off
    column partitioned format a15            heading 'Partition'  print entmap off
    column size_mb     format 999,999,990.99 heading 'Size_MB'    print entmap off
    select *
      from (  select t.owner,
                     t.table_name,
                     t.partitioned,
                     round (sum (s.bytes) / 1024 / 1024, 2) size_mb
                from dba_tables t, dba_segments s
               where     t.owner = s.owner
                     and s.segment_name = t.table_name
                     and s.segment_type like 'TABLE%'
            group by t.owner, t.table_name, t.partitioned
            order by size_mb desc)
     where rownum <= 10;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#storage">Back to Strorage Statistics</a>
    prompt <a href="#top">Back to Top</a>
     
    prompt <a name="25"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Top 10 Indexes</b></font>
     
    column owner      format a50 heading 'Owner'      print entmap off
    column table_name format a50 heading 'Table_Name' print entmap off
    column index_name format a50 heading 'Index_Name' print entmap off
     
    select *
      from (  select i.owner,
                     i.table_name,
                     i.index_name,
                     i.partitioned,
                     sum (s.bytes) / 1024 / 1024 size_mb
                from dba_indexes i, dba_segments s
               where     s.owner = i.owner
                     and s.segment_name = i.index_name
                     and s.segment_type like 'INDEX%'
            group by i.owner,
                     i.table_name,
                     i.index_name,
                     i.partitioned
            order by size_mb desc)
     where rownum <= 10;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#storage">Back to Strorage Statistics</a>
    prompt <a href="#top">Back to Top</a>
     
     
     
    -- ==============================================================================
    --                                  Undo Segments                                
    -- ==============================================================================
     
    prompt <a name="undo"></a>
    prompt <font size="+2" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Undo Segments Information</b></font>
    prompt <ul>-
    <li><a href='#31'>Undo Parameters</a></li>-
    <li><a href='#32'>Undo Segments Statistics</a></li>-
    </ul>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                              Undo Parameters                               |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="31"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Undo Parameters</b></font>
     
    clear columns breaks computes
     
    column instance format a15 heading 'Instance' print entmap off
    column name     format a15 heading 'Name'     print entmap off
    column value    format a10 heading 'Value'    print entmap off
     
    break on instance
     
      select i.instance_name instance, p.name, p.value 
        from gv$parameter p, gv$instance i 
       where     name like '%undo%'
             and p.inst_id = i.inst_id
    order by 1;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#undo">Back to Undo Segments Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                               Undo Segments                                |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="32"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Undo Segments Statistics</b></font>
     
    clear columns breaks computes
     
    column instance_name   format a10              heading 'Instance'     entmap off
    column tablespace_name format a9               heading 'Tablspace'    entmap off
    column roll_name       format a20              heading 'Roll Name'    entmap off
    column initial_extent  format 999,999,999      heading 'Init Extent'  entmap off
    column next_extent     format 999,999,999      heading 'Next Extent'  entmap off
    column min_extents     format 999,999,999      heading 'Min Extents'  entmap off
    column max_extents     format 999,999,999      heading 'Max Extents'  entmap off
    column status          format a8               heading 'Status'       entmap off
    column wraps           format 999,999,999      heading 'Wraps'        entmap off
    column shrinks         format 999,999,999      heading 'Shrinks'      entmap off
    column optsize         format 999,999,999,999  heading 'Optsize'      entmap off
    column bytes           format 999,999,999,999  heading 'Bytes'        entmap off
    column extents         format 999,999,999      heading 'Extents'      entmap off
     
    clear computes breaks
     
    break on report on instance_name on tablespace
    compute sum label 'Total:' of bytes extents shrinks wraps on report
     
        select instance_name,
             a.tablespace_name,
             a.owner || '.' || a.segment_name roll_name,
             a.initial_extent,
             a.next_extent,
             a.min_extents,
             a.max_extents,
             a.status,
             b.bytes,
             b.extents,
             d.shrinks,
             d.wraps,
             d.optsize
        from dba_rollback_segs a,
             dba_segments b,
             v$rollname c,
             v$rollstat d,
             gv$parameter p,
             gv$instance i
       where     a.segment_name = b.segment_name
             and a.segment_name = c.name(+)
             and c.usn = d.usn(+)
             and p.name(+) = 'undo_tablespace'
             and p.value(+) = a.tablespace_name
             and p.inst_id = i.inst_id(+)
    order by a.tablespace_name, a.segment_name;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#undo">Back to Undo Segments Information</a>
    prompt <a href="#top">Back to Top</a>
    prompt <br />
     
    -- ==============================================================================
    --                                Memory Statistics                                
    -- ==============================================================================
     
    prompt <a name="memory"></a>
    prompt <font size="+2" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Memory Statistics</b></font>
    prompt <ul>-
    <li><a href='#41'>Memory Allocate Size</a></li>-
    <li><a href='#42'>Show SGA</a></li>-
    <li><a href='#43'>SGA Info</a></li>-
    <li><a href='#44'>PGA Info</a></li>-
    </ul>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                            Memory Allocate Size                            |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="41"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Memory Allocate Size</b></font>
     
    clear columns breaks computes
     
    break on instance_name
     
    column instance_name format 9999999    heading 'Instance'     print entmap off
    column name          format a20        heading 'Memory Stats' print entmap off
    column value         format 999,990.99 heading 'Size_MB'      print entmap off
     
      select i.instance_name, name, round (value / 1024 / 1024, 2) value
        from gv$parameter p, gv$instance i
       where     p.inst_id = i.inst_id
             and name in ('memory_max_target',
                      'memory_target',
                      'sga_max_size',
                      'sga_target',
                      'pga_aggregate_target')
    order by 1;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#memory">Back to Memory Statistics</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                                 SGA Show                                   |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="42"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Show SGA</b></font>
     
    clear columns breaks computes
     
    column instance_name format a13         heading 'Instance'      print entmap off 
    column name          format a30         heading 'Name'          print entmap off
    column value         format 999,990.99  heading 'Size_MB'       print entmap off   
     
    break on report on instance_name
    compute sum label 'Total SGA:' of value on instance_name
     
      select i.instance_name,
             s.name,
             round(s.value/1024/1024,2) value
        from gv$sga s, gv$instance i
       where s.inst_id = i.inst_id
    order by i.instance_name, s.value desc;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#memory">Back to Memory Statistics</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                                 SGA Info                                   |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="43"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>SGA Info</b></font>
     
    clear columns breaks computes
     
    break on report on instance_name
     
    column instance_name format a13         heading 'Instance'   print entmap off
    column name          format a50         heading 'Pool Name'  print entmap off
    column bytes         format 999,990.99  heading 'Size_MB'    print entmap off
    column resizeable    format a10         heading 'Resizeable' print entmap off
     
      select instance_name,
             name,
             round (bytes / 1024 / 1024, 2) bytes,
             resizeable
        from gv$sgainfo s, gv$instance i
       where s.inst_id = i.inst_id
    order by 1, 3 desc;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#memory">Back to Memory Statistics</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                                 PGA Info                                   |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="44"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>PGA Info</b></font>
     
    clear columns breaks computes
     
    column instance_name       format a13                 heading 'Instance' print entmap off
    column name                format a50                 heading 'Name'     print entmap off
    column total_mb            format 999,999,990.99      heading 'Total_MB' print entmap off
    column unit        format a7                  heading 'Unit'     print entmap off
     
    break on report on instance_name
     
      select i.instance_name,
             p.name,
             round (p.value / 1024 / 1024, 2) total_mb,
             p.unit
        from gv$pgastat p, gv$instance i
       where p.inst_id = i.inst_id
    order by 1, 3 desc,4;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#memory">Back to Memory Statistics</a>
    prompt <a href="#top">Back to Top</a>
    prompt <br />
     
    -- ==============================================================================
    --                                   Security                                
    -- ==============================================================================
     
    prompt <a name="secutiry"></a>
    prompt <font size="+2" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Security Information</b></font>
    prompt <ul>-
    <li><a href='#51'>User Summary</a></li>-
    <li><a href='#52'>User Profiles</a></li>-
    <li><a href='#53'>Role</a></li>-
    <li><a href='#54'>Database Links</a></li>-
    </ul>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                                 User Info                                  |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="51"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>User Summary</b></font>-
    <br>
     
    -- User Information
     
    prompt <font size="2pt"><b>User Information</b></font>
     
    clear columns breaks computes
     
    column username              format a30          heading 'Username'           print entmap off
    column default_tablespace    format a18          heading 'Default Tablespace' print entmap off  
    column temporary_tablespace  format a15          heading 'Temp Tablespace'    print entmap off  
    column created               format a19          heading 'Created'            print entmap off
    column expiry_date           format a19          heading 'Expire Date'        print entmap off
    column lock_date             format a19          heading 'Lock Date'          print entmap off
    column profile               format a20          heading 'Profile'            print entmap off
    column sysdba                format a6           heading 'SYSDBA'             print entmap off
    column sysoper               format a7           heading 'SYSOPER'            print entmap off
    column sysasm                format a6           heading 'SYSASM'             print entmap off
    column account_status        format a16          heading 'Account Status'     print entmap off
     
      select distinct a.username,
                      a.default_tablespace,
                      a.temporary_tablespace,
                      a.profile,
                      a.account_status,
                      to_char (a.created, 'YYYY-MM-DD HH24:MI:SS') created,
                      to_char (a.expiry_date, 'YYYY-MM-DD HH24:MI:SS') expiry_date,
                      to_char (a.lock_date, 'YYYY-MM-DD HH24:MI:SS') lock_date
        from dba_users a
    order by a.account_status desc;
     
    -- User With SYSDBA Privilege
     
    prompt <font size="2pt"><b>User With SYSDBA Privilege</b></font>
     
    select * from v$pwfile_users;
     
     
    -- User With DBA Privilege
     
    prompt <font size="2pt"><b>User With DBA Privilege</b></font>
     
    clear columns breaks computes
     
    column grantee        for a50         heading 'User'         print entmap off 
    column granted_role   for a4          heading 'Role'         print entmap off
    column admin_option   for a12         heading 'Admin Option' print entmap off
    column default_role   for a12         heading 'Default Role' print entmap off 
     
    select grantee,
           granted_role,
           admin_option,
           default_role
      from dba_role_privs
     where granted_role = 'DBA';
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#secutiry">Back to Security Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                                User Profiles                               |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="52"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>User Profiles</b></font>
     
    clear columns breaks computes
     
    column profile       format a20 heading 'Profile'       print entmap off
    column resource_name format a50 heading 'Resource Name' print entmap off
    column resource_type format a30 heading 'Resource Type' print entmap off
    column limit         format a30 heading 'Limit'         print entmap off
     
    break on profile
     
      select profile,
             resource_name,
             resource_type,
             limit
        from dba_profiles
    order by profile;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#secutiry">Back to Security Information</a>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                                     Role                                   |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="53"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Roles</b></font>
     
    clear columns breaks computes
     
    column role         for a50 heading 'Role name'    print entmap off
    column grantee      for a50 heading 'Grantee'      print entmap off
    column admin_option for a15 heading 'Admin Option' print entmap off
    column default_role for a15 heading 'Default Role' print entmap off
     
    break on role
     
      select b.role,
             a.grantee,
             a.admin_option,
             a.default_role
        from dba_role_privs a, dba_roles b
       where granted_role(+) = b.role
    order by b.role, a.grantee;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#secutiry">Back to Security Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                                  DB Links                                  |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="54"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Database Links</b></font>
     
    clear columns breaks computes
     
    column owner    for a30  heading 'Owner'    print entmap off   
    column db_link  for a30  heading 'DB Link'  print entmap off
    column username for a30  heading 'Username' print entmap off   
    column host     for a30  heading 'Host'     print entmap off   
    column created  for a19  heading 'Created'  print entmap off   
     
    break on owner
     
      select owner,
             db_link,
             username,
             host,
             to_char (created, 'YYYY-MM-DD HH24:MI:SS') created
        from dba_db_links
    order by owner, db_link;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#secutiry">Back to Security Information</a>
    prompt <a href="#top">Back to Top</a>
    prompt <br />
     
    -- ==============================================================================
    --                                     Objects                               
    -- ==============================================================================
     
    prompt <a name="object"></a>
    prompt <font size="+2" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Objects Information</b></font>
    prompt <ul>-
    <li><a href='#61'>Invalid Objects</a></li>-
    <li><a href='#62'>Disabled Constraints</a></li>-
    <li><a href='#63'>Disabled Triggers</a></li>-
    <li><a href='#64'>Objects In System Tablespace</a></li>-
    <li><a href='#65'>Directory Information</a></li>-
    <li><a href='#66'>Recyclebin</a></li>-
    </ul>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                               Invalid Objects                              |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="61"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Invalid Objects</b></font>-
    <br>
     
    -- Invalid Objects Count
     
    prompt <font size="2pt"><b>Invalid Objects Count</b></font>
     
    clear columns breaks computes
     
    column owner       for a30     heading 'Owner'  print entmap off
    column object_name for a50     heading 'Name'   print entmap off
    column object_type for a50     heading 'Type'   print entmap off
    column count       for 999,999 heading 'Count'  print entmap off
    column status      for a7      heading 'Status' print entmap off
     
      select owner,
             object_type,
             status,
             count (object_name) as "count"
        from dba_objects
       where status = 'INVALID'
    group by owner, object_type, status
    order by count (object_name) desc;
     
    -- Invalid Objects Detail
     
    prompt <font size="2pt"><b>Invalid Objects Detail</b></font>
     
    break on owner on object_type
     
      select owner,
             object_type,
             object_name,
             status
        from dba_objects
       where status = 'INVALID'
    order by 1,2,3;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#object">Back to Objects Information</a>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                              Disabled Constraints                          |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="62"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Disabled Constraints</b></font>
     
    clear columns breaks computes 
     
    column owner           format a20 heading 'Owner'           print entmap off;
    column constraint_name format a30 heading 'Constraint Name' print entmap off;
    column constraint_type format a15 heading 'Constraint Type' print entmap off;
    column table_name      format a30 heading 'Table Name'      print entmap off;
     
    break on owner on table_name
     
      select owner,
             table_name,
             constraint_name,
             decode (constraint_type,
                     'C', 'check constraint on a table',
                     'P', 'primary key',
                     'U', 'unique key',
                     'R', 'referential integrity',
                     'V', 'with check option, on a view',
                     'O', 'with read only, on a view',
                     null)
                constraint_type
        from dba_constraints
       where status = 'DISABLED'
    order by 1,2;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#object">Back to Objects Information</a>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                               Disabled Triggers                            |
    -- +----------------------------------------------------------------------------+
    -- Check if there have disabled triggers
    ---- Recompile the disabled triggers
     
    prompt <a name="63"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Disabled Triggers</b></font>
     
    clear columns breaks computes 
     
    column owner        format a20 heading 'Owner'        print entmap off
    column trigger_name format a30 heading 'Trigger Name' print entmap off
    column trigger_type format a20 heading 'Trigger Type' print entmap off
     
    break on owner
     
    select owner, trigger_name, trigger_type
      from dba_triggers
     where status = 'DISABLED';
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#object">Back to Objects Information</a>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                          Object In System Tablespace                       |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="64"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Objects In System Tablespace</b></font>
     
    -- Check tables and indexes in system tablespace that not belong to sys or system 
     
    clear columns breaks computes 
     
    column object_type format a15 heading 'Object Type' print entmap off
    column owner       format a20 heading 'Owner'       print entmap off
    column tablespace  format a30 heading 'Tablespace'  print entmap off
    column object_name format a30 heading 'Object Name' print entmap off
     
    break on object_type on owner on tablespace
     
    select object_type,
           owner,
           tablespace_name tablespace,
           object_name
      from (select 'Table' object_type,
                   owner,
                   tablespace_name,
                   table_name object_name
              from dba_tables
            union
            select 'Index' object_type,
                   owner,
                   tablespace_name,
                   index_name object_name
              from dba_indexes)
     where     tablespace_name = 'SYSTEM'
           and owner not in
                  ('ANONYMOUS',
                   'BI',
                   'CTXSYS',
                   'DBSNMP',
                   'DIP',
                   'DMSYS',
                   'EXFSYS',
                   'HR',
                   'IX',
                   'LBACSYS',
                   'MDDATA',
                   'MDSYS',
                   'MGMT_VIEW',
                   'OE',
                   'OLAPSYS',
                   'ORDPLUGINS',
                   'ORDSYS',
                   'OUTLN',
                   'PM',
                   'SCOTT',
                   'SH',
                   'SI_INFORMTN_SCHEMA',
                   'SYS',
                   'SYSMAN',
                   'SYSTEM',
                   'WMSYS',
                   'WKPROXY',
                   'WK_TEST',
                   'WKSYS',
                   'XDB',
                   'APEX_030200',
                   'APEX_PUBLIC_USER',
                   'APPQOSSYS',
                   'DVSYS',
                   'FLOWS_FILES',
                   'IX',
                   'LBACSYS',
                   'ORACLE_OCM',
                   'OWBSYS',
                   'OWBSYS_AUDIT',
                   'SPATIAL_CSW_ADMIN_USR',
                   'SPATIAL_WFS_ADMIN_USR');
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#object">Back to Objects Information</a>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                                  Directory                                 |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="65"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Directory Information</b></font>-
    <br>
     
    -- Directory List
     
    prompt <font size="2pt"><b>Directory List</b></font>
     
    clear columns breaks computes
        
    column owner          format a30  heading 'Owner'          print entmap off
    column directory_name format a30  heading 'Directory Name' print entmap off 
    column directory_path format a100 heading 'Directory Path' print entmap off
     
    break on report on owner
     
      select owner,
             directory_name,
             directory_path
        from dba_directories
    order by owner,directory_name;
     
    -- Directory Privilege
     
    prompt <font size="2pt"><b>Directory Privilege</b></font>
     
    clear columns breaks computes
     
    column table_name    format a30 heading 'Directory Name' print entmap off
    column grantee       format a30 heading 'Grantee'        print entmap off
    column privilege     format a9  heading 'Privilege'      print entmap off
    column grantable     format a9  heading 'Grantable'      print entmap off
     
    break on report on table_name on grantee
     
      select table_name,
             grantee,
             privilege,
             grantable
        from dba_tab_privs
       where privilege in ('READ', 'WRITE')
    order by table_name, grantee, privilege;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#object">Back to Objects Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                                 Recyclebin                                 |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="66"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Recyclebin</b></font>
     
    clear columns breaks computes
     
    column owner               heading 'Owner'       print entmap off  
    column type  format a50    heading 'Object Type' print entmap off  
    column count format 999999 heading 'Count' print entmap off
     
    break on report on owner
    compute sum label 'Total:' of count on report
     
      select owner,type,count(*) count 
        from dba_recyclebin 
    group by owner,type;
     
    /*
    column owner                            heading 'Owner'         print entmap off  
    column original_name                    heading 'Original Name' print entmap off  
    column type          format a50         heading 'Object Type'   print entmap off  
    column object_name   format a50         heading 'Object Name'   print entmap off  
    column ts_name       format a50         heading 'Tablespace'    print entmap off  
    column operation     format a9          heading 'Operation'     print entmap off  
    column createtime    format a19         heading 'Create Time'   print entmap off  
    column droptime      format a19         heading 'Drop Time'     print entmap off  
    column can_undrop    format a10         heading 'Can Undrop'    print entmap off 
    column can_purge     format a9          heading 'Can Purge'     print entmap off 
    column size_mb       format 999,990.99  heading 'Size_MB'       print entmap off    
     
    break on report on owner
    compute count label 'Count:' of original_name on report
     
      select owner,
             original_name,
             type,
             object_name,
             ts_name,
             operation,
             createtime,
             droptime,
             can_undrop,
             can_purge,
             round((space * p.blocksize) / 1024 / 1024,2) as "size_mb"
        from dba_recyclebin r,
             (select value blocksize
                from v$parameter
               where name = 'db_block_size') p
    order by owner, object_name;
    */
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#object">Back to Objects Information</a>
    prompt <a href="#top">Back to Top</a>
    prompt <br />
     
    -- ==============================================================================
    --                                     Jobs                              
    -- ==============================================================================
     
    prompt <a name="job"></a>
    prompt <font size="+2" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Jobs</b></font>
     
    clear columns breaks computes
     
    column job        format 999999  heading 'Job ID'         
    column log_user   format a30     heading 'Log User'           
    column what       format a150    heading 'What'           
    column next_date  format a19     heading 'Next Date'  
    column interval   format a10     heading 'Interval'       
    column last_date  format a19     heading 'Last Date'  
    column failures   format 999999  heading 'Failures'       
    column broken     format a6      heading 'Broken'        
     
      select job,
             log_user,
             what,
             next_date,
             interval,
             last_date,
             failures,
             broken
        from dba_jobs
    order by job;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#job">Back to Jobs Information</a>
    prompt <a href="#top">Back to Top</a>
    prompt <br />
     
    -- ==============================================================================
    --                                    Backup                                  
    -- ==============================================================================
     
    prompt <a name="backup"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Backup Information</b></font>
    prompt <ul>-
    <li><a href='#71'>RMAN Backup Job</a></li>-
    <li><a href='#72'>RMAN Configure</a></li>-
    <li><a href='#73'>RMAN Backupset</a></li>-
    <li><a href='#74'>RMAN Backup Piece</a></li>-
    <li><a href='#75'>RMAN Backup Controlfile</a></li>-
    <li><a href='#76'>RMAN Backup Spfile</a></li>-
    <li><a href='#77'>Archive Log List</a></li>-
    </ul>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                              RMAN Backup Job                               |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="71"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>RMAN Backup Job</b></font>
     
    clear columns breaks computes
           
    column backup_name         format a19 heading 'Backup Name'   print entmap off    
    column start_time          format a19 heading 'Start Time'    print entmap off    
    column elapsed_time        format a12 heading 'Elapsed Time'  print entmap off    
    column status              format a30 heading 'Status'        print entmap off    
    column input_type          format a30 heading 'Input Type'    print entmap off    
    column output_device_type  format a11 heading 'Output Type'   print entmap off 
    column input_size          format a10 heading 'Input Size'    print entmap off    
    column output_size         format a11 heading 'Output Size'   print entmap off    
    column output_rate_per_sec format a13 heading 'Output Rate/s' print entmap off
     
    select r.command_id                                   backup_name,
           to_char(r.start_time, 'YYYY-MM-DD HH24:MI:SS') start_time,
           r.time_taken_display                           elapsed_time,
           decode(r.status,'COMPLETED',r.status,'<div align="left"><font color="red">' || r.status || '</font></div>') status,
           r.input_type                                   input_type,
           r.output_device_type                           output_device_type,
           r.input_bytes_display                          input_size,
           r.output_bytes_display                         output_size,
           r.output_bytes_per_sec_display                 output_rate_per_sec
      from 
           ( select command_id,start_time,time_taken_display,status,input_type,output_device_type,input_bytes_display,output_bytes_display,output_bytes_per_sec_display
               from v$rman_backup_job_details
           order by start_time desc
           ) r;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#backup">Back to Backup Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                              RMAN Configure                                |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="72"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>RMAN Configure</b></font>
     
    clear columns breaks computes
     
    column name  format a150 heading 'name'  print entmap off 
    column value format a150 heading 'value' print entmap off
     
    select name,value
      from v$rman_configuration;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#backup">Back to Backup Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                              RMAN Backupset                                |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="73"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>RMAN Backupset</b></font>
     
    clear columns breaks computes
     
    column bs_key               format 999,999             heading 'BS Key'               
    column backup_type          format a20                 heading 'Backup Type'          
    column device_type          format a11                 heading 'Device Type'          
    column controlfile_included format a20                 heading 'Controlfile Included'
    column spfile_included      format a15                 heading 'SPFILE Included'     
    column incremental_level    format 999                 heading 'Incremental Level'    
    column pieces               format 999,999             heading 'Pieces#'          
    column start_time           format a19                 heading 'Start Time'           
    column completion_time      format a19                 heading 'End Time'             
    column elapsed_seconds      format 999,999,999,999     heading 'Elapsed Seconds'      
    column tag                  format a18                 heading 'Tag'                  
    column block_size           format 999,999,999         heading 'Block Size'           
    column keep                 format a4                  heading 'Keep'                
    column keep_until           format a19                 heading 'Keep Until'           
    column keep_options         format a12                 heading 'Keep Options'         
     
    break on report
    compute sum label 'Total:' of pieces elapsed_seconds on report
     
      select bs.recid bs_key,
             decode (backup_type,'L', 'Archived Redo Logs','D', 'Datafile Full Backup','I', 'Incremental Backup') backup_type,
             device_type,
             decode (bs.controlfile_included, 'NO', '-', bs.controlfile_included) controlfile_included,
             nvl (sp.spfile_included, '-') spfile_included,
             bs.incremental_level,
             bs.pieces,
             to_char (bs.start_time, 'YYYY-MM-DD HH24:MI:SS') start_time,
             to_char (bs.completion_time, 'YYYY-MM-DD HH24:MI:SS') completion_time,
             bs.elapsed_seconds,
             bp.tag,
             bs.block_size,
             bs.keep,
             to_char (bs.keep_until, 'YYYY-MM-DD HH24:MI:SS') keep_until,
             bs.keep_options
        from v$backup_set bs,
             (select distinct set_stamp,
                              set_count,
                              tag,
                              device_type
                from v$backup_piece
               where status in ('A', 'X')) bp,
             (select distinct set_stamp, set_count, 'YES' spfile_included
                from v$backup_spfile) sp
       where     bs.set_stamp = bp.set_stamp
             and bs.set_count = bp.set_count
             and bs.set_stamp = sp.set_stamp(+)
             and bs.set_count = sp.set_count(+)
    order by bs.recid;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#backup">Back to Backup Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                             RMAN Backup Piece                              |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="74"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>RMAN Backup Piece</b></font>
     
    clear columns breaks computes
     
    column bs_key          format 999,999         heading 'BS Key'          print entmap off
    column piece#          format 999,999         heading 'Piece#'          print entmap off
    column copy#           format 999,999         heading 'Copy#'           print entmap off
    column bp_key          format 999,999         heading 'BP Key'          print entmap off
    column status          format a30             heading 'Status'          print entmap off
    column handle          format a150            heading 'Handle'          print entmap off
    column start_time      format a19             heading 'Start Time'      print entmap off
    column completion_time format a19             heading 'End Time'        print entmap off
    column elapsed_seconds format 999,999,999,999 heading 'Elapsed Seconds' print entmap off     
     
    break on bs_key
     
      select bs.recid bs_key,
             bp.piece#,
             bp.copy#,
             bp.recid bp_key,
             decode (bp.status, 'A', 'Available', 
                     'D', '<div align="left"><font color="red">' || 'Deleted' || '</font></div>',
                     'X', '<div align="left"><font color="red">' || 'Expired' || '</font></div>') status,
             bp.handle,
             to_char (bp.start_time, 'YYYY-MM-DD HH24:MI:SS') start_time,
             to_char (bp.completion_time, 'YYYY-MM-DD HH24:MI:SS') completion_time,
             bp.elapsed_seconds
        from v$backup_set bs, v$backup_piece bp
       where     bs.set_stamp = bp.set_stamp
             and bs.set_count = bp.set_count
             and bp.status in ('A', 'X')
    order by bs.recid, piece#;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#backup">Back to Backup Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                            RMAN Backup Controlfile                         |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="75"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>RMAN Backup Controlfile</b></font>
     
    clear columns breaks computes
     
    column bs_key               format 999,999      heading 'BS Key'               print entmap off
    column piece#               format 999,999      heading 'Piece#'               print entmap off
    column copy#                format 999,999      heading 'Copy#'                print entmap off
    column bp_key               format 999,999      heading 'BP Key'               print entmap off
    column controlfile_included format a20          heading 'Controlfile Included' print entmap off
    column status               format a30          heading 'Status'               print entmap off
    column handle               format a150         heading 'Handle'               print entmap off
    column start_time           for a19             heading 'Start Time'           print entmap off
    column completion_time      for a19             heading 'End Time'             print entmap off
    column elapsed_seconds      for 999,999,999,999 heading 'Elapsed Seconds'      print entmap off           
     
    break on bs_key
     
      select bs.recid bs_key,
             bp.piece#,
             bp.copy#,
             bp.recid bp_key,
             decode (bs.controlfile_included, 'NO', '-', bs.controlfile_included) controlfile_included,
             decode (bp.status, 'A', 'Available', 
                     'D', '<div align="left"><font color="red">' || 'Deleted' || '</font></div>',
                     'X', '<div align="left"><font color="red">' || 'Expired' || '</font></div>') status,
             handle
        from v$backup_set bs, v$backup_piece bp
       where     bs.set_stamp = bp.set_stamp
             and bs.set_count = bp.set_count
             and bp.status in ('A', 'X')
             and bs.controlfile_included != 'NO'
    order by bs.recid, piece#;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#backup">Back to Backup Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                            RMAN Backup Spfile                              |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="76"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>RMAN Backup Spfile</b></font>
     
    clear columns breaks computes
     
    column bs_key          format 999,999         heading 'BS Key'          print entmap off
    column piece#          format 999,999         heading 'Piece#'          print entmap off
    column copy#           format 999,999         heading 'Copy#'           print entmap off
    column bp_key          format 999,999         heading 'BP Key'          print entmap off
    column spfile_included format a15             heading 'SPFILE Included' print entmap off
    column status          format a30             heading 'Status'          print entmap off
    column handle          format a150            heading 'Handle'          print entmap off
    column start_time      format a19             heading 'Start Time'      print entmap off
    column completion_time format a19             heading 'End Time'        print entmap off
    column elapsed_seconds format 999,999,999,999 heading 'Elapsed Seconds' print entmap off
           
    break on bs_key
     
      select bs.recid bs_key,
             bp.piece#,
             bp.copy#,
             bp.recid bp_key,
             nvl (sp.spfile_included, '-') spfile_included,
             decode (bp.status, 'A', 'Available', 
                     'D', '<div align="left"><font color="red">' || 'Deleted' || '</font></div>',
                     'X', '<div align="left"><font color="red">' || 'Expired' || '</font></div>') status,
             handle
        from v$backup_set bs,
             v$backup_piece bp,
             (select distinct set_stamp, set_count, 'YES' spfile_included
                from v$backup_spfile) sp
       where     bs.set_stamp = bp.set_stamp
             and bs.set_count = bp.set_count
             and bp.status in ('A', 'X')
             and bs.set_stamp = sp.set_stamp
             and bs.set_count = sp.set_count
    order by bs.recid, piece#;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#backup">Back to Backup Information</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                                Archive Mode                                |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="77"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Archive Log List</b></font>
     
    clear columns breaks computes
     
    column inst_id                    format 999             heading 'Inst_ID'                    entmap off
    column log_mode                   format a15             heading 'Database Log Mode'          entmap off
    column log_archive_start          format a20             heading 'Automatic Archival'         entmap off
    column oldest_online_log_sequence format 999999999999999 heading 'Oldest Online Log Sequence' entmap off
    column current_log_sequence       format 999999999999999 heading 'Current Log Sequence'       entmap off
    column destination                format a80             heading 'Archive Destination'        entmap off
     
    select a.inst_id,
           d.log_mode,
           p.log_archive_start,
           a.destination,
           o.oldest_online_log_sequence,
           c.current_log_sequence
      from (select decode (log_mode,'ARCHIVELOG', 'Archive Mode','NOARCHIVELOG', 'No Archive Mode',log_mode) log_mode
              from v$database) d,
           (select decode (log_mode,'ARCHIVELOG', 'Enabled','NOARCHIVELOG', 'Disabled') log_archive_start
              from v$database) p,
           (select inst_id,destination 
              from gv$archive_dest
             where status='VALID' and inst_id = 1) a,
           (select sequence# current_log_sequence
              from v$log
             where status = 'CURRENT' and thread# = 1) c,
           (select min (sequence#) oldest_online_log_sequence
              from v$log where thread# = 1 ) o
    union all   
    select a.inst_id, 
           d.log_mode,
           p.log_archive_start,
           a.destination,
           o.oldest_online_log_sequence,
           c.current_log_sequence
      from (select decode (log_mode,'ARCHIVELOG', 'Archive Mode','NOARCHIVELOG', 'No Archive Mode',log_mode) log_mode
              from v$database) d,
           (select decode (log_mode,'ARCHIVELOG', 'Enabled','NOARCHIVELOG', 'Disabled') log_archive_start
              from v$database) p,
           (select inst_id,destination 
              from gv$archive_dest
             where status='VALID' and inst_id = 2) a,
           (select sequence# current_log_sequence
              from v$log
             where status = 'CURRENT' and thread# = 2) c,
           (select min (sequence#) oldest_online_log_sequence
              from v$log where thread# = 2 ) o
    union all
    select a.inst_id, 
           d.log_mode,
           p.log_archive_start,
           a.destination,
           o.oldest_online_log_sequence,
           c.current_log_sequence
      from (select decode (log_mode,'ARCHIVELOG', 'Archive Mode','NOARCHIVELOG', 'No Archive Mode',log_mode) log_mode
              from v$database) d,
           (select decode (log_mode,'ARCHIVELOG', 'Enabled','NOARCHIVELOG', 'Disabled') log_archive_start
              from v$database) p,
           (select inst_id,destination 
              from gv$archive_dest
             where status='VALID' and inst_id = 3) a,
           (select sequence# current_log_sequence
              from v$log
             where status = 'CURRENT' and thread# = 3) c,
           (select min (sequence#) oldest_online_log_sequence
              from v$log where thread# = 3 ) o
    union all
    select a.inst_id, 
           d.log_mode,
           p.log_archive_start,
           a.destination,
           o.oldest_online_log_sequence,
           c.current_log_sequence
      from (select decode (log_mode,'ARCHIVELOG', 'Archive Mode','NOARCHIVELOG', 'No Archive Mode',log_mode) log_mode
              from v$database) d,
           (select decode (log_mode,'ARCHIVELOG', 'Enabled','NOARCHIVELOG', 'Disabled') log_archive_start
              from v$database) p,
           (select inst_id,destination 
              from gv$archive_dest
             where status='VALID' and inst_id = 4) a,
           (select sequence# current_log_sequence
              from v$log
             where status = 'CURRENT' and thread# = 4) c,
           (select min (sequence#) oldest_online_log_sequence
              from v$log where thread# = 4 ) o;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#backup">Back to Backup Information</a>
    prompt <a href="#top">Back to Top</a>
    prompt <br />
     
    -- ==============================================================================
    --                            Performance Statistics                         
    -- ==============================================================================
     
    prompt <a name="performance"></a>
    prompt <font size="+2" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Performance Statistics</b></font>
    prompt <ul>-
    <li><a href='#81'>Statistics Level</a></li>-
    <li><a href='#82'>10g Gather Stats Job Information</a></li>-
    <li><a href='#83'>11g Gather Stats Job Information</a></li>-
    <li><a href='#84'>Objects Without Statistics Within 30 Days</a></li>-
    <li><a href='#85'>Resource Limit</a></li>-
    <li><a href='#86'>AWR Setting</a></li>-
    </ul>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                            STATISTICS LEVEL                                |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="81"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Statistics Level</b></font>
     
    clear columns breaks computes
     
    column instance_name        format a95 heading 'Instance'             entmap off
    column statistics_name      format a95 heading 'Statistics Name'      entmap off
    column session_status       format a95 heading 'Session Status'       entmap off
    column system_status        format a95 heading 'System Status'        entmap off
    column activation_level     format a95 heading 'Activation Level'     entmap off
    column statistics_view_name format a95 heading 'Statistics View Name' entmap off
    column session_settable     format a95 heading 'Session Settable'     entmap off
     
    break on report on instance_name
     
      select i.instance_name,
             s.statistics_name,
             s.session_status,
             s.system_status,
             s.activation_level,
             s.statistics_view_name,
             s.session_settable
        from gv$statistics_level s, gv$instance i
       where s.inst_id = i.inst_id
    order by i.instance_name, s.statistics_name;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#performance">Back to Performance Statistics</a>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                             Optimizer Job(10g)                             |
    -- +----------------------------------------------------------------------------+
     
    -- 10g,gather statistics job
    prompt <a name="82"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>10g Gather Stats Job Information</b></font>
     
    clear columns breaks computes
     
    column owner      format a30 heading 'Owner'      print entmap off
    column job_name   format a30 heading 'Job Name'   print entmap off
    column job_action format a30 heading 'Job Action' print entmap off
    column enabled    format a15 heading 'Enable'     print entmap off
    column state      format a15 heading 'State'      print entmap off
     
    select owner,
           job_name,
           job_action,
           enabled,
           state
      from dba_scheduler_jobs
     where job_name = 'GATHER_STATS_JOB';
     
    ---- For 10g gather_stats_job runing details 
     
    clear columns breaks computes
     
    column owner           format a6  heading 'Owner'           print entmap off
    column job_name        format a20 heading 'Job Name'        print entmap off
    column status          format a15 heading 'Status'          print entmap off
    column additional_info format a20 heading 'Additional Info' print entmap off
    column run_duration    format a10 heading 'Run Duration'    print entmap off
    column instance_id     format 99  heading 'Inst ID'         print entmap off
    column session_id      format a10 heading 'Session ID'      print entmap off
    column start_date      format a25 heading 'Start Time'      print entmap off
    column end_date        format a25 heading 'End Time'        print entmap off
    column error#          format 999 heading 'Error#'          print entmap off
     
      select instance_id,
             session_id,
             owner,
             job_name,
             status,
             error#,
             additional_info,
             to_char (actual_start_date, 'YYYY-MM-DD HH24:MI:SS') start_date,
             to_char (log_date, 'YYYY-MM-DD HH24:MI:SS') end_date,
             run_duration
             --( extract (day from run_duration)*24*60 + extract (hour from run_duration)*60 + extract (minute from run_duration)) + extract (second from run_duration)/60  "Run_Duration(Min)"
        from dba_scheduler_job_run_details
       where job_name = 'GATHER_STATS_JOB'
    order by log_id;
     
    ---- For 10g,Check gather stats windows
     
    clear columns breaks computes
     
    column window_group_name heading 'Window Group Name' print entmap off
    column window_name       heading 'Window Name'       print entmap off
     
    break on window_group_name on window_name;
     
    select window_group_name, 
           window_name
      from dba_scheduler_wingroup_members
     where window_group_name = 'MAINTENANCE_WINDOW_GROUP' 
    having (select substr(version,1,2) from v$instance) = '10';
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#performance">Back to Performance Statistics</a>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                             Optimizer Job(11g)                             |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="83"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>11g Gather Stats Job Information</b></font>-
    <br>
     
    -- On Oracle 10g,not exists table dba_autotask_client and dba_autotask_client_history
    -- Below 2 query will raise error:table or view does not exist
    -- Please ignore this error.
     
    prompt <font size="1pt"><b> On Oracle 10g,not exists table dba_autotask_client and dba_autotask_client_history.</b></font>
     
    prompt <font size="1pt"><b> This query only for 11g, please ignore the query errors on oracle 10g.</b></font>
     
    -- 11g,gather statistics job
     
    clear columns breaks computes
     
    column client_name heading 'Client Name' print entmap off
    column status      heading 'Status'      print entmap off
     
    select client_name, 
           status 
      from dba_autotask_client;
     
    -- 11g gather_stats_job runing details 
     
    clear columns breaks computes
     
    break on client_name
     
    column client_name     format a60 heading 'Client Name'    print entmap off
    column window_name     format a60 heading 'Window Nmae'    print entmap off
    column jobs_created               heading 'Jobs Created'   print entmap off
    column jobs_started               heading 'Jobs Started'   print entmap off
    column jobs_completed             heading 'Jobs Completed' print entmap off
    column start_time      format a20 heading 'Start Time'     print entmap off
    column end_time        format a20 heading 'End Time'       print entmap off
    column window_duration            heading 'Run Duration'   print entmap off
     
    select client_name,
           window_name,
           jobs_created,
           jobs_started,
           jobs_completed,
           to_char(window_start_time,'YYYY-MM-DD HH24:MI:SS') start_time,
           to_char(window_end_time,'YYYY-MM-DD HH24:MI:SS') end_time,
           window_duration
      from dba_autotask_client_history
     where client_name = 'auto optimizer stats collection';
     
    /* 
    -- PL/SQL display the table (dba_autotask_client and dba_autotask_client_history) information that not exists in 10g without raise any errors
    -- Use PL/SQL Intead of 2 query above.
     
    declare
       v_version           varchar2 (5);
     
       type c_type is ref cursor;
     
       v_c1                c_type;
       v_c2                c_type;
       sql_a               varchar2 (100);
       sql_b               varchar2 (4000);
       v_client_name       varchar2 (100);
       v_status            varchar2 (100);
       v_client            varchar2 (100);
       v_window_name       varchar2 (100);
       v_jobs_created      number;
       v_jobs_started      number;
       v_jobs_completed    number;
       v_start_time        char (19);
       v_end_time          char (19);
       v_window_duration   interval day (9) to second (6);
    begin
       sql_a := 'select client_name, status from dba_autotask_client';
     
       sql_b :=
          'select client_name client,
           window_name,
           jobs_created,
           jobs_started,
           jobs_completed,
           to_char(window_start_time,''YYYY-MM-DD HH24:MI:SS'') start_time,
           to_char(window_end_time,''YYYY-MM-DD HH24:MI:SS'') end_time,
           window_duration
      from dba_autotask_client_history
     where client_name = ''auto optimizer stats collection''';
     
       select substr (version, 1, 2) into v_version from v$instance;
     
       if v_version = '11'
       then
          --dbms_output.put_line (v_version);
     
          -- table sql_a
          dbms_output.put ('<table>');
          dbms_output.put (
                '<tr>'
             || '<th>'
             || 'Client Name'
             || '</th>'
             || '<th>'
             || 'Status'
             || '</th>'
             || '</tr>');
     
          open v_c1 for sql_a;
     
          loop
             fetch v_c1
                into v_client_name, v_status;
     
             exit when v_c1%notfound;
             dbms_output.put (
                   '<tr>'
                || '<td>'
                || v_client_name
                || '</td>'
                || '<td>'
                || v_status
                || '</td>'
                || '</tr>');
          end loop;
     
          dbms_output.put_line ('</table>');
     
          -- table sql_b
          dbms_output.put ('<table>');
          dbms_output.put_line (
                '<tr>'
             || '<th>'
             || 'Client Name'
             || '</th>'
             || '<th>'
             || 'Window Name'
             || '</th>'
             || '<th>'
             || 'Jobs Created'
             || '</th>'
             || '<th>'
             || 'Jobs Started'
             || '</th>'
             || '<th>'
             || 'Jobs Completed'
             || '</th>'
             || '<th>'
             || 'Start Time'
             || '</th>'
             || '<th>'
             || 'End Time'
             || '</th>'
             || '<th>'
             || 'Window Duration'
             || '</th>'
             || '</tr>');
     
          open v_c2 for sql_b;
     
          loop
             fetch v_c2
                into v_client,
                     v_window_name,
                     v_jobs_created,
                     v_jobs_started,
                     v_jobs_completed,
                     v_start_time,
                     v_end_time,
                     v_window_duration;
     
             exit when v_c2%notfound;
             dbms_output.put_line (
                   '<tr>'
                || '<td>'
                || v_client
                || '</td>'
                || '<td>'
                || v_window_name
                || '</td>'
                || '<td>'
                || v_jobs_created
                || '</td>'
                || '<td>'
                || v_jobs_started
                || '</td>'
                || '<td>'
                || v_jobs_completed
                || '</td>'
                || '<td>'
                || v_start_time
                || '</td>'
                || '<td>'
                || v_end_time
                || '</td>'
                || '<td>'
                || v_window_duration
                || '</td>');
          end loop;
     
          dbms_output.put_line ('</table>');
       end if;
    end;
    /
    */
     
     
    clear columns breaks computes
     
    column window_group_name heading 'Window Group Name' print entmap off
    column window_name       heading 'Window Name'       print entmap off
     
    break on window_group_name on window_name
     
    select window_group_name,
           window_name
      from dba_scheduler_wingroup_members
     where window_group_name = 'ORA$AT_WGRP_OS';
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#performance">Back to Performance Statistics</a>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                             Statistics Collect                             |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="84"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Objects Whitout Statistics Within 60 Days</b></font>
     
    -- Stats the objects those not collect statistics within 60 days
     
    clear columns breaks computes
             
    column object_type heading 'Object Type' print entmap off 
    column owner       heading 'Owner'       print entmap off
    column object_name heading 'Object Name' print entmap off
     
    break on object_type skip 1 on owner on report
    compute count label 'Count By Object Type:' of object_name on object_type
    compute count label 'Count All:'     of object_name on report
     
    select object_type, owner, object_name
      from (select 'Table' object_type, owner, table_name object_name
              from dba_tables
             where last_analyzed < sysdate - 60 and partitioned = 'NO'
            union all
            select 'Index' object_type, owner, index_name object_name
              from dba_indexes
             where last_analyzed < sysdate - 60 and partitioned = 'NO'
            union all
            select 'Partition Table' object_type, owner, table_name object_name
              from dba_tables
             where last_analyzed < sysdate - 60 and partitioned = 'YES'
            union all
            select 'Partition Index' object_type, owner, index_name object_name
              from dba_indexes
             where last_analyzed < sysdate - 60 and partitioned = 'YES')
     where owner not in
              ('ANONYMOUS',
               'BI',
               'CTXSYS',
               'DBSNMP',
               'DIP',
               'DMSYS',
               'EXFSYS',
               'HR',
               'IX',
               'LBACSYS',
               'MDDATA',
               'MDSYS',
               'MGMT_VIEW',
               'OE',
               'OLAPSYS',
               'ORDPLUGINS',
               'ORDSYS',
               'OUTLN',
               'PM',
               'SCOTT',
               'SH',
               'SI_INFORMTN_SCHEMA',
               'SYS',
               'SYSMAN',
               'SYSTEM',
               'WMSYS',
               'WKPROXY',
               'WK_TEST',
               'WKSYS',
               'XDB',
               'APEX_030200',
               'APEX_PUBLIC_USER',
               'APPQOSSYS',
               'DVSYS',
               'FLOWS_FILES',
               'IX',
               'LBACSYS',
               'ORACLE_OCM',
               'OWBSYS',
               'OWBSYS_AUDIT',
               'SPATIAL_CSW_ADMIN_USR',
               'SPATIAL_WFS_ADMIN_USR');
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#performance">Back to Performance Statistics</a>
    prompt <a href="#top">Back to Top</a>
     
    prompt <a name="85"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Resource Limit</b></font>         
     
    -- Resource limit
    clear columns breaks computes
     
    column resource_name       format a50         heading 'Resource Name'       print entmap off
    column current_utilization format 999,999,999 heading 'Current Utilization' print entmap off
    column max_utilization     format 999,999,999 heading 'Max Utilization'     print entmap off
    column initial_allocation  format a20         heading 'Initial Allocation'  print entmap off
    column limit_value         format a20         heading 'Limit Value'         print entmap off
     
    select resource_name,
           current_utilization,
           max_utilization,
           initial_allocation,
           limit_value
      from v$resource_limit;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#performance">Back to Performance Statistics</a>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                                 AWR Setting                                |
    -- +----------------------------------------------------------------------------+
     
    prompt <a name="86"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>AWR Setting</b></font>  
     
    clear columns breaks computes
     
    column dbid heading 'DBID' print entmap off
    column snap_interval heading 'Interval' print entmap off
    column retention heading 'Retention' print entmap off
    column topnsql heading 'TopN SQL' print entmap off
     
    select dbid, snap_interval, retention, topnsql
      from dba_hist_wr_control;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#performance">Back to Performance Statistics</a>
    prompt <a href="#top">Back to Top</a>
    prompt <br />
     
    -- ==============================================================================
    --                             Initialization Parameters                                  
    -- ==============================================================================
     
    prompt <a name="parameter"></a>
    prompt <font size="+2" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Initialization Parameters</b></font>
    prompt <ul>-
    <li><a href='#91'>Not Default Init Parameters</a></li>-
    <li><a href='#92'>All Database Initialization Parameters</a></li>-
    </ul>
    prompt <a href="#top">Back to Top</a>
     
    -- +----------------------------------------------------------------------------+
    -- |                    Not Default Initialization Parameters                   |
    -- +----------------------------------------------------------------------------+
    -- Not default init parameters 
     
    prompt <a name="91"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>Not Default Initialization Parameters</b></font>
     
    clear columns breaks computes
     
    column instance  format a20  heading 'Instance'  print entmap off
    column name      format a50  heading 'Name'      print entmap off
    column value     format a300 heading 'Value'     print entmap off
    column isdefault format a10  heading 'Isdefault' print entmap off
     
    break on instance 
     
    select i.instance_name instance,
           p.name,
           p.value,
           p.isdefault
      from gv$parameter p,
           gv$instance i
     where    p.inst_id = i.inst_id
          and isdefault = 'FALSE';
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#parameter">Back to Initialization Parameters</a>
    prompt <a href="#top">Back to Top</a>
    --prompt <br />
     
    -- +----------------------------------------------------------------------------+
    -- |                  All Database Initialization Parameters                    |
    -- +----------------------------------------------------------------------------+ 
     
    prompt <a name="92"></a>
    prompt <font size="+1" face="Arial,Helvetica,Geneva,sans-serif" color="#336699"><b>All Database Initialization Parameters</b></font>
     
      select ksppinm name,ksppstvl value
        from x$ksppi a,x$ksppcv b
       where a.indx = b.indx
    order by name;
     
    prompt <hr align="left" size="1" color="Gray" width="20%" />-
    <a href="#parameter">Back to Initialization Parameters</a>
    prompt <a href="#top">Back to Top</a>
    prompt <br />
     
     
    -- ==============================================================================
    --                                 End Of Report                                
    -- ==============================================================================
     
    prompt <div align="right">-
    <font size="-1" face="Arial,Helvetica,Geneva,sans-serif" color="gray">-
    <hr size="2" color="Gray" align="right" noshade/>-
    <b>Database Health Check Snapshot</b><br><b>Copyright (c) 2015 Stephen Zhao. All Rights Reserved</b>-
    </font>-
    </div>
     
    spool off
     
    set markup html off
     
    set termout on
     
    prompt 
    prompt Output written to: &filename._&_dbname._&_spool_time..html
    prompt
     
    exit;
  • 相关阅读:
    mobile web retina 下 1px 边框解决方案
    git基础操作
    JavaScript词法分析
    JS给元素循环添加事件的问题
    useMemo优化React Hooks程序性能,解决子组件重复执行问题
    使用 useReducer 和 useCallback 解决 useEffect 依赖诚实与方法内置&外置问题
    createContext 和 useContext 结合使用实现方法共享(React Hook跨组件透传上下文与性能优化)
    浅谈开发变量作用域---小坑
    优雅的在React项目中使用Redux
    浅谈react无状态组件(哑组件)和有状态组件(智能组件)的区别
  • 原文地址:https://www.cnblogs.com/l10n/p/9410619.html
Copyright © 2011-2022 走看看