清理UNDOTBS表空间,获取20G空间

本文介绍了一位开发人员如何解决笔记本硬盘空间不足的问题,详细记录了删除和重建Oracle数据库中大型UNDOTBS01.DBF文件的过程。

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

      我的60G分区,使用了不到1年就只剩下500mb,我又没有放置电影和软件的情况下怎么会没有空间了呢,实在是无法忍受的情况下我对硬盘中的大于100MB的文件进行搜索,结果发现占用硬盘最大的是RRbackups中的windows回复备份文件和oracle数据库中的UNDOTBS01.DBF文件占用硬盘空间最大,其中UNDOTBS01.DBF占有20G空间,好家伙,我说怎么没空间呢,就它就占了这么大.能有空间可用么.

      作为开发人员,我没必要让UNDOTBS01.DBF文件在我的笔记本上占这么大的存储空间.问题找到了,就上网bing吧,我现在开始用bing了,算是对微软的支持.

      很快在网上找到了解决办法,按照网上的操作步骤操作如下:

1. 创建新的UNDO表空间
CREATE UNDO TABLESPACE "UNDOTEMP"
    DATAFILE 'D:/oracle/product/10.1.0/oradata/fsdb/UNDOTEMP.ora' SIZE 5M

2.在OEM控制台修改系统默认的UNDO表空间名, 由UNDOTBS改为UNDOTEMP, 或通过下面的命令修改默认UNDO表空间的标识
ALTER SYSTEM SET UNDO_TABLESPACE = UNDOTEMP

3. 删除原来的系统默认UNDO表空间, 并重建UNDOTBS
DROP TABLESPACE "UNDOTBS" INCLUDING CONTENTS AND DATAFILES

执行完第三步后我看目录中的文件UNDOTBS01.DBF并没有被删除,因此我手动删除,系统提示该文件正在被使用.把oracleservicefsdb进程停止,停止后删除UNDOTBS01.DBF文件未报错,重新启动OracleOraDb10g_home1TNSListener和oracleservicefsdb进程后继续第4步的操作.

4.重新创建undo表空间

CREATE UNDO TABLESPACE "UNDOTBS"
    DATAFILE 'G:/ORACLE/ORADATA/HOME/UNDOTBS01.DBF' SIZE 200M
    AUTOEXTEND ON NEXT  4096K MAXSIZE  500M

5. 在OEM控制台修改系统默认的UNDO表空间名, 由 UNDOTEMP 改为 UNDOTBS, 改回原有的UNDO表空间标识
ALTER SYSTEM SET UNDO_TABLESPACE = UNDOTBS

6. 删除临时创建的UNDO表空间UNDOTEMP
DROP TABLESPACE "UNDOTEMP" INCLUDING CONTENTS AND DATAFILES

经过这6个步骤,我的机器恢复20G的硬盘空间,如果您也遇到这种情况,不妨试试.

SELECT df.tablespace_name AS "表空间名", df.total_space AS "总空间(MB)", NVL(fs.free_space, 0) AS "空闲空间(MB)", (df.total_space - NVL(fs.free_space, 0)) AS "已用空间(MB)", ROUND((df.total_space - NVL(fs.free_space, 0)) 2 3 4 5 6 * 100 / df.total_space, 2) AS "利用率(%)" FROM (SELECT tablespace_name, ROUND(SUM(bytes) / 1024 / 1024, 2) total_space FROM dba_data_files GROUP BY tablespace_name) df LEFT JOIN (SELECT 7 8 9 10 11 12 13 14 15 16 17 tablespace_name, ROUND(SUM(bytes) / 1024 / 1024, 2) free_space FROM dba_free_space GROUP BY tablespace_name) fs ON df.tablespace_name = fs.tablespace_name ORDER BY "利用率(%)" DESC; 18 19 20 21 22 23 24 25 26 表空间名 总空间(MB) 空闲空间(MB) 已用空间(MB) 利用率(%) ------------------------------ ---------- ------------ ------------ ---------- SYSTEM 65527.98 117.94 65410.04 99.82 TIMP_XZEEMS_INTER_FLOW 20992 1237.13 19754.87 94.11 SYSAUX 1800 116.94 1683.06 93.5 TIMP_XZEEMS_INTRA_FLOW 8192 768.69 7423.31 90.62 USERS 5 3.69 1.31 26.2 UNDOTBS1 175 137.94 37.06 21.18 TIMP_XZEEMS_INTRA 1024 985.31 38.69 3.78 TIMP_XZEEMS_INTER 1024 986.13 37.87 3.7 TIMP_XZEEMS_MQ_INTRA 1024 1019.63 4.37 .43 9 rows selected. SQL> SELECT a.tablespace_name AS "表空间名", ROUND(a.bytes_alloc / 1024 / 1024, 2) AS "总空间(MB)", ROUND((a.bytes_alloc - NVL(b.bytes_free, 0)) / 1024 / 1024, 2) AS "已用空间(MB)", ROUND(NVL(b.bytes_free, 0) / 1024 / 1024, 2) AS "空 2 3 4 5 闲空间(MB)", ROUND((a.bytes_alloc - NVL(b.bytes_free, 0)) / a.bytes_alloc * 100, 2) AS "利用率(%)", a.autoextensible AS "自动扩展" FROM (SELECT tablespace_name, SUM(bytes) bytes_alloc, MAX(autoextensible) aut 6 7 8 9 10 11 12 oextensible FROM dba_data_files GROUP BY tablespace_name) a LEFT JOIN (SELECT tablespace_name, SUM(bytes) bytes_free FROM dba_free_space GROUP BY tablespace_name) b ON a.tablespace_name = b.tablespace_name UNION AL 13 14 15 16 17 18 19 20 21 22 L SELECT tablespace_name AS "表空间名", ROUND(SUM(bytes) / 1024 / 1024, 2) AS "总空间(MB)", ROUND(SUM(bytes_used) / 1024 / 1024, 2) AS "已用空间(MB)", ROUND(SUM(bytes_free) / 1024 / 1024, 2) AS "空闲空间(MB)", ROUND(SUM( 23 24 25 26 27 28 bytes_used) / SUM(bytes) * 100, 2) AS "利用率(%)", 'YES' AS "自动扩展" FROM dba_temp_free_space GROUP BY tablespace_name ORDER BY 5 DESC; 29 30 31 32 ROUND(SUM(bytes_used) / SUM(bytes) * 100, 2) AS "利用率(%)", * ERROR at line 28: ORA-00904: "BYTES": invalid identifier
08-07
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值