DROP ROLE删除指定的角色。要删除一个超级用户角色,你自己必须也是一个超级用户; 要删除非超级用户角色,你必须有CREATEROLE权限。
commands can be useful for this purpose. 不能删除仍然被集群中的任意数据库引用的角色,如果想删除它,会抛出一个错误。 在删除一个角色之前,你必须删除它拥有的所有对象(或者重新赋予他们新的所有者), 并且撤销赋予该角色的任何权限。REASSIGN OWNED和DROP OWNED命令可以达到这个目的。
不过,没有必要删除涉及该角色的角色成员关系;DROP ROLE自动撤销目标角色在 任何其它角色里面的成员关系,以及其它角色在目标角色里的成员关系。其它角色不会被删除, 也不会受到其它影影响。