在了解mysql的用户管理语句之前,先来了解一下mysql的用户账号格式,即:
username@host
username对应的用户能够通过那个host登录mysql。
host:次mysql用户能够通过哪些客户端主机ip登录当前服务器上的mysql服务。
注:可以使用通配符表示,%和_;192.168.%即表示这个网段的所有主机
1、查询用户
MariaDB [(none)]> use mysql Database changed MariaDB [mysql]> select user,host,password from user; +------+-----------------------+----------+ | user | host | password | +------+-----------------------+----------+ | root | localhost | | | root | localhost.localdomain | | | root | 127.0.0.1 | | | root | ::1 | | | | localhost | | | | localhost.localdomain | | +------+-----------------------+----------+
2、创建用户
方法一:使用create user命令创建mysql用户;
MariaDB [mysql]> create user 'Batman' identified by 'Robin'; Query OK, 0 rows affected (0.00 sec)
方法二:直接在mysql库的user表中插入记录;这种方法较少使用,而且这种方法在设置了严格的sql-mode以后便无法使用;
MariaDB [mysql]> insert into mysql.user(user,host,password) values('superman','192.168.%.%',password('Super'));
注意:如果当前mysql数据库的sql-mode设置为严格检查(TRADITIONAL),则无法使用上述方法插入数据;显示为
ERROR 1364 (HY000): Field 'ssl_cipher' doesn't have a default value
方法三:在授权数据库的同时,如果对应用户不存在,namemysql将会自动创建对应的用户;
MariaDB [mysql]> grant all on testdb.* to superman identified by 'super'; Query OK, 0 rows affected (0.00 sec)
3、删除用户
通常使用drop命令删除用户或者直接删除mysql.user表中对应的用户记录
方法一:使用delete语句删除mysql.user表中对应的记录,但是会有相关信息残留
MariaDB [mysql]> DELETE FROM mysql.user WHERE user='superman' and host='%'; Query OK, 1 row affected (0.01 sec)
上例中,使用了delete语句删除了user表中的用户对应的记录,但是如果某些数据库的权限以赋给该用户;那么,在mysql.db表中,该用户相应的权限将不会被删除,当管路员再次创建superman用户时则会出现如下错误:
MariaDB [mysql]> CREATE USER 'superman'; ERROR 1396 (HY000): Operation CREATE USER failed for 'superman'@'%'
解决上述问题;
我们可以删除mysql.db表中源“superman@%”用户残留的权限数据后,使用
flush privileges
进行刷新,之后正常创建;
方法二:使用drop user命令删除对应用户;用户与用户对应的所有权限将被删除。
MariaDB [mysql]> DROP USER 'superman'; Query OK, 1 row affected (0.01 sec)
4、重命名用户
可用如下语句重命名账户;
rename user OldName to NewName;
实例:
1 MariaDB [mysql]> select user,host,password from user; 2 +--------+-----------------------+-------------------------------------------+ 3 | user | host | password | 4 +--------+-----------------------+-------------------------------------------+ 5 | root | localhost | | 6 | root | localhost.localdomain | | 7 | root | 127.0.0.1 | | 8 | root | ::1 | | 9 | | localhost | | 10 | | localhost.localdomain | | 11 | Batman | % | *5CEE5F1426974EA6CD9708CB85FF206C98ADF749 | 12 +--------+-----------------------+-------------------------------------------+ 13 7 rows in set (0.00 sec) 14 15 MariaDB [mysql]> rename user Batman to Robin; 16 Query OK, 0 rows affected (0.00 sec) 17 18 MariaDB [mysql]> select user,host,password from user; 19 +-------+-----------------------+-------------------------------------------+ 20 | user | host | password | 21 +-------+-----------------------+-------------------------------------------+ 22 | root | localhost | | 23 | root | localhost.localdomain | | 24 | root | 127.0.0.1 | | 25 | root | ::1 | | 26 | | localhost | | 27 | | localhost.localdomain | | 28 | Robin | % | *5CEE5F1426974EA6CD9708CB85FF206C98ADF749 | 29 +-------+-----------------------+-------------------------------------------+ 30 7 rows in set (0.00 sec)
5、用户密码管理
方法一:管理员在系统命令中使用mysqladmin命令设置mysql密码。
mysqladmin -u用户名 -p旧密码 password 新密码
实例:
[root@localhost ~]# mysqladmin -uRobin -pRobin password 123456
如果数据库刚刚被初始化 用户还没有密码,则可用不指定旧密码;
[root@localhost ~]# mysqladmin -uroot password 123456
方法二:使用root用户登入以后,使用SET PASSWORD命令设置用户密码
MariaDB [(none)]> SET PASSWORD for Robin = password('123456'); Query OK, 0 rows affected (0.00 sec)
方法三:忘记root密码,破解root账号密码
- 空数据库的情况下恢复密码
# systemctl stop mariadb # rm -rf /var/lib/mysql/* #删库跑路 # systemctl start mariadb
- 有数据的情况下恢复密码
1)在/etc/my.cnf配置文件的[mydqld]下添加skip-grant-tables和skip-networking参数 2)# systemctl restart mariadb 重启服务 3)执行mysql登录到数据库 4)MariaDB [(none)]> UPDATE mysql.user SET password=PASSWORD('newpassword') WHERE user='root' AND host='localhost'; #更新密码 5)MariaDB [(none)]> FLUSH PRIVILEGES; #刷新授权表 6)退出,修改配置文件,删除skip-grant-tables和skip-networking参数,重启服务
注:也可以在启动mysqld进程时,使用如下选项:
--skip-grant-tables --skip-networking
6、授权管理
1)授权
使用授权语句的语法:
GRANT priv_type ON [object_type] priv_level TO user@'%' [IDENTIFIED BY 'password'] [WITH GRANT OPTION];
如同创建用户方法三;授权时如果用户不存在则创建,所以我们一般不会单独去创建一个用户,而是授权创建一块完成。
1 priv_type 授权类型 2 SELECT 3 INSERT 4 UPDATE 5 DELETE 6 CREATE 7 DROP 8 INDEX 9 ALTER 10 SHOW DATABASES 11 CREATE TEMPORARY TABLES 12 LOCK TABLES 13 CREATE VIEW 14 SHOW VIEW 15 CREATE USER 16 ALL PRIVILEGES 或 ALL 17 object_type 授权对象 18 TABLE 19 FUNCTION 20 PROCEDURE 21 priv_level 授权级别 22 *或*.* 表示所有库 23 db_name.* 表示指定库中的所有表 24 db_name.tbl_name 指定库中的指定表 25 tbl_name 表示当前库的表 26 db_name.routine_name 表示指定库的函数,存储过程,触发器 27 WITH GRANT OPTION 28 MAX_QUERIES_PER_HOUR count 29 MAX_UPDATES_PER_HOUR count 30 MAX_CONNECTIONS_PER_HOUR count 31 MAX_USER_CONNECTIONS count
实例:
MariaDB [school]> GRANT SELECT(stuid,name) ON TABLE school.students TO admin@'%' IDENTIFIED BY 'admin'; #把students表的stuid和name字段的查询权限授权于admin@'%'用户 MariaDB [school]> FLUSH PRIVILEGES; #刷新授权表
授权用户某个数据库多个权限:
MariaDB [school]> GRANT INSERT,DELETE,UPDATE,SELECT ON school.* TO superman'192.168.%.%'; MariaDB [school]> FLUSH PRIVILEGES;
同时授权多个用户:
MariaDB [school]> GRANT INSERT,DELETE,UPDATE,SELECT ON school.* TO superman,batman; MariaDB [school]> FLUSH PRIVILEGES;
2)查询授权
查询指定用户的权限
MariaDB [school]> SHOW GRANTS FOR admin@'%'G #查看指定用户的权限 *************************** 1. row *************************** Grants for admin@%: GRANT USAGE ON *.* TO 'admin'@'%' IDENTIFIED BY PASSWORD '*4ACFE3202A5FF5CF467898FC58AAB1D615029441' *************************** 2. row *************************** Grants for admin@%: GRANT SELECT (stuid, name) ON `school`.`students` TO 'admin'@'%'
查询自己的权限
[root@working ~]# mysql -uadmin -padmin -h192.168.0.7 MariaDB [(none)]> SHOW GRANTS FOR CURRENT_USER()G #查询自己的权限 *************************** 1. row *************************** Grants for admin@%: GRANT USAGE ON *.* TO 'admin'@'%' IDENTIFIED BY PASSWORD '*4ACFE3202A5FF5CF467898FC58AAB1D615029441' *************************** 2. row *************************** Grants for admin@%: GRANT SELECT (stuid, name) ON `school`.`students` TO 'admin'@'%'
3)收回授权
MariaDB [school]> REVOKE SELECT(stuid) ON school.students FROM admin@'%';
#收回admin@'%'用户对stuid字段的查询权限
注:当一个用户被创建时,mysql会自动授予usage权限;usage权限只能用于登录数据,不能执行其他操作。
如果用户有可能会跨越不安全的网络连接到数据库,我们可以强制用户使用ssl建立会话:
grant usage on *.* to 'superman'@'222.222.222.222' require ssl;
如果取消上述ssl连接,使用如下命令撤销:
grant usage on *.* to 'superman'@'222.222.222.222' require none;
如果,root用户授权了superman用户权限时,搭配了grant选项,那么superman有权将已拥有的权限授予其他用户。这样做很危险;请勿随意使用此选项;示例如下
grant select on *.* to superman@'192.168.%.%' with grant option;
在上面提到了WITH GRANT OPTION这一项,管理员爸爸还可以通过这些选项对用户进行一些其他限制。