DROP ROLE移除指定的角色。要删除一个 超级用户角色,你必须自己就是一个超级用户。要删除一个非超级用户角 色,你必须具有CREATEROLE特权。
如果一个角色仍然被集簇中任何数据库中引用,它就不能被移除。 如果尝试移除将会抛出一个错误。在删除该角色前,你必须删除 (或者重新分配所有权)它所拥有的所有对象并且收回该角色授予给其他对象的权限。 REASSIGN OWNED和DROP OWNED 命令可以用于这个目的;参阅第 20.4 节获取更多讨论。
不过,没有必要移除涉及该角色的角色成员关系。 DROP ROLE会自动收回目标角色在其他角色中的成员 关系,以及其他角色在目标角色中的成员关系。其他角色不会被删除也不 会被影响。