MySQL——用户管理

用户管理

一、用户信息

​ MySQL中的用户都存储在系统数据库mysqluser表中;

​ 关键字段,User(用户名),Host(允许用户从哪一个主机进行登录),authentication_string(存放着当前用户对应的登陆密码),_priv(表示某种权限);

​ 换句话说,对MySQL进行用户管理如增删改,就是对user表进行修改;

二、用户管理相关SQL

2.1创建用户

​ 创建完新用户,并且要刷新特权;将登陆主机设置成%表示允许以任意主机的方式进行登录

mysql 复制代码
create user '用户名'@'登陆主机/ip' identified by '密码';
flush privileges;

​ 当显示密码政策不支持时,进行如下操作;

mysql 复制代码
show variables like 'validate_password%';
+--------------------------------------+--------+
| Variable_name                        | Value  |
+--------------------------------------+--------+
| validate_password_check_user_name    | OFF    |
| validate_password_dictionary_file    |        |
| validate_password_length             | 8      |
| validate_password_mixed_case_count   | 1      |
| validate_password_number_count       | 1      |
| validate_password_policy             | MEDIUM |
| validate_password_special_char_count | 1      |
+--------------------------------------+--------+
mysql 复制代码
set global validate_password_policy=low;
+--------------------------------------+-------+
| Variable_name                        | Value |
+--------------------------------------+-------+
| validate_password_check_user_name    | OFF   |
| validate_password_dictionary_file    |       |
| validate_password_length             | 8     |
| validate_password_mixed_case_count   | 1     |
| validate_password_number_count       | 1     |
| validate_password_policy             | LOW   |
| validate_password_special_char_count | 1     |
+--------------------------------------+-------+

​ 当远端用户登录不支持时,在/etc/my.cnf文件中添加skip_ssl;进行远端登录必须保证服务端内部配置了允许远端登录的账号,另外不建议将云服务器的mysqld的端口号暴露到公网中;

​ MySQL主要是在内网环境中进行访问;

2.2删除用户

mysql 复制代码
drop user '用户名'@'登陆主机/ip';

2.3修改用户密码

方式一:自己修改自己的密码;

mysql 复制代码
set password=password('密码');

方式二:root用户可以修改其他人密码,也支持自己修改自己的密码;

mysql 复制代码
set password for '用户名'@'主机名'=password('新密码'); 

三、权限管理

3.1给用户进行授权

mysql 复制代码
grant 权限列表(一个或者是多个权限,用,隔开) on 库.对象名(数据库.表/视图存储过程,*.*表示所有数据库的所有对象,库.*表示某个数据库的所有对象) to '用户名'@'主机名' 可以加设计密码但是不建议使用;
mysql 复制代码
grant all on...#表示给赋予所有的权限;

3.2查看给某一个用户的权限

mysql 复制代码
show grants for '用户名'@'主机名';
------------------------------------------------------+
| Grants for dyh@%                                     |
+------------------------------------------------------+
| GRANT USAGE ON *.* TO 'dyh'@'%'                      |
| GRANT ALL PRIVILEGES ON `rootDB`.`user` TO 'dyh'@'%' |
+------------------------------------------------------+

3.3回收用户权限

mysql 复制代码
revoke 权限列表 on 库.对象名 from '用户名'@'主机名';
相关推荐
Wang's Blog1 小时前
Redis: 集群环境搭建,集群状态检查,分析主从日志,查看集群信息
数据库·redis
容器( ु⁎ᴗ_ᴗ⁎)ु.。oO1 小时前
MySQL事务
数据库·mysql
数据龙傲天2 小时前
1688商品API接口:电商数据自动化的新引擎
java·大数据·sql·mysql
engineer-gxd3 小时前
MySQL 表的操作
mysql
cyt涛3 小时前
MyBatis 学习总结
数据库·sql·学习·mysql·mybatis·jdbc·lombok
Rookie也要加油3 小时前
01_SQLite
数据库·sqlite
liuxin334455663 小时前
教育技术革新:SpringBoot在线教育系统开发
数据库·spring boot·后端
看山还是山,看水还是。4 小时前
MySQL 管理
数据库·笔记·mysql·adb
fishmemory7sec4 小时前
Koa2项目实战2(路由管理、项目结构优化)
数据库·mongodb·koa
momo小菜pa4 小时前
【MySQL 09】表的内外连接
数据库·mysql