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