繁体   English   中英

撤消MySQL数据库上所有用户的所有权限

[英]Revoke all privileges for all users on a MySQL DB

来自: http//dev.mysql.com/doc/refman/5.0/en/drop-database.html

...删除数据库时,不会自动删除数据库的用户权限。

那么问题就变成了,你如何撤销MySQL数据库上所有用户的所有权限? 我想这很简单,但我很惊讶我无法在任何地方找到它。

您可以使用以下语法撤消特定用户的所有权限:

REVOKE ALL PRIVILEGES, GRANT OPTION FROM user [, user] ...
FLUSH PRIVILEGES;

它会删除指定用户或用户的所有全局,数据库,表,列和例程权限

但是不确定是否有办法同时为所有用户执行此操作。

REVOKE ALL PRIVILEGES ON *.* FROM '<user_name>'@'localhost';
REVOKE ALL PRIVILEGES ON *.* FROM '<user_name>'@'%';

例如。:

REVOKE ALL PRIVILEGES ON *.* FROM 'jeffrey'@'localhost';
REVOKE ALL PRIVILEGES ON *.* FROM 'jeffrey'@'%';

我想你可以这样做:

REVOKE ALL PRIVILEGES FROM '%'@'%';
FLUSH PRIVILEGES;

(不要直接修改MySQL表)

REVOKE ALL PRIVILEGES FROM '%'@'%';

以上可能是危险的,因为我认为它将删除包括root在内的所有用户的所有权限

将其修改为:

REVOKE ALL PRIVILEGES FROM 'user'@'localhost';

要么

REVOKE ALL PRIVILEGES FROM 'user'@'%';

在执行之前

USE mysql; 
DELETE * FROM user;
FLUSH PRIVILEGES;

...将删除所有用户,包括root和您正在连接的任何用户,因此您可能希望添加WHERE子句。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM