`
logicgate
  • 浏览: 96396 次
  • 性别: Icon_minigender_1
  • 来自: 新力吐皮
社区版块
存档分类
最新评论

Oracle 中减小数据文件大小

阅读更多

由于要做一个测试,我在users表空间中创建一个表并且插入了500万条数据,结果导致数据文件的大小由1G涨到了8G。测试完成后删除表,但数据文件的大小仍然维持在8G。

 

研究了一下,可以通过resize datafile来减小数据文件的大小。

 

首先,要查清楚数据文件的真实使用空间。可以通过查询dba_extents达到这个目的。users表空间使用的数据文件为D:\ORACLE\ORADATA\EPCIT\DATA_FILE\EPCITUSERS01.DBF

SQL> select file_name, sum(e.bytes)/1024/1024 as MB
  2  from dba_extents e join dba_data_files f on e.file_id=f.file_id
  3  group by file_name;

FILE_NAME                                                       MB
------------------------------------------------------- ----------
E:\ORADATA\DATA_FILE\EPCITSYSAUX01.DBF                      330.25
E:\ORADATA\DATA_FILE\EPCITBLOBS01.DBF                     197.1875
D:\ORACLE\ORADATA\EPCIT\DATA_FILE\PERFSTAT.DBF              143.75
D:\ORACLE\ORADATA\EPCIT\DATA_FILE\EPCITUSERS01.DBF        143.3125
E:\ORADATA\DATA_FILE\EPCITINDEX01.DBF                      421.625
E:\ORADATA\DATA_FILE\EPCITSYSTEM01.DBF                    355.5625
E:\ORADATA\DATA_FILE\EPCITUNDOTBS01.DBF                    26.3125

7 rows selected.

 

可以看出EPCITUSERS01.DBF实际使用空间只有143MB。resize datafile的时候不可以小过这个大小。

SQL> alter database datafile 6 resize 100M;
alter database datafile 6 resize 100M
*
ERROR at line 1:
ORA-03297: file contains used data beyond requested RESIZE value

SQL> alter database datafile 6 resize 500M;

Database altered.
分享到:
评论
1 楼 saup007 2011-11-10  
thank you!~!

相关推荐

Global site tag (gtag.js) - Google Analytics