我在 PostgreSQL 数据库中有一个表,并从该表中进行一些限制的选择,并且我想知道该选择有多少磁盘空间。我知道有一个postgres函数pg_total_relation_size
这给了我数据库中某个表的大小,但是如何找到“子表”的大小?
有任何想法吗?
我使用 PostgreSQL 9.1
要获得数据大小,考虑到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 块的大小。它并不关心这些块大部分是空的。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)