2005-02-27 07:31:15 +08:00
|
|
|
This module contains several functions that report the on-disk size of a
|
|
|
|
given database object in bytes:
|
2002-02-23 07:05:35 +08:00
|
|
|
|
2004-09-09 03:35:33 +08:00
|
|
|
int8 database_size(name)
|
|
|
|
int8 relation_size(text)
|
2005-02-27 07:31:15 +08:00
|
|
|
int8 indexes_size(text)
|
|
|
|
int8 total_relation_size(text)
|
2002-02-23 07:05:35 +08:00
|
|
|
|
2004-09-09 03:35:33 +08:00
|
|
|
int8 pg_database_size(oid)
|
|
|
|
int8 pg_relation_size(oid)
|
2004-09-29 03:35:43 +08:00
|
|
|
int8 pg_tablespace_size(oid)
|
2002-02-23 07:05:35 +08:00
|
|
|
|
2004-09-09 03:35:33 +08:00
|
|
|
text pg_size_pretty(int8)
|
|
|
|
|
2005-02-27 07:31:15 +08:00
|
|
|
setof record relation_size_components(text)
|
|
|
|
|
|
|
|
The first four functions take the name of the object (possibly
|
|
|
|
schema-qualified for the latter three) and returns the size of the
|
|
|
|
on-disk files in bytes.
|
2004-09-09 03:35:33 +08:00
|
|
|
|
|
|
|
SELECT database_size('template1');
|
|
|
|
SELECT relation_size('pg_class');
|
2005-02-27 07:31:15 +08:00
|
|
|
SELECT indexes_size('pg_class');
|
|
|
|
SELECT total_relation_size('pg_class');
|
2004-09-09 03:35:33 +08:00
|
|
|
|
2005-02-27 07:31:15 +08:00
|
|
|
These functions take object OIDs:
|
2004-09-09 03:35:33 +08:00
|
|
|
|
|
|
|
SELECT pg_database_size(1); -- template1 database
|
|
|
|
SELECT pg_relation_size(1259); -- pg_class table size
|
2004-09-29 03:35:43 +08:00
|
|
|
SELECT pg_tablespace_size(1663); -- pg_default tablespace
|
2004-09-09 03:35:33 +08:00
|
|
|
|
2005-02-27 07:31:15 +08:00
|
|
|
The indexes_size() function returns the total size of the indices for a
|
|
|
|
relation, including any toasted indices.
|
|
|
|
|
|
|
|
The total_relation_size() function returns the total size of the relation,
|
|
|
|
all its indices, and any toasted data.
|
|
|
|
|
2004-09-29 03:35:43 +08:00
|
|
|
Please note that relation_size and pg_relation_size report only the size of
|
2005-02-27 07:31:15 +08:00
|
|
|
the selected relation itself; any related indexes or toast tables are not
|
|
|
|
counted. To obtain the total size of a table including all indices and
|
|
|
|
toasted data, use total_relation_size().
|
|
|
|
|
|
|
|
The last function, relation_size_components(), returns a set of rows
|
|
|
|
showing the sizes of the component relations constituting the input
|
|
|
|
relation.
|
|
|
|
|
|
|
|
Examples
|
|
|
|
========
|
|
|
|
|
|
|
|
I've loaded the following table with a little less than 3 MB of data for
|
|
|
|
illustration:
|
|
|
|
|
|
|
|
create table fat ( id serial, data varchar );
|
|
|
|
create index fat_uidx on fat (id);
|
|
|
|
create index fat_idx on fat (data);
|
|
|
|
|
|
|
|
You can retrieve a rowset containing constituent sizes as follows:
|
|
|
|
|
|
|
|
# SELECT relation_size_components('fat');
|
|
|
|
relation_size_components
|
|
|
|
----------------------------------------------------
|
|
|
|
(2088960,65536,2891776,fat,r,59383,59383)
|
|
|
|
(32768,704512,737280,pg_toast_59383,t,59386,59386)
|
|
|
|
(0,32768,32768,pg_toast_59383_index,i,59388,59388)
|
|
|
|
(0,2039808,2039808,fat_idx,i,59389,59389)
|
|
|
|
(0,49152,49152,fat_uidx,i,59911,59911)
|
|
|
|
(5 rows)
|
|
|
|
|
|
|
|
To see a more readable output of the rowset:
|
|
|
|
|
|
|
|
SELECT *
|
|
|
|
FROM relation_size_components('fat') AS (idxsize BIGINT,
|
|
|
|
datasize BIGINT,
|
|
|
|
totalsize BIGINT,
|
|
|
|
relname NAME,
|
|
|
|
kind "char",
|
|
|
|
relid OID,
|
|
|
|
node OID)
|
|
|
|
ORDER BY totalsize;
|
|
|
|
|
|
|
|
idxsize | datasize | totalsize | relname | kind | relid | node
|
|
|
|
---------+----------+-----------+----------------------+------+-------+-------
|
|
|
|
0 | 32768 | 32768 | pg_toast_59383_index | i | 59388 | 59388
|
|
|
|
0 | 49152 | 49152 | fat_uidx | i | 59911 | 59911
|
|
|
|
32768 | 704512 | 737280 | pg_toast_59383 | t | 59386 | 59386
|
|
|
|
0 | 2039808 | 2039808 | fat_idx | i | 59389 | 59389
|
|
|
|
2088960 | 65536 | 2891776 | fat | r | 59383 | 59383
|
|
|
|
(5 rows)
|
|
|
|
|
|
|
|
To see the sum total size of a relation:
|
|
|
|
|
|
|
|
# select total_relation_size('fat');
|
|
|
|
total_relation_size
|
|
|
|
-------------------------
|
|
|
|
2891776
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
To see just the size of the uncompressed relation data:
|
|
|
|
|
|
|
|
# select relation_size('fat');
|
|
|
|
relation_size
|
|
|
|
---------------
|
|
|
|
65536
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
To see the size of all related indices:
|
|
|
|
|
|
|
|
# select indexes_size('fat');
|
|
|
|
indexes_size
|
|
|
|
--------------
|
|
|
|
2088960
|
|
|
|
(1 row)
|
2004-09-09 03:35:33 +08:00
|
|
|
|
2004-09-29 03:35:43 +08:00
|
|
|
To install, just run make; make install. Then load the functions
|
2004-09-09 03:35:33 +08:00
|
|
|
into any database using dbsize.sql.
|