78 lines
3.4 KiB
MySQL
78 lines
3.4 KiB
MySQL
|
|
-- +----------------------------------------------------------------------------+
|
||
|
|
-- | Jeffrey M. Hunter |
|
||
|
|
-- | jhunter@idevelopment.info |
|
||
|
|
-- | www.idevelopment.info |
|
||
|
|
-- |----------------------------------------------------------------------------|
|
||
|
|
-- | Copyright (c) 1998-2012 Jeffrey M. Hunter. All rights reserved. |
|
||
|
|
-- |----------------------------------------------------------------------------|
|
||
|
|
-- | DATABASE : Oracle |
|
||
|
|
-- | FILE : rman_controlfiles.sql |
|
||
|
|
-- | CLASS : Recovery Manager |
|
||
|
|
-- | PURPOSE : Provide a listing of automatically backed up control files. |
|
||
|
|
-- | NOTE : As with any code, ensure to test this script in a development |
|
||
|
|
-- | environment before attempting to run it in production. |
|
||
|
|
-- +----------------------------------------------------------------------------+
|
||
|
|
|
||
|
|
SET TERMOUT OFF;
|
||
|
|
COLUMN current_instance NEW_VALUE current_instance NOPRINT;
|
||
|
|
SELECT rpad(instance_name, 17) current_instance FROM v$instance;
|
||
|
|
SET TERMOUT ON;
|
||
|
|
|
||
|
|
PROMPT
|
||
|
|
PROMPT +------------------------------------------------------------------------+
|
||
|
|
PROMPT | Report : RMAN Control Files |
|
||
|
|
PROMPT | Instance : ¤t_instance |
|
||
|
|
PROMPT | Note : Available automatic control files within all available |
|
||
|
|
PROMPT | (and expired) backup sets. |
|
||
|
|
PROMPT +------------------------------------------------------------------------+
|
||
|
|
|
||
|
|
SET ECHO OFF
|
||
|
|
SET FEEDBACK 6
|
||
|
|
SET HEADING ON
|
||
|
|
SET LINESIZE 180
|
||
|
|
SET PAGESIZE 50000
|
||
|
|
SET TERMOUT ON
|
||
|
|
SET TIMING OFF
|
||
|
|
SET TRIMOUT ON
|
||
|
|
SET TRIMSPOOL ON
|
||
|
|
SET VERIFY OFF
|
||
|
|
|
||
|
|
CLEAR COLUMNS
|
||
|
|
CLEAR BREAKS
|
||
|
|
CLEAR COMPUTES
|
||
|
|
|
||
|
|
COLUMN bs_key FORMAT 9999 HEADING 'BS|Key'
|
||
|
|
COLUMN piece# FORMAT 99999 HEADING 'Piece|#'
|
||
|
|
COLUMN copy# FORMAT 9999 HEADING 'Copy|#'
|
||
|
|
COLUMN bp_key FORMAT 9999 HEADING 'BP|Key'
|
||
|
|
COLUMN controlfile_included FORMAT a11 HEADING 'Controlfile|Included?'
|
||
|
|
COLUMN completion_time FORMAT a20 HEADING 'Completion|Time'
|
||
|
|
COLUMN status FORMAT a9 HEADING 'Status'
|
||
|
|
COLUMN handle FORMAT a75 HEADING 'Handle'
|
||
|
|
|
||
|
|
BREAK ON bs_key
|
||
|
|
|
||
|
|
SELECT
|
||
|
|
bs.recid bs_key
|
||
|
|
, bp.piece# piece#
|
||
|
|
, bp.copy# copy#
|
||
|
|
, bp.recid bp_key
|
||
|
|
, DECODE( bs.controlfile_included
|
||
|
|
, 'NO', '-'
|
||
|
|
, bs.controlfile_included) controlfile_included
|
||
|
|
, TO_CHAR(bs.completion_time, 'mm/dd/yyyy HH24:MI:SS') completion_time
|
||
|
|
, DECODE( status
|
||
|
|
, 'A', 'Available'
|
||
|
|
, 'D', 'Deleted'
|
||
|
|
, 'X', 'Expired') status
|
||
|
|
, handle handle
|
||
|
|
FROM
|
||
|
|
v$backup_set bs JOIN v$backup_piece bp USING (set_stamp,set_count)
|
||
|
|
WHERE
|
||
|
|
bp.status IN ('A', 'X')
|
||
|
|
AND bs.controlfile_included != 'NO'
|
||
|
|
ORDER BY
|
||
|
|
bs.recid
|
||
|
|
, piece#
|
||
|
|
/
|