RESIZE DATAFILE与ORA-03297

本文介绍了如何通过清理Oracle数据库中的回收站来释放表空间占用的空间,并调整数据文件大小的方法。通过实例展示了truncate操作和resize命令的具体应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

       当我们创建了一个表空间并指定了数据文件,在操作系统上就是出现这个文件。但是如果我们将这个文件开启了自动扩展,只要有新的数据存入,这个文件就会越来越大,直到达到文件或者操作系统的限制。
但是有时候明明表是空的,但是却还是占据了很大的空间。这时候就需要我们降低表的高水位线,使得表所使用的段变小,释放多余空间。然后通过resize改变数据文件大小。已达到释放操作系统空间的作用。
验一:
降低高水位线(truncate方式)缩小数据文件大小
  1. --创建一个表空间并指定对应的数据文件
  2. VAST@prod > create tablespace vdedutbs datafile '/u01/app/oracle/oradata/prod/vdedutbs01.dbf' size 10M autoextend on;
  3. Tablespace created.
  4. --在这个表空间上创建一张大表
  5. VAST@prod > create table ote tablespace vdedutbs as select * from dba_objects;
  6. Table created.
  7. --再次插入数据,将表变的更大一些
  8. VAST@prod > insert into ote select * from ote;
  9. 75354 rows created
  10. VAST@prod > commit;
  11. Commit complete.
  12. --查看此时数据文件大小
  13. VAST@prod > set line 200
  14. VAST@prod > col file_name for a50
  15. VAST@prod > select file_id,
  16.   2 file_name,
  17.   3 tablespace_name,
  18.   4 autoextensible,
  19.   5 bytes / 1048576 total,
  20.   6 user_bytes / 1048576 used,
  21.   7 online_status
  22.   8 from dba_data_files
  23.   9 where tablespace_name = 'VDEDUTBS';
  24.    FILE_ID FILE_NAME                                          TABLESPACE_NAME                AUT TOTAL      USED       ONLINE_
  25. ---------- -------------------------------------------------- ------------------------------ --- ---------- ---------- -------
  26.          7 /u01/app/oracle/oradata/prod/vdedutbs01.dbf        VDEDUTBS                       YES         19         18 ONLINE

  27. --查看表空间上的各个段
  28. VAST@prod > col segment_name for a10
  29. VAST@prod > select owner, segment_name, segment_type, tablespace_name, bytes / 1048576
  30.   2 from dba_segments
  31.   3 where tablespace_name = 'VDEDUTBS';
  32. OWNER                          SEGMENT_NA SEGMENT_TYPE       TABLESPACE_NAME                BYTES/1048576
  33. ------------------------------ ---------- ------------------ ------------------------------ -------------
  34. VAST                           OTE        TABLE              VDEDUTBS                                  18
  35. --降低高水位线
  36. VAST@prod > truncate table ote;
  37. Table truncated.
  38. --查看表空间上的各个段
  39. VAST@prod > select owner, segment_name, segment_type, tablespace_name, bytes / 1048576
  40.   2 from dba_segments
  41.   3 where tablespace_name = 'VDEDUTBS';

  42. OWNER                          SEGMENT_NA   SEGMENT_TYPE       TABLESPACE_NAME                BYTES/1048576
  43. ------------------------------ ----------   ------------------ ------------------------------ -------------
  44. VAST                           OTE          TABLE              VDEDUTBS                               .0625
  45. --resize数据文件

  46. VAST@prod > alter database datafile '/u01/app/oracle/oradata/prod/vdedutbs01.dbf' resize 10M;
  47. Database altered.
  48. --查看此时数据文件大小
  49. VAST@prod > select file_id,
  50.   2 file_name,
  51.   3 tablespace_name,
  52.   4 autoextensible,
  53.   5 bytes / 1048576 total,
  54.   6 user_bytes / 1048576 used,
  55.   7 online_status
  56.   8 from dba_data_files
  57.   9 where tablespace_name = 'VDEDUTBS';

  58.    FILE_ID FILE_NAME                                          TABLESPACE_NAME                AUT TOTAL      USED       ONLINE_
  59. ---------- -------------------------------------------------- ------------------------------ --- ---------- ---------- -------
  60.          7 /u01/app/oracle/oradata/prod/vdedutbs01.dbf        VDEDUTBS                       YES         10          9 ONLINE
前几天出现这么一个情况,想讲一个空的数据文件的大小减小一部分,查询表空间的使用率以及表空间下是否有表的存在,发现都没有。但是却一直报ORA-03297错误
 实验二:

  1. --表空间使用率
  2. set line 200
  3. select total.tablespace_name,
  4.        round(total.MB, 2) as Total_MB,
  5.        round(total.MB - free.MB, 2) as Used_MB,
  6.        round((1 - free.MB / total.MB) * 100, 2) || '%' as Used_Pct from
  7.        (select tablespace_name,sum(bytes) / 1024 / 1024 as MB from dba_free_space group by tablespace_name) free,
  8.        (select tablespace_name,sum(bytes) / 1024 / 1024 as MB from dba_data_files group by tablespace_name) total
  9.        where free.tablespace_name = total.tablespace_name order by used_pct desc;
  10. TABLESPACE_NAME                TOTAL_MB   USED_MB    USED_PCT
  11. ------------------------------ ---------- ---------- ----------
  12. SYSTEM                                720     717.69     99.68%
  13. SYSAUX                                620     580.13     93.57%
  14. EXAMPLE                            345.63     310.13     89.73%
  15. VASTTBS                            421.81     227.56     53.95%
  16. UNDOTBS1                              105      50.44     48.04%
  17. USERS                              196.25        4.5      2.29%
  18. VDEDUTBS                               10          1        10%
  19. --修改文件大小为5M
  20. VAST@prod > alter database datafile '/u01/app/oracle/oradata/prod/vdedutbs01.dbf' resize 5M;
  21. alter database datafile '/u01/app/oracle/oradata/prod/vdedutbs01.dbf' resize 5M
  22. *
  23. ERROR at line 1:
  24. ORA-03297: file contains used data beyond requested RESIZE value
  25. --查看VEDUDTBS下有哪些表
  26. VAST@prod > select * from dba_tables where tablespace_name='VDEDUTBS';
  27. no rows selected
  28. 明明修改的大小小于使用大小,且表空间下无表的存在为什么不能缩小数据文件呢
  29. --查看表空间上的各个段
  30. VAST@prod > col segment_name for a30
  31. VAST@prod > /

  32. OWNER                          SEGMENT_NAME                   SEGMENT_TYPE       TABLESPACE_NAME                BYTES/1048576
  33. ------------------------------ ------------------------------ ------------------ ------------------------------ -------------
  34. VAST                           BIN$RpdF3cZzdTTgU2VQqMBzGg==$0 TABLE              VDEDUTBS                                   9
  35. 这时查看段发现,在这个表空间内存在着一个被删除的表

  36. --查看回收站
  37. VAST@prod > show recyclebin;
  38. ORIGINAL         NAME                           RECYCLEBIN   NAME OBJECT TYPE DROP TIME
  39. ---------------- ------------------------------ ------------ -------------------
  40. OTE              BIN$RpdF3cZzdTTgU2VQqMBzGg==$0 TABLE        2017-01-21:16:13:00
  41. 此表已经不再使用,将他从回收站中清除干净
  42. VAST@prod > purge table ote;

  43. Table purged.

  44. --修改文件大小为5M
  45. VAST@prod > alter database datafile '/u01/app/oracle/oradata/prod/vdedutbs01.dbf' resize 5M;
  46. Database altered.
  1. 修改成功
  2. 原来是由于之前将一个表删除,但是没有真的被删除,而是被放在的回收站中。




来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/30820196/viewspace-2132782/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/30820196/viewspace-2132782/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值