查找所有数据库大小的命令是什么?
我能够通过使用以下命令找到特定数据库的大小:
select pg_database_size('databaseName');
查找所有数据库大小的命令是什么?
我能够通过使用以下命令找到特定数据库的大小:
select pg_database_size('databaseName');
当前回答
您可以输入以下psql元命令来获取指定数据库的一些详细信息,包括其大小:
\l+ <database_name>
并获得所有数据库的大小(你可以连接):
\l+
其他回答
您可以使用下面的查询来查找PostgreSQL所有数据库的大小。
参考资料来自这个博客。
SELECT
datname AS DatabaseName
,pg_catalog.pg_get_userbyid(datdba) AS OwnerName
,CASE
WHEN pg_catalog.has_database_privilege(datname, 'CONNECT')
THEN pg_catalog.pg_size_pretty(pg_catalog.pg_database_size(datname))
ELSE 'No Access For You'
END AS DatabaseSize
FROM pg_catalog.pg_database
ORDER BY
CASE
WHEN pg_catalog.has_database_privilege(datname, 'CONNECT')
THEN pg_catalog.pg_database_size(datname)
ELSE NULL
END DESC;
您可以从“pg_database”系统表中获得可以连接到的所有数据库的名称。只需将函数应用于名称,如下所示。
select t1.datname AS db_name,
pg_size_pretty(pg_database_size(t1.datname)) as db_size
from pg_database t1
order by pg_database_size(t1.datname) desc;
如果您想让机器而不是人使用输出,则可以删除pg_size_pretty()函数。
-- Database Size
SELECT pg_size_pretty(pg_database_size('Database Name'));
-- Table Size
SELECT pg_size_pretty(pg_relation_size('table_name'));
du -k /var/lib/postgresql/ |sort -n |tail
启动pgAdmin,连接到服务器,单击数据库名称,并选择统计信息选项卡。您将在列表的底部看到数据库的大小。
然后,如果单击另一个数据库,它将停留在statistics选项卡上,因此您可以轻松地查看许多数据库大小,而不需要太多工作。如果您打开表列表,它将显示所有表及其大小。