你好,
我发现实际数据库大小(在HDD上和pg_database_size()调用显示)和大小之间存在很大差异,通过总计pg_total_relation_size()检索的总关系大小来计算.
第一个是62G,最后一个是16G(右边是最大表中删除数据的差异)
select current_database(),pg_size_pretty( sum(total_relation_raw_size)::bigint ) as calculated_database_size,pg_size_pretty( pg_database_size(current_database()) ) as database_size from (select pg_total_relation_size(relid) as total_relation_raw_size from pg_stat_all_tables -- this includes also system tables shared between databases where schemaname != 'pg_toast' ) as stats;
似乎那里有一些悬空数据.出现这种情况后,我们从该数据库中转储并完全抽空了大量未使用的数据.
BobG写道,LOB是一个非常有效的问题,因为当应用程序表(包含OID)的行被删除时,它们不会被删除.
这些不会被VACUUM进程自动删除,只有您已经在它们上运行VACUUMLO.
示例电话:
vacuumlo -U postgres -W -v <database_name>
原文地址:https://www.jb51.cc/postgresql/191917.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。