Wednesday, 24 December 2014

Tablespace Monitor Sql Scripts

ALL TABLESPACES SIZE IN MB
SET LINES 150
SET pages 300
col "Tablespace" FOR a30
col "Total MB" FOR a15
col "Free MB" FOR a15
col "Used MB" FOR a15
col “% Used” FOR a15
SELECT tablespace_name "Tablespace",
d.STATUS “Status”,
TO_CHAR((a.bytes / 1048576),’99,999,990.900′) “Total MB”,
TO_CHAR(((DECODE(f.bytes, NULL, 0, f.bytes)) / 1048576),’99,999,990.900′) “Free MB”,
TO_CHAR(((a.bytes – DECODE(f.bytes, NULL, 0, f.bytes)) / 1048576),’99,999,990.900′) “Used MB”,
TO_CHAR((((a.bytes – DECODE(f.bytes, NULL, 0, f.bytes)) / 1048576)*100) / (a.bytes / 1048576),’999,999.9′) “% Used”
FROM
(sys.dba_tablespaces d JOIN sys.sm$ts_avail a USING (tablespace_name))
LEFT OUTER JOIN sys.sm$ts_free f USING (tablespace_name)
ORDER BY 6
/Another useful query
col “Tablespace” for a13
col “Used MB” for 99,999,999
col “Free MB” for 99,999,999
col “Total MB” for 99,999,999
col “Block Size” for 9,999,999
select
df.tablespace_name “Tablespace”,
block_size “Block Size”,
(df.totalspace – fs.freespace) “Used MB”,
fs.freespace “Free MB”,
df.totalspace “Total MB”,
round(100 * (fs.freespace / df.totalspace)) “Pct. Free”
from
dba_tablespaces ts,
(select tablespace_name,
round(sum(bytes) / 1048576) TotalSpace
from dba_data_files
group by tablespace_name) df,
(select tablespace_name,
round(sum(bytes) / 1048576) FreeSpace
from dba_free_space
group by tablespace_name) fs
where
ts.tablespace_name = fs.tablespace_name
and
df.tablespace_name = fs.tablespace_name(+)
;

TO CHECK SINGLE TABLESPACE AND ALL ITS DATAFILE LIST IN MB
set lines 190
col FILE_NAME for a55
col TABLESPACE_NAME for a20
select TABLESPACE_NAME,FILE_NAME,bytes/1024/1024 “MB” from dba_data_files where TABLESPACE_NAME=upper(‘&tsname’);

TO ADD NEW DATAFILE
alter tablespace STAGE_DATA add datafile ‘+DATA/INST/datafile/stage15.dbf’ size 4000m;

TO RESIZE A DATAFILE
ALTER DATABASE DATAFILE ‘+DATA/INST/datafile/stage15.dbf’ RESIZE 4G;

TO CHECK THE TEMP TABLESPACE
set lines 160
set pages 300
col FILE_NAME for a70
col PROPERTY_VALUE for a40
Select tablespace_name,file_name,bytes/1024/1024 from dba_temp_files;
select TABLESPACE_NAME,sum(BYTES_USED)/1024/1024 USED_MB, sum(BYTES_FREE)/1024/1024 FREE_MB from V$TEMP_SPACE_HEADER group by TABLESPACE_NAME;

To findout default temp tablespace
set lines 160
set pages 300
col PROPERTY_VALUE for a40
select property_name,property_value from database_properties where property_name=’DEFAULT_TEMP_TABLESPACE';

TO ADD TEMP FILE
ALTER TABLESPACE PSTEMP ADD TEMPFILE ‘/u01/oradata/hrcopy/pstemp01.dbf’ SIZE 1000M;

TO RESIZE TEMP FILE
alter database tempfile ‘/u01/oradata/TESTDB/temp01.dbf’ resize 250M;

TOTAL TEMP USAGE
SELECT (SELECT (SUM (tu.blocks))
FROM v$tempseg_usage tu)
* (SELECT VALUE
FROM v$parameter
WHERE NAME = ‘db_block_size’)
/ 1024 / 1024 AS “Used (MB)”,
(SELECT SUM (tf.BYTES)
FROM dba_temp_files tf) / 1024 / 1024 AS “Total (MB)”,
ROUND ((SELECT (SUM (tu.blocks))
FROM v$tempseg_usage tu) / (SELECT SUM (tf.blocks)
FROM dba_temp_files tf) * 100,
2
) AS pct
FROM DUAL;

WHO IS USING TEMP TABLESPACE
set lines 160
set pages 500
col SID_SERIAL for a15;
col USERNAME for a15;
col osuser for a15;
col SPID for a15
col MODULE for a30
col PROGRAM for a20
col TABLESPACE for a10
SELECT S.sid || ‘,’ || S.serial# sid_serial, S.username, S.osuser, P.spid, S.module,
S.program, SUM (T.blocks) * TBS.block_size / 1024 / 1024 mb_used, T.tablespace,
COUNT(*) sort_ops
FROM v$sort_usage T, v$session S, dba_tablespaces TBS, v$process P
WHERE T.session_addr = S.saddr
AND S.paddr = P.addr
AND T.tablespace = TBS.tablespace_name
GROUP BY S.sid, S.serial#, S.username, S.osuser, P.spid, S.module,
S.program, TBS.block_size, T.tablespace
ORDER BY sid_serial;

WHO IS USING UNDO TABLESPACE
SET PAGESIZE 500
SET LINESIZE 160
COLUMN pgm_notes FORMAT a80 HEADING ‘Notes’
COLUMN rbs FORMAT a12 HEADING ‘Undo Segment’
COLUMN oracle_user FORMAT a12 HEADING ‘Oracle|Username’
COLUMN sid_serial FORMAT a12 HEADING ‘SID,Serial’
COLUMN unix_pid FORMAT a6 HEADING ‘O/S|PID’
COLUMN Client_User FORMAT a20 HEADING ‘Client|Username’
COLUMN Unix_user FORMAT a12 HEADING ‘O/S|Username’
COLUMN login_time FOR/MAT a17 HEADING ‘Login Time’
COLUMN last_txn FORMAT a17 HEADING ‘Last Active’
COLUMN undo_kb FORMAT 99,999,999 HEADING ‘Undo KB’
SELECT r.name rbs,
nvl(s.username, ‘None’) oracle_user,
s.osuser client_user,
p.username unix_user,
to_char(s.sid)||’,’||to_char(s.serial#) as sid_serial,
p.spid unix_pid,
— TO_CHAR(s.logon_time, ‘mm/dd/yy hh24:mi:ss’) as login_time,
— TO_CHAR(sysdate – (s.last_call_et) / 86400,’mm/dd/yy hh24:mi:ss’) as last_txn,
t.used_ublk * TO_NUMBER(x.value)/1024 as undo_kb
FROM v$process p,
v$rollname r,
v$session s,
v$transaction t,
v$parameter x
WHERE s.taddr = t.addr
AND s.paddr = p.addr(+)
AND r.usn = t.xidusn(+)
AND x.name = ‘db_block_size’
ORDER
BY r.name
;

CALCULATE UNDO RETENTION
SELECT d.undo_size/(1024*1024) “ACTUAL UNDO SIZE [MByte]”,
SUBSTR(e.value,1,25) “UNDO RETENTION [Sec]”,
ROUND((d.undo_size / (to_number(f.value) *
g.undo_block_per_sec))) “OPTIMAL UNDO RETENTION [Sec]”
FROM (
SELECT SUM(a.bytes) undo_size
FROM v$datafile a,
v$tablespace b,
dba_tablespaces c
WHERE c.contents = ‘UNDO’
AND c.status = ‘ONLINE’
AND b.name = c.tablespace_name
AND a.ts# = b.ts#
) d,
v$parameter e,
v$parameter f,
(
SELECT MAX(undoblks/((end_time-begin_time)*3600*24))
undo_block_per_sec
FROM v$undostat
) g
WHERE e.name = ‘undo_retention’
AND f.name = ‘db_block_size’
/

SYSAUX USAGE
select OCCUPANT_NAME,SCHEMA_NAME,SPACE_USAGE_KBYTES from V$sysaux_occupants order by
SPACE_USAGE_KBYTES;

COMPONENTS ARE OCCUPYING SPACE IN SYSAUX
select space_usage_kbytes, occupant_name, occupant_desc from v$sysaux_occupants
order by 1 desc;

ALL DATAFILES USAGE
set pages 8000
set lines 700
col FILE_NAME for a60
SELECT SUBSTR (df.NAME, 1, 60) file_name, df.bytes / 1024 / 1024 allocated_mb,
((df.bytes / 1024 / 1024) – NVL (SUM (dfs.bytes) / 1024 / 1024, 0)) used_mb,
NVL (SUM (dfs.bytes) / 1024 / 1024, 0) free_space_mb
FROM v$datafile df, dba_free_space dfs
WHERE df.file# = dfs.file_id(+)
GROUP BY dfs.file_id, df.NAMEdf.file#, df.bytes
ORDER BY file_name;

To find out the RETENTION period stats:
Select dbms_stats.get_stats_history_retention from dual;

LOCALLY VS DICTIONARY MANAGED TABLESPACES
select tablespace_name, extent_management from dba_tablespaces;

TO DETERMINE AUTOEXTEND ON/OFF TABLESPACES
select file_id, tablespace_name, bytes, maxbytes, maxblocks, increment_by, file_name from dba_data_files where autoextensible = ‘YES';

TO VERIFY THE LOCATION OF ALL FILES
set lines 160
set lines 100
set pages 999
col name format a70
set lines 100
set pages 999
col name format a70
select name, bytes from
(select name, bytes from v$datafile
union all
select name, bytes from v$tempfile
union all
select lf.member “name”, l.bytes from v$logfile lf , v$log l where lf.group# = l.group#
union all
select name, 0 from v$controlfile) used , (select sum(bytes) as p from dba_free_space) free
/

THE FOLLOWING QUERY RETURNS A LIST OF OBJECTS THAT ARE CREATED IN THE SYSTEM TABLESPACE BUT NOT OWNED BY SYS OR SYSTEM.(DEPENDENCY)
select owner, segment_name, segment_type from dba_segments where tablespace_name = ‘SYSTEM’ and owner not in (‘SYS’,’SYSTEM’);

To Determine the Tablespace more then 90%
SELECT vm.tablespace_name,
(100 – (NVL (vf.BYTES, 0) / vm.BYTES) * 100) pctinuse,
NVL (vf.BYTES, 0)/1024/1024 free_mb, vm.BYTES max_bytes,
NVL (MAX (f.BYTES), 0) free_ext
FROM SYS.sm$ts_avail vm, SYS.sm$ts_free vf, SYS.dba_free_space f
WHERE vm.tablespace_name = vf.tablespace_name
AND vm.tablespace_name = f.tablespace_name
AND (100 – (NVL (vf.BYTES, 0) / vm.BYTES) * 100) > 90
GROUP BY vm.tablespace_name, vf.BYTESvm.BYTES
ORDER BY 1;

To Determine the Tablespace more then 80% full

set pages 999 lines 100
col tablespace_name format a40
col “size MB” format 999999999
col “% Used” format 999
col “80%” format 999999
col “75%” format 999999
select tsu.tablespace_name
, ceil(tsu.used_mb) “size MB”
, 100 – floor(tsf.free_mb/tsu.used_mb*100) “% Used”
, (tsu.used_mb / 100) * (20 – floor(tsf.free_mb/tsu.used_mb*100)) “80%”
, (tsu.used_mb / 100) * (25 – floor(tsf.free_mb/tsu.used_mb*100)) “75%”
from (select tablespace_name, sum(bytes)/1024/1024 used_mb
from dba_data_files group by tablespace_name) tsu
, (select tablespace_name, sum(bytes)/1024/1024 free_mb
from dba_free_space group by tablespace_name) tsf
where tsu.tablespace_name = tsf.tablespace_name (+)
and 100 – floor(tsf.free_mb/tsu.used_mb*100) >= 80
order by 3,4,5

No comments:

Post a Comment