set line 200
col segment_name for a60
WITH segment_stats
AS (SELECT ss.owner || '.' || ss.object_name
|| DECODE (ss.subobject_name,NULL, '',
'(' || ss.subobject_name || ')') segment_name,
ss.object_type,
SUM ( CASE WHEN statistic_name LIKE 'physical reads%'
THEN VALUE ELSE 0 END) reads,
SUM ( CASE WHEN statistic_name LIKE 'physical writes%'
THEN VALUE ELSE 0 END) writes,
ROUND (SUM (bytes) / 1048576) mb
FROM v$segment_statistics ss
JOIN dba_segments s
ON (s.owner = ss.owner AND s.segment_name = ss.object_name
AND NVL (ss.subobject_name, 'x') =NVL (s.partition_name, 'x') )
WHERE statistic_name LIKE 'physical reads%'
OR statistic_name LIKE 'physical writes'
GROUP BY ss.owner, ss.object_name, ss.subobject_name, ss.object_type)
SELECT segment_name, object_type, reads, writes,
ROUND (reads * 100 / SUM (reads) OVER (), 2) pct_reads,
ROUND (writes * 100 / SUM (writes) OVER (), 2) pct_writes, mb
FROM segment_stats
ORDER BY reads DESC
Sample Result:
Ref: http://guyharrison.squarespace.com