内容简介:最近使用GreenPlum时,因为大量实验,遗留了很多或临时或正式的表,存储捉襟见肘。准备清理表时,第一件事就是查看表占用磁盘大小,从网上找了一些方法,比较靠谱的是这两篇https://www.cnblogs.com/gobird/archive/2012/04/11/2442846.htmlhttps://my.oschina.net/u/347414/blog/544187
背景
最近使用GreenPlum时,因为大量实验,遗留了很多或临时或正式的表,存储捉襟见肘。准备清理表时,第一件事就是查看表占用磁盘大小,从网上找了一些方法,比较靠谱的是这两篇
https://www.cnblogs.com/gobird/archive/2012/04/11/2442846.html
https://my.oschina.net/u/347414/blog/544187
使用
查询库占用磁盘大小
select pg_size_pretty(pg_database_size( 'MyDatabase' ));
查询表占用磁盘大小
普通表
select pg_size_pretty(pg_relation_size('relation_name')) ;
分区表
使用上面的语句去查分区表,会得到0bytes,就使用上文中创建的函数
-- Function: calc_partition_table(character varying, character varying) -- DROP FUNCTION calc_partition_table(character varying, character varying); CREATE OR REPLACE FUNCTION calc_partition_table(v_schemaname character varying, v_tablename character varying) RETURNS bigint AS $BODY$ DECLARE v_calc BIGINT := 0; v_total BIGINT := 0; v_tbname VARCHAR(200); cur_tbname cursor for select schemaname||'.'||partitiontablename as tb from pg_partitions where schemaname=v_schemaname and tablename=v_tablename; BEGIN OPEN cur_tbname; loop FETCH cur_tbname into v_tbname; if not found THEN exit; end if; EXECUTE 'select pg_relation_size('''||v_tbname||''')' into v_calc; v_total:=v_total+v_calc; end loop; CLOSE cur_tbname; RETURN v_total; end; $BODY$ LANGUAGE plpgsql VOLATILE; ALTER FUNCTION calc_partition_table(character varying, character varying) OWNER TO gpadmin;
其中 gpadmin是你的username
然后使用select查询,如
select calc_partition_table ('public', 'test_partition_table')
PostgreSQL 提供了多个系统管理函数来查看表,索引,表空间及数据库的大小
函数名 | 返回类型 | 描述 |
pg_column_size(any) | int | 存储一个指定的数值需要的字节数(可能压缩过) |
pg_database_size(oid) | bigint | 指定OID的数据库使用的磁盘空间 |
pg_database_size(name) | bigint | 指定名称的数据库使用的磁盘空间 |
pg_indexes_size(regclass) | bigint | 关联指定表OID或表名的表索引的使用总磁盘空间 |
pg_relation_size(relation regclass, fork text) | bigint | 指定OID或名的表或索引,通过指定fork('main', 'fsm' 或'vm')所使用的磁盘空间 |
pg_relation_size(relation regclass) | bigint | pg_relation_size(..., 'main')的缩写 |
pg_size_pretty(bigint) | text | Converts a size in bytes expressed as a 64-bit integer into a human-readable format with size units |
pg_size_pretty(numeric) | text | 把以字节计算的数值转换成一个人类易读的尺寸单位 |
pg_table_size(regclass) | bigint | 指定表OID或表名的表使用的磁盘空间,除去索引(但是包含TOAST,自由空间映射和可视映射) |
pg_tablespace_size(oid) | bigint | 指定OID的表空间使用的磁盘空间 |
pg_tablespace_size(name) | bigint | 指定名称的表空间使用的磁盘空间 |
pg_total_relation_size(regclass) | bigint | 指定表OID或表名使用的总磁盘空间,包括所有索引和TOAST数据 |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 如何清理Docker占用的磁盘空间
- 治疗磁盘空间不足焦虑症,释放容器占用空间:Win10 + Docker 篇
- docker的storage-driver是overlay2时,限制单个容器可占用的磁盘空间
- 原 荐 java计算对象占用内存大小:lucene专用于计算堆内存占用大小的工具类
- .NET/C# 如何获取当前进程的 CPU 和内存占用?如何获取全局 CPU 和内存占用?
- shell之磁盘容量检查,配合crontab可以定时清理磁盘
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Design systems
Not all design systems are equally effective. Some can generate coherent user experiences, others produce confusing patchwork designs. Some inspire teams to contribute to them, others are neglected. S......一起来看看 《Design systems》 这本书的介绍吧!