vacuumlo
是一个 Contrib 模块,提供了一个实用程序,可以删除孤立的 大对象。
vacuumlo
添加于 PostgreSQL 6.5。
更改历史记录
- PostgreSQL 12
- PostgreSQL 9.4
- 使用游标来限制客户端内存使用(提交 67ccbb08)
- PostgreSQL 9.3
- 现在设置
fallback_application_name
(提交 17676c78)
- 现在设置
- PostgreSQL 9.2
- 添加选项
-l
(初始提交 b69f2e36)
- 添加选项
- PostgreSQL 8.4
- 添加选项
-w
/--no-password
(提交 9de59fd1)
- 添加选项
- PostgreSQL 6.5
- 添加(提交 94bb87f9)
请注意,在 PostgreSQL 9.2 中添加的 -l
选项也已反向移植到 PostgreSQL 9.0 (9.0.8) 和 PostgreSQL 9.1 (9.1.4)。
示例
删除与表无关的大对象
$ psql -c '\dl' Large objects ID | Owner | Description -------+----------+---------------------- 16459 | postgres | A small large object (1 row) $ vacuumlo -n postgres Connected to database "postgres" Test run: no large objects will be removed! Would remove 1 large objects from database "postgres". $ vacuumlo postgres $ psql -c '\dl' Large objects ID | Owner | Description ----+-------+------------- (0 rows)
尝试删除与表相关联的大对象
postgres=# CREATE TABLE lo_test (id SERIAL PRIMARY KEY, lo_oid OID); CREATE TABLE postgres=# \lo_import /tmp/hello-world.txt lo_import 16479 postgres=# INSERT INTO lo_test VALUES (DEFAULT, 16479); INSERT 0 1 postgres=# \q $ vacuumlo -n postgres Connected to database "postgres" Test run: no large objects will be removed! Checking lo_oid in public.lo_test Would remove 0 large objects from database "postgres".
参考
- PostgreSQL 文档: vacuumlo