首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Vacuum不回收磁盘空间

Vacuum不回收磁盘空间
EN

Stack Overflow用户
提问于 2014-04-05 01:47:51
回答 1查看 1.5K关注 0票数 1

我有一个包含950万条记录的事实表。该表使用distyle=key,并托管在具有2个“小”节点的RedShift集群上。

我在表上执行了许多更新和删除操作,不出所料,我看到“实际”行数远远超过9.5M。

因此,我在表上运行了vacuum,令我惊讶的是,在vacuum完成后,我仍然看到表分配的“行数”没有回到950万条记录。

你能告诉我这种行为的原因是什么吗?

解决这个问题的最好方法是什么?

我的shell中的一些复制-粘贴:

我所说的事实表:

代码语言:javascript
复制
select count(1) from tbl_facts;
9597184

数据库中的“实际”记录数:

代码语言:javascript
复制
select * from stv_tbl_perm where id= 332469;
slice | id | name | rows | sorted_rows | temp | db_id | insert_pristine | delete_pristine
-------+--------+--------------------------------------------------------------------------+----------+-------------+------+--------+-----------------+-----------------
0 | 332469 | tbl_facts | 24108360 | 24108360 | 0 | 108411 | 0 | 1
2 | 332469 | tbl_facts | 24307733 | 24307733 | 0 | 108411 | 0 | 1
3 | 332469 | tbl_facts | 24370022 | 24370022 | 0 | 108411 | 0 | 1
1 | 332469 | tbl_facts | 24597685 | 24597685 | 0 | 108411 | 0 | 1
3211 | 332469 | tbl_facts | 0 | 0 | 0 | 108411 | 3 | 0

(总共有近1亿条记录)。

非常感谢!

EN

回答 1

Stack Overflow用户

发布于 2014-10-14 02:16:58

我认为您需要对特定的事实表运行analyze。在运行vacuum (或任何其他更改行数的命令)之后,Analyze将更新链接到事实表的统计信息。

一定要让我们知道这是不是这样(我手头没有可以测试的表格) :-)

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22869620

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档