1、首先了解基本概念
表空间是非常大的一块存储区域,为了方便管理,我们对其进行以下划分。
- 物理概念上存储空间的划分
- 64个页——为一个区(1MB)
- 256个区——为一个组(256MB)所有的组——构成表空间
- 逻辑概念上存储空间的划分---段
- 段是逻辑概念上的划分,目的是将用途相同的页存储在一起,将不同用途的页分开存储;
- 段是 一些完整的区+零散的页 的集合。段在表空间,因为区可能分布在表空间中不同的数据文件上,所以段可能包含一个表空间上多个数据文件上的数据。另外创建一个对象便会创建一个段,占用存储空间的每一个对象都会对应一个段,如创建一个表或索引,便会生成表段、索引段。
- 一个索引至少有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;