dropdb — 移除一个PostgreSQL数据库
dropdb [connection-option...] [option...] dbname
dropdb删除一个现有的 PostgreSQL数据库。 执行此命令的用户必须是数据库超级用户或该数据库的拥有者。
dropdb是SQL命令 DROP DATABASE的一个包装器。 通过此工具删除数据库与通过其他访问服务器的方法删除数据库,在效果上没有区别。
dropdb接受下列命令行参数:
dbname指定要移除的数据库名称。
-e--echo回显dropdb生成并发送给服务器的命令。
-f--force在删除目标数据库之前,尝试终止所有到该数据库的现有连接。 关于此选项的更多信息,见DROP DATABASE。
-i--interactive在执行任何破坏性操作之前发出确认提示。
-V--version打印dropdb版本并退出。
--if-exists如果数据库不存在,则不要抛出错误。这种情况下会发出一个提示。
-?--help显示有关dropdb命令行参数的帮助并退出。
dropdb也接受下列用于连接参数的命令行参数:
-h host--host=host指定服务器所在机器的主机名。如果该值以斜杠开头, 则它将被用作 Unix 域套接字的目录。
-p port--port=port指定服务器监听连接所用的 TCP 端口或本地 Unix 域套接字文件扩展名。
-U username--username=username指定用于连接的用户名。
-w--no-password从不发出密码提示。如果服务器要求密码认证,而密码又无法通过诸如 .pgpass文件等其他方式获得,则连接尝试将失败。 该选项适合没有用户在场输入密码的批处理作业和脚本。
-W--password强制dropdb在连接数据库之前提示输入密码。
这个选项并非必不可少,因为如果服务器要求密码认证, dropdb会自动提示输入密码。 不过,dropdb会浪费一次连接尝试,才知道服务器需要密码。 在某些情况下,为了避免这次额外的连接尝试,提前指定-W是值得的。
--maintenance-db=dbname指定在删除目标数据库时要连接到的数据库名称。如果未指定,将使用 postgres数据库;若该数据库不存在(或者它正是要被删除的数据库), 则改用template1。这也可以是一个 连接字符串。如果是这种情况, 其中的连接字符串参数将覆盖任何冲突的命令行选项。
PGHOSTPGPORTPGUSER默认连接参数
PG_COLOR指定诊断消息是否使用颜色。可选值为 always、auto和 never。
与大多数其他PostgreSQL工具一样,此工具也使用 libpq支持的环境变量 (见Section 32.15)。
若遇到困难,请参见DROP DATABASE和psql, 其中讨论了潜在问题和错误消息。数据库服务器必须运行在目标主机上。 此外,libpq前端库使用的任何默认连接设置和环境变量也都会生效。
要在默认数据库服务器上删除数据库demo:
$dropdb demo
要使用主机eden、端口 5000 上的服务器删除数据库demo, 并带确认提示以及查看底层命令:
$dropdb -p 5000 -h eden -i -e demoDatabase "demo" will be permanently deleted. Are you sure? (y/n)yDROP DATABASE demo;
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。