MySQL——用户管理

在使用MySQL时,初始都是只有一个root账号,跟Linux类似,拥有最高管理员权限。如果数据库将来要被多个人使用,如果所有人都通过root登录,那么就可以对所有的数据库信息进行操作,这显然是不安全的,因此MySQL也必须做用户管理。


一.用户管理

1.创建用户

MySQL中的所有用户信息都存放在系统数据库mysql的user表中:

  • host: 表示这个用户可以从哪个主机登陆,如果是localhost,表示只能从本机登陆
  • user: 用户名
  • authentication_string: 用户密码通过password函数加密后的

创建用户:

create user '用户名'@'登陆主机/ip' identified by '密码';

如果**@localhost** ,表示该用户只能在本地主机 登录MySQL,如果**@特定的IP地址** ,则用户只能在该IP地址 下登录MySQL,如果**@%** ,则用户可以在任意主机下登录MySQL。


2.删除用户

删除用户需要在root用户下操作:

drop user '用户名'@'主机名';

不能直接输入用户名进行删除,必须@,因为系统会默认将其识别为%,即所有地方均可登录。


3.修改用户密码

自己修改自己的密码:

set password=password('新的密码');

root用户修改指定用户的密码:

set password for '用户名'@'主机名'=password('新的密码');


二.数据库权限

1.授权

刚创建的新用户,没有任何权限,不能自己创建数据库 ,因此需要root用户为其创建专用的数据库并授权

grant 权限列表 on 库.对象名 to '用户名'@'登陆位置' [identified by '密码'];

权限列表,多个权限用逗号分开:

grant select on ...

grant select, delete, create on ....

grant all [privileges] on ... -- 表示赋予该用户在该对象上的所有权限

其中 "库.对象名" 的用法如下:

  • *.* : 代表对本系统中的所有数据库的所有对象授权(表,视图,存储过程等)
  • 库.* : 表示某个数据库中的所有数据对象授权(表,视图,存储过程等)
  • 库.对象名:表示某个数据库中的某个数据对象授权(表,视图,存储过程等)

identified by 可选。 如果用户存在,赋予权限的同时修改密码,如果该用户不存在,就是创建用户并为其设置密码。

查看用户已有权限:

show grants for '用户名'@'主机名';


2.回收权限

revoke 权限列表 on 库.对象名 from '用户名'@'登陆位置';

用法与授权一致。

相关推荐
神秘的猪头33 分钟前
🚀 React 开发者进阶:RAG 核心——手把手带你玩转 Milvus 向量数据库
数据库·后端·llm
0xDevNull17 小时前
MySQL索引进阶用法
后端·mysql
0xDevNull17 小时前
MySQL索引用法
mysql
IvorySQL19 小时前
PostgreSQL 技术日报 (3月6日)|为什么 Ctrl-C 在 psql 里让人不安?
数据库·postgresql·开源
NineData20 小时前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
程序员小崔日记1 天前
一篇文章彻底搞懂 MySQL 和 Redis:原理、区别、项目用法全解析(建议收藏)
redis·mysql·项目实战
IvorySQL1 天前
PostgreSQL 技术日报 (3月5日)|规划器控制力升级,内核能力再进阶
数据库·postgresql·开源
武子康1 天前
大数据-241 离线数仓 - 实战:电商核心交易数据模型与 MySQL 源表设计(订单/商品/品类/店铺/支付)
大数据·后端·mysql
数据组小组2 天前
免费数据库管理工具深度横评:NineData 社区版、Bytebase 社区版、Archery,2026 年开发者该选哪个?
数据库·测试·数据库管理工具·数据复制·迁移工具·ninedata社区版·naivicat平替