日更成长营

oracle数据库删除数据后手动释放表空间

2022-01-30  本文已影响0人  小强聊成长

ORACLE数据库使用一段时间后,必然面临着空间减少,直到不够用的时候,这个时候你有两个选择。

1.增加硬盘空间,购买新的存储。这个涉及到资金和机器本身还是否有接口。

2.删除部分历史数据,释放空间。

那如果是按照第二种情况来处理,又分2种情况。

1.直接把整个表的数据删除,使用TRUNCATE命令,这个比较简单,能够立即释放出空间。

而如果你不能把整个表的数据都删除,只能删除部分历史数据,就需要使用第二种方法。

2.使用DELETE 方法,加上WHERE条件,删除部分数据。这种方法删除部分的表空间不会释放。

如果想要释放这部分的空间,你需要手动执行下面的语句。也是分两步完成。

1.开启允许行移动, 此操作后允许rowid改变。

执行语句:alter table 你的表名 enable row movement;

2.回收空间。

执行语句:alter table 你的表名 shrink space;

你还知道其他方法吗?欢迎留言分享。
________________END______________

上一篇下一篇

猜你喜欢

热点阅读