Сжатие базы Oracle 11g, 10g

Oracle
Замечательный скрипт нашел у Тома Кайта. Скрипт создает SQL запросы для сжатия файлов базы Oracle. Итак скрипт:
----------- maxshrink.sql ----------------------------------

set verify off
column file_name format a50 word_wrapped
column smallest format 999,990 heading "Smallest|Size|Poss."
column currsize format 999,990 heading "Current|Size"
column savings  format 999,990 heading "Poss.|Savings"
break on report
compute sum of savings on report

column value new_val blksize
select value from v$parameter where name = 'db_block_size'
/

select file_name,
       ceil( (nvl(hwm,1)*&&blksize)/1024/1024 ) smallest,
       ceil( blocks*&&blksize/1024/1024) currsize,
       ceil( blocks*&&blksize/1024/1024) -
       ceil( (nvl(hwm,1)*&&blksize)/1024/1024 ) savings
from dba_data_files a,
     ( select file_id, max(block_id+blocks-1) hwm
         from dba_extents
        group by file_id ) b
where a.file_id = b.file_id(+)
/

column cmd format a75 word_wrapped

select 'alter database datafile '''||file_name||''' resize ' ||
       ceil( (nvl(hwm,1)*&&blksize)/1024/1024 )  || 'm;' cmd
from dba_data_files a,
     ( select file_id, max(block_id+blocks-1) hwm
         from dba_extents
        group by file_id ) b
where a.file_id = b.file_id(+)
  and ceil( blocks*&&blksize/1024/1024) -
      ceil( (nvl(hwm,1)*&&blksize)/1024/1024 ) > 0
/

Скопипастил его в sqlplus и получил такой результат:
CMD
---------------------------------------------------------------------------
alter database datafile 'С:\DB\SYSIND.DBF' resize 32641m;
alter database datafile 'D:\DB\SUTV.DBF' resize 21569m;
alter database datafile 'D:\DB\EXPVT.DBF' resize 1m;
alter database datafile 'D:\DB\SYSIND2.DBF' resize 2m;

Выполняем скрипт и удивляемся как легко можно освободить место на жестких дисках.

5 комментариев