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