一、创建用户
CREATE USER 'dev'@'%' IDENTIFIED BY 'dev123456';
二、用户授权
2.1、授权所有权限给dev用户
grant all privileges on *.* to 'dev'@'%' identified by 'dev123456' with grant option;
- all privileges:表示将所有权限授予给用户。也可指定具体的权限,如:SELECT、CREATE、DROP等。
- on:表示这些权限对哪些数据库和表生效,格式:数据库名.表名,这里写“*”表示所有数据库,所有表。如果我要指定将权限应用到test库的user表中,可以这么写:test.user
- to:将权限授予哪个用户。格式:”用户名”@”登录IP或域名”。%表示没有限制,在任何主机都可以登录。比如:”yangxin”@”192.168.0.%”,表示yangxin这个用户只能在192.168.0IP段登录
- identified by:指定用户的登录密码
- 可以使用GRANT给用户添加权限,权限会自动叠加,不会覆盖之前授予的权限,比如你先给用户添加一个SELECT权限,后来又给用户添加了一个INSERT权限,那么该用户就同时拥有了SELECT和INSERT权限。
2.2、授权所有权限给单库
grant all on dev_test.* to 'dev'@'%';
2.3、授权指定权限给dev用户
grant select,create,drop,update,alter on *.* to 'dev'@'%' identified by 'dev23456' with grant option;
2.4、授权dev用户在任意主机访问
GRANT ALL PRIVILEGES ON *.* TO 'dev'@'%';
2.5、刷新权限
flush privileges;
2.6、回收权限
revoke create on *.* from 'dev@%';
2.7、查看用户
select user,host from mysql.user;
2.8、删除用户
drop user 'test'@'localhost';
2.9、重命名用户
rename user 'dev3'@'%' to 'dev1'@'%';
2.10、修改密码
mysql> use mysql;
mysql5.7之前
mysql> update user set password=password('123456') where user='root';
mysql5.7之后
mysql> update user set authentication_string=password('123456') where user='root';