Oracle查询单表占用空间实际大小

1、查询”帐户/库”数据占用存储空间大小

select sum(bytes)/1024/1024 as “size(M)” from dba_segments where owner=’帐户名/库名’

2、查询单表数据占用存储空间大小

select sum(bytes)/(1024*1024) as “size(M)” from user_segments

where segment_name=upper(‘表名’);

3、在表空间中,查询占用存储空间最大的表

SELECT * FROM (SELECT SEGMENT_NAME, SUM(BYTES) / 1024 / 1024 MB FROM DBA_SEGMENTS WHERE TABLESPACE_NAME = upper(‘表空间名称’) GROUP BY SEGMENT_NAME ORDER BY 2 DESC) WHERE ROWNUM < 10;

4、在”帐户/库”中,查询占用存储空间最大的表

SELECT owner, segment_name, segment_type, sum(bytes) / 1024 / 1024 "Size (MB)" FROM dba_segments WHERE owner = '你的用户名' GROUP BY owner, segment_name, segment_type ORDER BY (sum(bytes) / 1024 / 1024) DESC;

5、查询某segment_name属于哪个table

select owner,table_name,column_name,segment_name,index_name from dba_lobs a where a.segment_name = '上一步查询到的segment_name名称';

6、如果遇到大表需要清理历史数据,直接批量删除容易锁表,采用大表单表按天清理数据的过程方法:

DECLARE
  begin_date date := to_date('2020-09-01','yyyy-mm-dd');
BEGIN 
  WHILE begin_date < to_date('2023-07-01','yyyy-mm-dd') loop 
    DELETE FROM tablespace_name.table_name WHERE CREATE_TIME >= begin_date and CREATE_TIME < begin_date+1; 
    commit; 
    begin_date := begin_date+1; 
  end loop; 
END; 
/
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值