-- space used schema wise
select owner, sum(bytes/(1024*1024*1024)) from dba_segments group by rollup(owner)
-- find partitios, subpartition high
level info along with # of partition
with
temp_low as (
select table_name, PARTITION_NAME from user_tab_partitions a where PARTITION_POSITION in (
select min(PARTITION_POSITION) from
user_tab_partitions b where a.table_name=b.table_name)
)
,temp_high as
(
select table_name, PARTITION_NAME from user_tab_partitions a where PARTITION_POSITION in (
select max(PARTITION_POSITION)-1 from
user_tab_partitions b where a.table_name=b.table_name)
)
select a.table_name, a.PARTITION_NAME,
b.PARTITION_NAME, c.PARTITION_COUNT,
decode(c.SUBPARTITIONING_KEY_COUNT,1,'YES','NO') as SUBPARTITION
from temp_low a, temp_high b, user_part_tables c
where a.table_name=b.table_name
and a.table_name=c.table_name
/
sample report
TABLE_NAME starting_partition end_partition #
SUBP
------------------------------ ------------------
------------------ ---------------- ------
BOS_MESSAGE_LOG P_20130307 P_20140802 514 NO