Hot to check table size including their indexes.
SELECT
owner, table_name, TRUNC(sum(bytes)/1024/1024) gigas
FROM
(SELECT segment_name table_name, owner, bytes
FROM dba_segments
WHERE segment_type = 'TABLE'
AND SEGMENT_NAME NOT LIKE ('BIN%')
UNION ALL
SELECT i.table_name, i.owner, s.bytes
FROM dba_indexes i, dba_segments s
WHERE s.segment_name = i.index_name
AND s.owner = i.owner
AND s.segment_type = 'INDEX'
AND s.SEGMENT_NAME NOT LIKE ('BIN%')
UNION ALL
SELECT l.table_name, l.owner, s.bytes
FROM dba_lobs l, dba_segments s
WHERE s.segment_name = l.segment_name
AND s.SEGMENT_NAME NOT LIKE ('BIN%')
AND s.owner = l.owner
AND s.segment_type = 'LOBSEGMENT'
UNION ALL
SELECT l.table_name, l.owner, s.bytes
FROM dba_lobs l, dba_segments s
WHERE s.segment_name = l.index_name
AND s.SEGMENT_NAME NOT LIKE ('BIN%')
AND s.owner = l.owner
AND s.segment_type = 'LOBINDEX')
GROUP BY table_name, owner
HAVING SUM(bytes)/1024/1024/1024 > 1
ORDER BY SUM(bytes) desc;
Comments