mysql怎么管理权限 mysql如何设置权限

如何设置mysql用户的权限1、创建新用户
通过root用户登录之后创建
grant all privileges on *.* to testuser@localhost identified by "123456" ;//创建新用户,用户名为testuser,密码为123456 ;
grant all privileges on *.* to testuser@localhost identified by "123456" ;//设置用户testuser,可以在本地访问mysql
grant all privileges on *.* to testuser@"%" identified by "123456" ; //设置用户testuser,可以在远程访问mysql
flush privileges ;//mysql 新设置用户或更改密码后需用flush privileges刷新MySQL的系统权限相关表,否则会出现拒绝访问,还有一种方法,就是重新启动mysql服务器,来使新设置生效
2、设置用户访问数据库权限
grant all privileges on test_db.* to testuser@localhost identified by "123456" ;//设置用户testuser,只能访问数据库test_db,其他数据库均不能访问 ;
grant all privileges on *.* to testuser@localhost identified by "123456" ;//设置用户testuser , 可以访问mysql上的所有数据库 ;
grant all privileges on test_db.user_infor to testuser@localhost identified by "123456" ;//设置用户testuser,只能访问数据库test_db的表user_infor,数据库中的其他表均不能访问 ;
3、设置用户操作权限
grant all privileges on *.* to testuser@localhost identified by "123456" WITH GRANT OPTION ;//设置用户testuser,拥有所有的操作权限,也就是管理员 ;
grant select on *.* to testuser@localhost identified by "123456" WITH GRANT OPTION ;//设置用户testuser,只拥有【查询】操作权限 ;
grant select,insert on *.* to testuser@localhost identified by "123456";//设置用户testuser , 只拥有【查询\插入】操作权限 ;
grant select,insert,update,delete on *.* to testuser@localhost identified by "123456";//设置用户testuser , 只拥有【查询\插入】操作权限 ;
REVOKE select,insert ON what FROM testuser//取消用户testuser的【查询\插入】操作权限 ;
如何设置mysql的权限为所有的用户权限这个设置只要进入 Linux 系统的超级用户状态 # 下面 , 即可以使用 chmod 命令对 MySQL 数据库系统下面的所有文件进行权限设置 。具体的就看你想设置成什么权限,你就可以设置成什么权限了 。chmod 的基本用法如下:
#chmod 750 myfile cr
该命令对 myfile 这个文件设置成:文件所有者(头 3 位)具有:可读(4)、可写(2)、可执行(1)权限;同组用户(中间 3 位)具有:可读(4)、可执行(1)权限;其他用户(后 3 位):不可读(4)、不可写(2)、不可执行(1)权限 。
关于 chmod 更多的参数,你可以使用 man chmod 命令进行查看 。
mysql 权限设置背景
在了解动态权限之前,我们先回顾下 MySQL 的权限列表 。
权限列表大体分为服务级别和表级别,列级别以及大而广的角色(也是MySQL 8.0 新增)存储程序等权限 。我们看到有一个特殊的 SUPER 权限,可以做好多个操作 。比如 SET 变量,在从机重新指定相关主机信息以及清理二进制日志等 。那这里可以看到,SUPER 有点太过强大,导致了仅仅想实现子权限变得十分困难,比如用户只能 SET 变量 , 其他的都不想要 。那么 MySQL 8.0 之前没法实现 , 权限的细分不够明确,容易让非法用户钻空子 。
那么 MySQL 8.0 把权限细分为静态权限和动态权限,下面我画了两张详细的区分图 , 图 1 为静态权限,图 2 为动态权限 。
图 1- MySQL 静态权限的权限管理图
图 2-动态权限图
那我们看到其实动态权限就是对 SUPER 权限的细分 。SUPER 权限在未来将会被废弃掉 。
我们来看个简单的例子,
比如,用户 'ytt2@localhost', 有 SUPER 权限 。

推荐阅读