我在PostgreSQL数据库中有一个表,并且从这个表中选择了一些限制条件,并且我想知道这个选择有多少磁盘空间。我知道有一个postgres函数pg_total_relation_size
,它给了我一些在DB中的表的大小,但我怎么能找到'subtable'的大小?PostgreSQL选择结果大小
任何想法?
我使用PostgreSQL 9.1
我在PostgreSQL数据库中有一个表,并且从这个表中选择了一些限制条件,并且我想知道这个选择有多少磁盘空间。我知道有一个postgres函数pg_total_relation_size
,它给了我一些在DB中的表的大小,但我怎么能找到'subtable'的大小?PostgreSQL选择结果大小
任何想法?
我使用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块的大小。它并不在意这些块大部分是空的。
谢谢,这正是我所期待的,'octet_length'也是可以的,但它给了我二进制字符串中的字节数,所以如果字符串只是一个文本,我会得到错误的大小... – golinko
@ann octet_length也不会准确反映TOAST的空间使用情况。请参阅http://stackoverflow.com/questions/13304572/how-can-pg-column-size-be-smaller-than-octet-length –
16384?这是什么意思?它是在kb还是字节? –
select语句没有“磁盘大小”,因为它没有存储在任何地方。 –
好的,所以我需要先存储它才能获得大小?有其他的选择吗?我的意思是,我只是想知道一个子表的大小... – golinko
你可以将其假脱机到一个文本文件,以粗略估计数据的原始大小 –