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

1.手动查看 sql

查看数据库mydatabase的oid 数据库

SELECT oid from pg_database where datname='mydatabase';
  oid    |         datname
----------+-------------------------
  67889 | mydatabase

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

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 提供了多个系统管理函数来查看表,索引,表空间及数据库的大小 post

函数名 返回类型 描述
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数据
相关文章
相关标签/搜索