暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

openGauss VACUUM FULL一张表后,表文件大小无变化

原创 墨天轮 2020-11-12
970

问题现象

使用VACUUM FULL命令对一张表进行清理,清理完成后表大小和清理前一样大。

原因分析

假定该表的名称为table_name,对于该现象可能有以下两种原因:

  • table_name表本身没有delete过数据,使用VACUUM FULL table_name后无需清 理delete的数据。因此表大小清理前后一样大。

  • 在执行VACUUM FULL table_name时有并发的事务存在,可能会导致VACUUM FULL跳过清理那些近删除的数据,导致清理不完全。

处理办法

对于可能原因的第二种情况,给出如下两种处理方法:

  • 如果在VACUUM FULL时有并发的事务存在,此时需要等待所有事务结束,再次 执行VACUUM FULL命令对该表进行清理。

  • 如果使用上面的方法清理后,表文件大小仍然无变化,确认无业务操作后,使用 以下SQL查询活跃事务列表状态:

    select txid_current();

    使用该SQL可以查询当前的事务XID。再使用以下命令查看活跃事务列表:

    select txid_current_snapshot();

    如果发现活跃事务列表中有XID比当前的事务XID小时,

    停止数据库再启动数据库,再次使用VACUUM FULL命令对该表 进行清理。

最后修改时间:2020-11-12 17:36:55
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论

文集目录
暂无数据