- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我删除了 postgres 数据库中的大量行,稍后运行了真空分析。
我注意到 AWS RDS 控制台中的磁盘使用量没有太大变化。
尝试运行查询,基于表的大小也没有太大变化。
SELECT *, pg_size_pretty(total_bytes) AS total
, pg_size_pretty(index_bytes) AS INDEX
, pg_size_pretty(toast_bytes) AS toast
, pg_size_pretty(table_bytes) AS TABLE
FROM (
SELECT *, total_bytes-index_bytes-COALESCE(toast_bytes,0) AS table_bytes FROM (
SELECT c.oid,nspname AS table_schema, relname AS TABLE_NAME
, c.reltuples AS row_estimate
, pg_total_relation_size(c.oid) AS total_bytes
, pg_indexes_size(c.oid) AS index_bytes
, pg_total_relation_size(reltoastrelid) AS toast_bytes
FROM pg_class c
LEFT JOIN pg_namespace n ON n.oid = c.relnamespace
WHERE relkind = 'r'
) a
) a order by total_bytes desc;
这正常吗?或者磁盘空间根本没有被回收?
最佳答案
VACUUM 回收死元组占用的存储空间,也就是说,它将表文件和索引中的空间标记为可重用,但不会释放磁盘空间。
我想你想要的是一个重写整个表和索引的命令,同时只保留真正存在的数据。那将是 CLUSTER,或 VACUUM FULL,或需要重写表的 ALTER TABLE 的一种形式。如果您的性能可以从特定顺序的聚类中获益,那么现在就是这样做的好时机。
虽然它会锁定表,所以不要在需要不间断访问的实时服务器上执行此操作,除非表很小并且您可以忍受几秒钟的停机时间。
关于postgresql - 大量删除行后真空分析不释放 postgres 中的空间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45779877/
我正在尝试在我的数据库上运行 VACUUM 命令,但似乎空间不足: > sqlite3 mydatabase.db "VACUUM" Error: database or disk is full 数
我正在尝试在我的数据库上运行 VACUUM 命令,但似乎空间不足: > sqlite3 mydatabase.db "VACUUM" Error: database or disk is full 数
我正在尝试在我的数据库上运行 VACUUM 命令,但似乎空间不足: > sqlite3 mydatabase.db "VACUUM" Error: database or disk is full 数
我是一名优秀的程序员,十分优秀!