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;

 

<think>嗯,用户询问GaussDB中创建数据库与创建表空间的关系。这个问题需要结合数据库的基础概念和GaussDB的特性来解释。 首先需要明确几个关键概念:在GaussDB中,数据库是逻辑上的数据容器,包含表、索引等对象;而表空间是物理存储位置,用于管理磁盘空间。两者关系类似仓库和货架——数据库是仓库,表空间是里面的存储区域。 用户引用的材料提到表空间可以跨数据库使用,这点很重要。参考引用[3]中的CREATE TABLESPACE语法,可以看到表空间创建时指定了物理文件路径和存储参数,这说明表空间本质是物理存储单元。而引用[1]提到数据库包含表空间,表明数据库作为逻辑容器可以包含多个表空间。 权限管理方面,表空间需要独立授权。引用[3]的WITH子句展示了表空间级配置,如压缩、分区策略等,这些特性会影响数据库性能但独立于数据库定义。用户可能还关心实践中的关联操作,比如创建数据库时默认表空间的分配机制。 性能优化角度也很关键。引用[4]显示创建分区表时需要关联表空间,这说明表空间直接影响数据分布策略。不同表空间配置不同的存储参数(如引用[3]的列存配置),可以针对业务场景优化数据库性能。 最后需要强调依赖关系:虽然表空间可独立创建,但必须关联数据库才能存储数据对象;而数据库创建时必须依赖至少一个表空间。这种解耦设计既保证灵活性,又确保数据必须落地存储。</think>在GaussDB中,**创建数据库**和**创建表空间**是两个密切相关但职责不同的操作,它们的关系可概括为:**表空间数据库提供物理存储空间,数据库表空间服务的逻辑容器**。具体关系如下: ### 1. **职责分工** * **数据库 (`DATABASE`)**: * 是**逻辑上的数据集合**,包含表、索引、视图、函数等所有数据库对象。 * 定义了数据的**逻辑边界**和**访问权限**(用户、角色)。 * 一个数据库实例下可创建多个数据库(如 `db1`, `db2`)。 * **表空间 (`TABLESPACE`)**: * 是**物理存储位置**的映射,对应磁盘上的一个或多个数据文件(如 `.dbf`)。 * 管理**磁盘空间的分配策略**(如块大小、压缩、条带化)。 * **独立于数据库存在**,可被多个数据库共享使用[^1][^3]。 ### 2. **依赖关系** * **创建数据库必须指定表空间**: 当执行 `CREATE DATABASE` 时,必须为其指定一个**默认表空间**(用于存储该数据库的系统表和用户对象,除非显式指定其他表空间)。 ```sql CREATE DATABASE mydb WITH TABLESPACE = ts_default; -- ts_default 是已存在的表空间 ``` * **表空间可先于数据库创建**: 表空间是物理资源,可在创建任何数据库之前预先规划和创建(如引用[3][^3]所示),后续供数据库使用。 ### 3. **使用场景** * **隔离存储**: 为不同业务数据库(如财务库 `db_finance`、日志库 `db_log`)分配独立的表空间(如 `ts_finance`, `ts_log`),实现物理存储隔离和性能管理。 * **性能优化**: 为频访问的表或索引指定性能存储的表空间(如SSD盘),为归档数据指定大容量表空间(如HDD盘)[^3]。 * **空间管理**: 通过监控表空间使用率,独立扩展某个数据库的存储容量,无需影响其他数据库。 ### 4. **关键区别总结** | 特性 | 数据库 (`DATABASE`) | 表空间 (`TABLESPACE`) | |--------------|--------------------------------------|--------------------------------------| | **本质** | 逻辑数据容器 | 物理存储单元 | | **作用** | 组织数据对象、管理权限 | 管理磁盘空间、定义存储策略 | | **创建依赖** | 必须指定表空间 | 可独立创建 | | **共享性** | 对象严格隔离(默认) | 可被多个数据库共用 | | **操作目标** | 存放表、索引等 | 存放数据文件 | ### 示例流程 ```sql -- 1. 先创建表空间(物理存储) CREATE TABLESPACE ts_app1 DATAFILE '/gaussdb/data/ts_app1.dbf' SIZE 100GB; -- 2. 创建数据库,并关联表空间 CREATE DATABASE app_db1 WITH TABLESPACE = ts_app1; -- 3. 在数据库中创建表时,可显式指定表空间(默认为数据库的默认表空间) CREATE TABLE app_db1.order_table (...) TABLESPACE ts_app1; ``` ### 结论 在GaussDB中,**表空间数据库的物理存储基础**。创建数据库时**必须绑定至少一个表空间**作为其存储位置,而表空间作为独立的物理资源池,可被多个数据库灵活共享。这种设计实现了**逻辑数据管理与物理存储资源的解耦**,为数据库的存储规划、性能调优和容量扩展提供了更大灵活性[^1][^3][^4]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值