ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
# REVOKE ## Name REVOKE -- 删除访问权限 ## Synopsis ``` REVOKE [ GRANT OPTION FOR ] { { SELECT | INSERT | UPDATE | DELETE | TRUNCATE | REFERENCES | TRIGGER } [, ...] | ALL [ PRIVILEGES ] } ON { [ TABLE ] _table_name_ [, ...] | ALL TABLES IN SCHEMA _schema_name_ [, ...] } FROM { [ GROUP ] _role_name_ | PUBLIC } [, ...] [ CASCADE | RESTRICT ] REVOKE [ GRANT OPTION FOR ] { { SELECT | INSERT | UPDATE | REFERENCES } ( _column_name_ [, ...] ) [, ...] | ALL [ PRIVILEGES ] ( _column_name_ [, ...] ) } ON [ TABLE ] _table_name_ [, ...] FROM { [ GROUP ] _role_name_ | PUBLIC } [, ...] [ CASCADE | RESTRICT ] REVOKE [ GRANT OPTION FOR ] { { USAGE | SELECT | UPDATE } [, ...] | ALL [ PRIVILEGES ] } ON { SEQUENCE _sequence_name_ [, ...] | ALL SEQUENCES IN SCHEMA _schema_name_ [, ...] } FROM { [ GROUP ] _role_name_ | PUBLIC } [, ...] [ CASCADE | RESTRICT ] REVOKE [ GRANT OPTION FOR ] { { CREATE | CONNECT | TEMPORARY | TEMP } [, ...] | ALL [ PRIVILEGES ] } ON DATABASE _database_name_ [, ...] FROM { [ GROUP ] _role_name_ | PUBLIC } [, ...] [ CASCADE | RESTRICT ] REVOKE [ GRANT OPTION FOR ] { USAGE | ALL [ PRIVILEGES ] } ON DOMAIN _domain_name_ [, ...] FROM { [ GROUP ] _role_name_ | PUBLIC } [, ...] [ CASCADE | RESTRICT ] REVOKE [ GRANT OPTION FOR ] { USAGE | ALL [ PRIVILEGES ] } ON FOREIGN DATA WRAPPER _fdw_name_ [, ...] FROM { [ GROUP ] _role_name_ | PUBLIC } [, ...] [ CASCADE | RESTRICT ] REVOKE [ GRANT OPTION FOR ] { USAGE | ALL [ PRIVILEGES ] } ON FOREIGN SERVER _server_name_ [, ...] FROM { [ GROUP ] _role_name_ | PUBLIC } [, ...] [ CASCADE | RESTRICT ] REVOKE [ GRANT OPTION FOR ] { EXECUTE | ALL [ PRIVILEGES ] } ON { FUNCTION _function_name_ ( [ [ _argmode_ ] [ _arg_name_ ] _arg_type_ [, ...] ] ) [, ...] | ALL FUNCTIONS IN SCHEMA _schema_name_ [, ...] } FROM { [ GROUP ] _role_name_ | PUBLIC } [, ...] [ CASCADE | RESTRICT ] REVOKE [ GRANT OPTION FOR ] { USAGE | ALL [ PRIVILEGES ] } ON LANGUAGE _lang_name_ [, ...] FROM { [ GROUP ] _role_name_ | PUBLIC } [, ...] [ CASCADE | RESTRICT ] REVOKE [ GRANT OPTION FOR ] { { SELECT | UPDATE } [, ...] | ALL [ PRIVILEGES ] } ON LARGE OBJECT _loid_ [, ...] FROM { [ GROUP ] _role_name_ | PUBLIC } [, ...] [ CASCADE | RESTRICT ] REVOKE [ GRANT OPTION FOR ] { { CREATE | USAGE } [, ...] | ALL [ PRIVILEGES ] } ON SCHEMA _schema_name_ [, ...] FROM { [ GROUP ] _role_name_ | PUBLIC } [, ...] [ CASCADE | RESTRICT ] REVOKE [ GRANT OPTION FOR ] { CREATE | ALL [ PRIVILEGES ] } ON TABLESPACE _tablespace_name_ [, ...] FROM { [ GROUP ] _role_name_ | PUBLIC } [, ...] [ CASCADE | RESTRICT ] REVOKE [ GRANT OPTION FOR ] { USAGE | ALL [ PRIVILEGES ] } ON TYPE _type_name_ [, ...] FROM { [ GROUP ] _role_name_ | PUBLIC } [, ...] [ CASCADE | RESTRICT ] REVOKE [ ADMIN OPTION FOR ] _role_name_ [, ...] FROM _role_name_ [, ...] [ CASCADE | RESTRICT ] ``` ## 描述 `REVOKE`撤销以前赋予一个或多个角色的权限。关键字`PUBLIC` 代表隐含定义的、拥有所有角色的组。 参阅[GRANT](#calibre_link-19)命令的描述获取权限类型的含义。 请注意,任何特定的角色都将拥有直接赋予它的权限,加上它所在组的权限, 再加上赋予`PUBLIC`的权限的总和。因此,举例来说,废止`PUBLIC` 的`SELECT`权限并不意味着所有角色都失去了对该对象的`SELECT`权限: 那些直接得到的权限以及通过一个组得到的权限仍然有效。相似的,废止一个用户的`SELECT` 权限可能并不阻止用户使用`SELECT`,如果`PUBLIC`或其他成员组仍然拥有 `SELECT`权限。 如果指定了`GRANT OPTION FOR`,那么只是撤销对该权限的授权的权力, 而不是撤销该权限本身。否则,权限和授权选项都被撤销。 如果一个用户持有某个权限,并且还有授权的选项,并且还把这个权限赋予了其它用户, 那么那些其它用户持有的权限都叫做依赖性权限。如果第一个用户持有的权限或者授权选项被撤销, 而依赖性权限仍然存在;那么如果声明了`CASCADE`,则所有依赖性权限都被撤销, 否则撤销动作就会失败。这个递规的撤销只影响那种通过一个用户链赋予的权限, 这个链条可以通过这条`REVOKE`命令里面给出的用户跟踪。因此, 如果权限本身是通过其它用户赋予的,那么被影响的用户可以有效地保留这个权限。 当在表上撤销权限时,相应的字段权限(如果有)也自动撤销。另一方面, 如果已经赋予了一个角色在表上的权限,那么在单独的字段上删除相同的权限将不会有作用。 在撤销一个角色里的成员关系的时候,不是调用`ADMIN OPTION`而是调用 `GRANT OPTION`,但是行为类似。不过这种形式的命令不允许出现`GROUP`噪声字。 ## 注意 使用[psql](#calibre_link-23)的`\dp`命令显示在一个现存表和字段上赋予的权限。 又见[GRANT](#calibre_link-19)获取关于格式的信息。对于非表对象,可以使用`\d` 命令显示他们的权限。 一个用户只能撤销由它自己直接赋予的权限。举例来说,如果用户 A 带着授权选项把一个权限赋予了用户 B , 然后用户 B 又赋予了用户 C ,那么用户 A 不能直接将 C 的权限撤销。但是, 用户 A 可以撤销用户 B 的授权选项,并且使用`CASCADE`选项,这样, 用户 C 的权限就会自动被撤销。另外一个例子:如果 A 和 B 都赋予了 C 同样的权限, 则 A 可以撤销他自己的授权选项,但是不能撤销 B 的,因此 C 仍然有效地拥有该权限。 如果一个对象的非所有者试图`REVOKE`对象上的权限,那么,如果这个用户没有该对象上的权限, 则命令马上失败。只要他有某些权限,则命令继续,但是它只撤销那些该用户有授权选项的权限。 如果没有在授权选项,那么`REVOKE ALL PRIVILEGES`形式将发出一个错误信息, 而对于其它形式的命令而言,如果同样是命令中指定名字的权限没有相应的授权选项, 那么该命令将发出一个警告。原则上这些语句也适用于对象所有者, 但是因为所有者总是认为持有所有授权选项,所以这种情况绝不会发生。 如果一个超级用户发出一个`GRANT`或`REVOKE`命令, 那么命令是以被影响的对象的所有者执行的。因为所有权限最终从对象所有者 (可能间接通过赋权选项)获取,超级用户可以废除所有权限, 但是这样就要求像上面说的那样使用`CASCADE`。 `REVOKE`也可以由一个并非被影响对象的所有者来执行, 不过这个角色必须是拥有该对象的角色的成员,或者是一个在该对象上持有 `WITH GRANT OPTION`的角色的成员。在这种情况下, 该命令执行起来就好像是由实际拥有该对象的角色,或者是在该对象上持有 `WITH GRANT OPTION`权限的角色发出的一样。比如,如果表`t1` 被`g1`所有,而`u1`是`g1`的成员,那么`u1` 可以撤销`t1`上的权限,而纪录为`g1`发出的命令。这种现像包括 `u1`和其它`g1`角色成员发出的授权。 如果执行`REVOKE`的角色持有权限是通过多层成员关系获得的, 那么具体是哪个包含的角色执行的该命令就是未声明的。在这种场合下, 最好的方法是使用`SET ROLE`成为你希望执行`REVOKE`的角色。 不这么做的后果可能导致删除你不想删除的权限,或者是啥权限都没有删除。 ## 例子 撤销公众在表`films`上的插入权限: ``` REVOKE INSERT ON films FROM PUBLIC; ``` 撤销用户`manuel`对视图`kinds`的所有权限: ``` REVOKE ALL PRIVILEGES ON kinds FROM manuel; ``` 请注意这样实际上意味着"撤销所有我赋予的权限"。 删除用户`joe`的`admins`成员关系: ``` REVOKE admins FROM joe; ``` ## 兼容性 [GRANT](#calibre_link-19)命令的兼容性信息基本上也适用于`REVOKE`。 标准要求`RESTRICT`或`CASCADE`必须出现, 但是PostgreSQL假设缺省是`RESTRICT`。 ## 又见 [GRANT](#calibre_link-19)