查找所有数据库大小的命令是什么?
我能够通过使用以下命令找到特定数据库的大小:
select pg_database_size('databaseName');
查找所有数据库大小的命令是什么?
我能够通过使用以下命令找到特定数据库的大小:
select pg_database_size('databaseName');
当前回答
-- Database Size
SELECT pg_size_pretty(pg_database_size('Database Name'));
-- Table Size
SELECT pg_size_pretty(pg_relation_size('table_name'));
其他回答
来自PostgreSQL wiki。
注意:用户无法连接到的数据库按无限大小排序。
SELECT d.datname AS Name, pg_catalog.pg_get_userbyid(d.datdba) AS Owner,
CASE WHEN pg_catalog.has_database_privilege(d.datname, 'CONNECT')
THEN pg_catalog.pg_size_pretty(pg_catalog.pg_database_size(d.datname))
ELSE 'No Access'
END AS Size
FROM pg_catalog.pg_database d
ORDER BY
CASE WHEN pg_catalog.has_database_privilege(d.datname, 'CONNECT')
THEN pg_catalog.pg_database_size(d.datname)
ELSE NULL
END DESC -- nulls first
LIMIT 20
该页面还提供了用于查找最大关系和最大表大小的代码片段。
您可以输入以下psql元命令来获取指定数据库的一些详细信息,包括其大小:
\l+ <database_name>
并获得所有数据库的大小(你可以连接):
\l+
是的,在Postgres中有一个命令可以查找数据库的大小。是这样的:
SELECT pg_database.datname as "database_name", pg_size_pretty(pg_database_size(pg_database.datname)) AS size_in_mb FROM pg_database ORDER by size_in_mb DESC;
du -k /var/lib/postgresql/ |sort -n |tail
SELECT pg_size_pretty(pg_database_size('name of database'));
会给你一个特定数据库的总大小,但我不认为你可以做所有的数据库在一个服务器。
然而你可以这样做…
DO
$$
DECLARE
r RECORD;
db_size TEXT;
BEGIN
FOR r in
SELECT datname FROM pg_database
WHERE datistemplate = false
LOOP
db_size:= (SELECT pg_size_pretty(pg_database_size(r.datname)));
RAISE NOTICE 'Database:% , Size:%', r.datname , db_size;
END LOOP;
END;
$$