天天看點

找出所有檔案最小可resize尺寸

找出所有檔案最小可resize尺寸
--找出所有檔案最小可resize尺寸
SELECT a.file_id,
    CEIL( ( NVL( hwm,1 ) * blksize ) / 1024 / 1024 ) smallest_M,
    CEIL( blocks * blksize / 1024 / 1024 ) currsize_M,
    CEIL( blocks * blksize / 1024 / 1024 ) -
    CEIL( ( NVL( hwm,1) * blksize ) / 1024 / 1024 ) savings_M,
    '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,  (
       SELECT TO_NUMBER( value ) blksize FROM V$PARAMETER
       WHERE  name = 'db_block_size' )
  WHERE a.file_id = b.file_id(+)
  AND  CEIL( blocks * blksize / 1024 / 1024 ) - CEIL( ( NVL( hwm, 1 ) * blksize ) / 1024 / 1024 ) > 0
  ORDER BY 5 desc;
      

作者:九命貓幺

部落格出處:http://www.cnblogs.com/yongestcat/

歡迎轉載,轉載請标明出處。

如果你覺得本文還不錯,對你的學習帶來了些許幫助,請幫忙點選右下角的推薦