vacuumdb命令用于收集无用文件并且分析一个PostgreSQL数据库。
用法
vacuumdb [connection-option…] [–full | -f] [–verbose | -v] [–analyze | -z] [–table | -t table [( column [,…] )] ] [dbname]
vacuumdb [connection-options…] [–all | -a] [–full | -f] [–verbose | -v] [– analyze | -z]
描述
vacuumdb 是一个用于整理 PostgreSQL 数据库的工具。vacuumdb 还将会生成用于 PostgreSQL 查询优化器的内部统计数据。
vacuumdb 是 SQL 命令 VACUUM 的封装。 因此,用哪种方法清理数据库都没什么特别的。
参数
-a
–all
清理所有数据库。
[-d] dbname
[–dbname] dbname
声明要被清理或分析的数据库名称。如果没有声明这个参数并且没有使用 -a(或 — all), 那么从环境变量 PGDATABASE 里读取数据库名。如果那个也没有设置,则使用连接的用户名。
-e
–echo
回显 vacuumdb 生成的查询并且把它发送到服务器。
-f
–full
执行”完全”清理
-q
–quiet
不显示响应。
-t table [ (column [,…]) ]
–table table [ (column [,…]) ]
只是清理或分析 table。 字段名称只是在与 –analyze 选项联合使用时才需要声明。
提示: 如果你声明了要清理的字段,你可能不得不在 shell 上逃逸圆括弧(见下面的例子)。
-v
–verbose
在处理过程中打印详细信息。
-z
–analyze
计算用于优化器的该数据库的统计值。
联接参数
-h host
–host host
声明运行服务器的机器的主机名。 如果主机名以斜杠开头,则它被用做到 Unix 域套接字的路径。
-p port
–port port
声明服务器在侦听联接的 TCP 端口号或一个本地的 Unix 域套接字文件句柄。
-U username
–username username
进行联接的用户名。
-W
–password
强制口令输入提示。
实例
-bash-3.2$ vacuumdb test #整理数据库 test
-bash-3.2$ vacuumdb –analyze test #为优化器清理和分析一个名为 test 的数据库
-bash-3.2$ vacuumdb –analyze –verbose –table ‘foo(bar)’ test #清理数据库xyzzy 里表 foo,并且为优化器分析列 bar