ORACLE缩小表空间的数据文件

如果我们遇到需要缩小表空间内的数据文件的情况,可以参考以下方法

一、查看数据文件能缩小的最小值
SELECT a.tablespace_name,
file_name,
c.VALUE / 1024 "Blk. size(Kb)",
CEIL ((NVL (hwm, 1) * c.VALUE) / 1024 / 1024) "smallest(Mb) - HWM",
CEIL (blocks * c.VALUE / 1024 / 1024) "currsize(Mb)",
CEIL (blocks * c.VALUE / 1024 / 1024) - CEIL ((NVL (hwm, 1) * c.VALUE) / 1024 / 1024) "savings(Mb)"
FROM dba_data_files a,
(SELECT file_id, MAX (block_id + blocks - 1) hwm
FROM dba_extents
GROUP BY file_id) b,
(SELECT VALUE
FROM v$parameter
WHERE NAME = 'db_block_size') c
WHERE a.file_id = b.file_id(+)
and a.status !='INVALID';

二、通过如下方式修改对应表空间数据文件大小
alter database   datafile '+DATA/test/datafile/users02.dbf'  resize 500M;

猜你喜欢

转载自www.cnblogs.com/zhm1985/p/12767759.html