Gauss数据库表空间使用率过高

1、首先了解基本概念

表空间是非常大的一块存储区域,为了方便管理,我们对其进行以下划分。

  • 物理概念上存储空间的划分
    • 64个页——为一个区(1MB)
    • 256个区——为一个组(256MB)所有的组——构成表空间3f7c068dc0c946ba84f3b4745e4ea0f0.png
  • 逻辑概念上存储空间的划分---段
  1. 段是逻辑概念上的划分,目的是将用途相同的页存储在一起,将不同用途的页分开存储;
  2. 段是 一些完整的区+零散的页 的集合。段在表空间,因为区可能分布在表空间中不同的数据文件上,所以段可能包含一个表空间上多个数据文件上的数据。另外创建一个对象便会创建一个段,占用存储空间的每一个对象都会对应一个段,如创建一个表或索引,便会生成表段、索引段。
  3. 一个索引至少有2个段——叶子节点段非叶子节点段
    (将不同用途的页分开,因为同一用途的页可能需要连续读取,如果混着存储,会让扫描效果大打折扣)

为什么后面要以完整的区为单位来分配存储空间?
我们经常需要访问多个逻辑上连续的页,如果以页为单位来分配存储空间,会在成逻辑上连续的页,在物理上不连续,这样访问多个逻辑上连续的页,会产生许多随机IO,影响性能
以区为单位来分配存储空间——目的是消除随机IO,让逻辑上相邻的页在物理上页相邻,这个进行扫描时,使用的是顺序IO。

2、查询使用情况

查询表空间的使用率

SQL> select 100*used_size/total_size as rate from adm_tablespace order by rate desc limit 10;

 

查询表空间中top10张表占用空间的大小,按照由大到小排序

SQL> select table_name,tablespace_name,round(bytes/(1024*1024)) from my_tables order by bytes desc limit 10;

 

查询表空间中top10段占用空间的大小,按照由大到小排序

这里的段包括:表、索引、LOB

SQL> select owner,segment_name,segment_type,round(bytes/(1024*1024)) from adm_segments where tablespace_name="resourcedb" order by bytes desc limit 10;

 

有些表数据可能同一个id对应多条数据,比如告警数据,需要使用聚合查询

SQL> select alarm_id,count(*) as num from tbl_alarm group by alarm_id order by num desc limit 10;

3、清理表数据

1、truncate删除表中的所有数据、释放空间,但是保留表结构。

需要注意的是,执行 TRUNCATE 操作后,所有的自增长(AUTO_INCREMENT)属性将被重置。

truncate删除操作立即生效,原数据不放到rollback segment中,不能rollback,操作不触发trigger。

SQL> truncate table table_name;

SQL>

2、delete删除表中数据而不删除表结构,也不释放空间。

delete可以删除一行、多行、乃至整张表,如果不加where条件,表示删除表中所有数据。

每次删除一行,都在事务日志中为所删除的每行记录一项,可回滚。

SQL> delete from table_name;

SQL> delete from table_name where event_time like '%2024-04%';

SQL> alter table table_name shrink space;

 

  • 38
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值