Oracle表空间清理

编程入门 行业动态 更新时间:2024-10-21 19:09:46

一、查看表所占空间大小

--1、查看用户表、索引、分区表占用空间
select segment_name, sum(bytes)/1024/1024 as Mbytes from user_segments group by segment_name order by Mbytes desc;

--2、表占用空间:
select segment_name, sum(bytes)/1024/1024 as Mbytes from user_segments where segment_type='TABLE' group by segment_name order by Mbytes desc;

--3、索引占用空间:
select segment_name ,sum(bytes)/1024/1024 as Mbytes from user_segments where segment_type ='INDEX' group by segment_name order by Mbytes desc;

--4、分区表TABLE PARTITION占用空间:
select segment_name,sum(bytes)/1024/1024 as Mbytes from user_segments where segment_type='TABLE PARTITION' group by segment_name order by Mbytes desc;

二、删除不需要的表和分区

使用drop命令删除不需要的表和分区,删除后再执行[语句1],发现表里多了以BIN开头的文件,而且仍然占用很大空间。

oracle drop table的时候,不会彻底删除该表,它将drop的表放到了自己的回收站里,放到回收站的表就是我们看到的形如bin$/rt62vkdt5wmrjfcz28eja==$0的表,其中包含了表的结构定义信息和数据。

三、清理垃圾表

PURGE RECYCLEBIN

四、扩展

--查询所有垃圾表
select * from recyclebin where type='TABLE';
 
--删除回收站中所有的表
PURGE RECYCLEBIN     -------这语句就能清除所有以BIN开头的残留文件
 
--删除指定的垃圾表
PURGE TABLE TABLE_NAME
 
--闪回被删除的表
FLASHBACK TABLE table_name TO BEFORE DROP;
 
--Drop表时不产生Bin型表
DROP TABLE "TableName" purge;
  
--设置falshback功能的开启和关闭
startup mount
alter database flashback on(off)

 

更多推荐

Oracle表空间清理

本文发布于:2023-06-20 12:59:00,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/801897.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:空间   Oracle

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!