2

我在 PostgreSQL DB 中有一个表,并从该表中进行选择,但有一些约束,我想知道这个选择有多少磁盘空间。我知道有一个 postgres 函数pg_total_relation_size可以为我提供 DB 中某个表的大小,但我怎样才能找到“子表”的大小?

有任何想法吗?

我使用 PostgreSQL 9.1

4

1 回答 1

11

要获取数据大小,允许TOAST压缩等:

regress=> SELECT sum(pg_column_size(devices)) FROM devices WHERE country = 'US';
 sum 
-----
 105
(1 row)

要获得所需的磁盘存储,包括块分配开销、标头等:

regress=> CREATE TEMPORARY TABLE query_out AS SELECT * FROM devices WHERE country = 'US';
SELECT 3
regress=> SELECT pg_total_relation_size('query_out');
 pg_total_relation_size 
------------------------
                  16384
(1 row)

为什么结果如此不同?因为后一个查询报告的是主表的 8k 块的大小,以及 TOAST 表的 8k 块的大小。它并不关心这些块大部分是空的。

于 2012-11-20T23:18:52.953 回答