PostgreSQL【查看数据库占用物理空间大小】

1.手动查看

查看数据库mydatabase的oid

SELECT oid from pg_database where datname='mydatabase';

  oid    |         datname

———-+————————-

  67889 | mydatabase

查找数据库的目录PostgreSQL\9.2\data\base下,查看名称为12002的文件的大小即是数据库postgres的大小;

cd /var/lib/postgres/data/base/12002
du -sh

2.SQL语句查询

select pg_size_pretty(pg_database_size('mydatabase'));

pg_size_pretty
—————-
 42 GB
(1 row)

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数据

    原文作者:数据库基础
    原文地址: https://my.oschina.net/u/347414/blog/544187
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞