【MySQL】MySQL创建用户和授权

MySQL创建用户和授权


1、添加用户

CREATE USER 'username'@'host' IDENTIFIED BY  'password';

说明:
username:你将创建的用户名
host:指定该用户在哪个主机上可以登陆,如果是本地用户可用localhost,如果想让该用户可以从任意远程主机登陆,可以使用通配符%,网段则可用如192.168.1.%
password:该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器


2、授权

GRANT privileges ON databasename.tablename TO 'username'@'host'

说明:
privileges:用户的操作权限,如SELECT,INSERT,UPDATE等,如果要授予所的权限则使用ALL
databasename:数据库名
tablename:表名,如果要授予该用户对所有数据库和表的相应操作权限则可用表示,如.*

用以上命令授权的用户不能给其它用户授权,如果想让该用户可以授权,用以下命令:
GRANT privileges ON databasename.tablename TO ‘username’@‘host’ WITH GRANT OPTION;

通过show grants命令查看权限授予执行的命令:

 SHOW GRANTS FOR 'username';

privilegesCode表示授予的权限类型,常用的有以下几种类型[1]:

  • all privileges:所有权限。
  • all: 所有权限。
  • select:读取权限。
  • delete:删除权限。
  • update:更新权限。
  • create:创建权限。
  • drop:删除数据库、数据表权限。

刷新权限:

flush privileges;

3、撤销权限

REVOKE privilege ON databasename.tablename FROM 'username'@'host';

说明:
privilege, databasename, tablename:同授权部分

例子:
REVOKE SELECT ON . FROM ‘user1’@’%’;
注意:
假如你在给用户’user1’@’%‘授权的时候是这样的(或类似的):GRANT SELECT ON test.user TO ‘user1’@’%’,则在使用REVOKE SELECT ON . FROM ‘user1’@’%’;命令并不能撤销该用户对test数据库中user表的SELECT 操作。相反,如果授权使用的是GRANT SELECT ON . TO ‘user1’@’%’;则REVOKE SELECT ON test.user FROM ‘user1’@’%’;命令也不能撤销该用户对test数据库中user表的Select权限。


4、修改密码

SET PASSWORD FOR 'username'@'host' = PASSWORD('newpassword');

如果是当前登陆用户用:
SET PASSWORD = PASSWORD(“newpassword”);


5.删除用户

命令:DROP USER 'username'@'host';

6.查看用户表

SELECT *FROM mysql.user;

从mysql.user中可以查看到当前已经添加过的用户和权限。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值