MySQL用户管理

MySQL用户管理

1. 查看用户信息

MySQL 的用户信息都存储在 mysql 数据库中。

mysql 复制代码
select USER,HOST,authentication_string from user;

USER: 用户名。

HOST: 表示这个用户可以从哪个主机登录,localhost 表示只能从本机登录。

authentication_string: 用户密码通过加密后显示的字符。


user 表中还有一堆的权限字段,以 *_priv 的方式命名,可以查看用户具有哪些权限:

2. 创建用户

创建本地用户:

本地用户只能从本机访问数据库。

mysql 复制代码
create user 'user_name'@'localhost' identified by 'password';
-- 或
create user 'user_name'@'127.0.0.1' identified by 'password';

创建公网用户:

mysql 复制代码
create user 'user_name'@'%' identified by 'password';

也可以指定公网用户具体通过哪个 IP 登录才能访问数据库。


创建完用户后,需要刷新新用户才能访问数据库:

mysql 复制代码
flush privileges;

3. 删除用户

mysql 复制代码
drop user '用户名'@'主机名';

4. 修改用户密码

用户修改自己的密码:

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

root修改指定用户密码:

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

5. 数据库权限

权限 上下文
CREATE Create_priv 数据库、表或索引
DROP Drop_priv 数据库或表
GRANT OPTION Grant_priv 数据库、表或保存的程序
REFERENCES References_priv 数据库或表
ALTER Alter_priv
DELETE Delete_priv
INDEX Index_priv
INSERT Insert_priv
SELECT Select_priv
UPDATE Update_priv
CREATE VIEW Create_view_priv 视图
SHOW VIEW Show_view_priv 视图
ALTER ROUTINE Alter_routine_priv 保存的程序
CREATE ROUTINE reate_routine_priv 保存的程序
EXECUTE Execute_priv 保存的程序
FILE File_priv 服务器主机上的文件访问
CREATE TEMPORARY TABLES Create_tmp_table_priv 服务器管理
LOCK TABLES Lock_tables_priv 服务器管理
CREATE USER Create_user_priv 服务器管理
PROCESS Process_priv 服务器管理
RELOAD Reload_priv 服务器管理
REPLICATION CLIENI Repl_client_priv 服务器管理
REPLICATION SLAVE Repl_slave_priv 服务器管理
SHOW DATABASES Show_db_priv 服务器管理
SHUTDOWN Shut_dow_priv 服务器管理
SUPER Super_priv 服务器管理

5.1 用户授权

新创建的用户没有任何权限,需要手动给用户授权。

mysql 复制代码
grant 权限列表 on 库.对象名 to '用户名'@'登录IP' [identified by 'password'];

库.对象名: 可使用 *.* 代表本系统中所有数据库的所有对象;可使用 库.* 表示某个数据库中的所有对象。

identified by: 为可选项,当授权用户不存在时会使用密码创建用户并授权;用户存在时会授权并修改用户密码。


对用户授权后,如果没有生效,需要刷新:

mysql 复制代码
flush privileges;

5.2 回收权限

mysql 复制代码
revoke 权限列表 on 库.对象名 from '用户名'@'登录IP';
相关推荐
yookay zhang5 分钟前
达梦新云文档数据库分享
数据库
laplace01232 小时前
Java八股—MySQL
java·mysql·oracle
熙客3 小时前
TiDB:分布式关系型数据库
java·数据库·分布式·tidb
你想考研啊6 小时前
oracle导出 导入
数据库·oracle
韩立学长8 小时前
基于Springboot的旧时月历史论坛4099k6s9(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
TDengine (老段)9 小时前
TDengine 字符串函数 CONCAT_WS 用户手册
android·大数据·数据库·时序数据库·tdengine·涛思数据
IT 小阿姨(数据库)10 小时前
PostgreSQL 之上的开源时序数据库 TimescaleDB 详解
运维·数据库·sql·postgresql·开源·centos·时序数据库
颜大哦10 小时前
linux安装mysql
linux·运维·mysql·adb
熊文豪11 小时前
openEuler 云原生实战:部署高性能 Redis 集群与压测分析
数据库·redis·云原生·openeuler
GTgiantech11 小时前
科普SFP 封装光模块教程
服务器·网络·数据库