内容简介:最近使用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可以定时清理磁盘
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。