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

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

image
姬紫颜
片是落叶处,一切尽萧然。
4
发布数
0
关注者
1766
累计阅读

热门教程文档

Maven
5小节
Objective-C
29小节
Redis
14小节
Javascript
24小节
PHP
52小节
广告