news 2026/2/17 9:55:17

MySQL用户管理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL用户管理

MySQL用户管理

  • 与Linux操作系统类似,MySQL也有超级用户好普通用户之分
  • 如果一个用户只需要访问MySQL中的某一个数据库,设置数据库中的某一个表,那么可以为其创建一个普通用户,并未该用户赋予对应的权限,而不让用户看到数据库中的其他数据,防止该用户对其他数据进行误操作。

用户

MySQL中有一个默认的名为mysql的数据库,

查看该数据库中的表,可以找到一个名为user的表,user中存储的就是mysql中用户相关信息

不分字段说明

  • user:表示该用户的用户名
  • host:表示该用户可以从哪个主机登录,localhost表示只能从本地登录,%表示可以从任意地方登录
  • authentication_string:表示该用户的密码经过password函数加密后的值
  • xxx_priv:表示该用户是否拥有对应权限
    在查看用户的时候为了避免刷屏,可以只选择对不分字段进行显示,如下:

    这里可以发现,MySQL中可以存在同名的用户,只要他们对应登录主机不同就行,因为user表中的主键是复合主键,由表中的user列和host共同承担

    创建用户
CREATEUSER'用户名'@'登录主机'IDENTIFIEDBY'密码';

比如我现在来创建一个用户aolang,并且让他可以在任意地方登录,如下:

现在我从window上登录一下

修改用户密码

修改自己的密码

ALTERUSERUSER()IDENTIFIEDBY'新密码';

超级用户修改别人的密码

ALTERUSER'root'@'localhost'IDENTIFIEDBY'新密码';

删除用户

DROPUSER'用户名'@'登录地址';

比如将刚才创建的用户删除

数据库的权限

MySQL中的权限

权限列名上下文
CREATECreate_priv数据库、表或索引
DROPDrop_priv数据库或表
GRANT OPTIONGrant_priv数据库、表或保存的程序
REFERENCESReferences_priv数据库或表
ALTERAlter_priv
DELETEDelete_priv
INDEXIndex_priv
SELECTSelect_priv
UPDATEUpdate_priv
CREATE VIEWCreate_view_priv视图
SHOW VIEWShow_view_priv视图
ALTER ROUTINEAlter_routine_priv保存的程序
CREATE ROUTINECreate_routine_priv保存的程序
EXECUTEExecute_priv保存的程序
FILEFile_priv服务器主机上的文件访问
CREATE TEMPORARY TABLESCreate_tmp_table_priv服务器管理
LOCK TABLESLock_tables_priv服务器管理
CREATE USERCreate_user_priv服务器管理
PROCESSProcess_priv服务器管理
RELOADReload_priv服务器管理
REPLICATION CLIENTRepl_client_priv服务器管理
REPLICATION SLAVERepl_slave_priv服务器管理
SHOW DATABASESShow_db_priv服务器管理
SHUTDOWNShutdown_priv服务器管理
SUPERSuper_priv服务器管理

给用户授权

GRANT权限列表ON库名.对象名TO'用户名'@'登录地址'[IDENTIFIEDBY'密码'];
  • '用户名'@'登录地址':表示给哪一个用户授权
  • 库名.对象名:表示要授予用户哪个数据库下的哪个对象的权限
  • 权限列表:表示要授予用户何种权限,多个权限之间用逗号隔开
  • IDENTIFIED BY '密码'可选:如果用户存在,则在授予权限的同时修改改用户的密码,如果不存在则创建该用户
    MySQL 8.0 及以上版本(必须先创建用户,再授权)


对于aolang

可以通过show grants for '用户名'@'密码'查看用户现有的权限

  • 创建用户后用户默认有USAGE权限,它只能用于数据库登录,不能执行任何操作
  • *.*表示所有数据库的所有对象,库名.*表示某个数据库的所有对象(表、视图、存储过程等)

aolang进入test数据库后,只能查看表中的信息,无法对表中数据进行修改,因为我们只赋予了select权限
回收权限

REVOKE权限列表ON库名.对象名FROM'用户名'@'登录地址';
  • 回收权限的语法与授权一样,只不过将to关键字改为了from,并且没有了IDENTIFIED BY '密码’字段。

  • 回收用户在某一数据库下的权限后,在该用户下一次进入该数据库时才会起作用。

  • 如果回收权限时该用户正在使用对应数据库,那么回收权限后该用户仍然拥有对应的权限。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/6 11:03:51

Dify 1.7.0音频转文字实测解析(精准度高达98.6%的底层逻辑曝光)

第一章:Dify 1.7.0音频转文字功能概览Dify 1.7.0 版本引入了全新的音频转文字功能,显著提升了语音内容处理的效率与准确性。该功能基于先进的语音识别模型,支持多种常见音频格式(如 MP3、WAV、M4A),可广泛应…

作者头像 李华
网站建设 2026/2/15 22:23:29

astmd4169、astm d4169运输包装测试系统有多少测试内容

astmd4169、astm d4169运输包装测试系统有多少个测试项目按照astmd4169、astm d4169中测试程序A、B、C、D、E、F、G、H、I、J包含10个测试项目又分为18个配送周期,根据不同的包装方式和货运方式依次分为DC1~DC18其中小件参考较多的为DC13,大件带托盘的包…

作者头像 李华
网站建设 2026/2/7 15:47:30

R与Python数据库连接实战(高频问题+5种解决方案全收录)

第一章:R与Python数据库交互概述在数据科学和分析领域,R 与 Python 是两种广泛使用的编程语言。它们各自拥有强大的生态系统,支持从数据清洗、建模到可视化的完整流程。随着项目复杂度的提升,直接操作数据库成为常态,因…

作者头像 李华
网站建设 2026/2/6 23:56:41

Worker 线程中的 函数序列化 模式

工作者线程也可以利用函数序列化来初始化行内脚本。因为函数的toString()方法会返回函数代码的字符串,而函数可以在父上下文中定义但在子上下文中执行。什么是函数序列化?函数序列化是将函数(包括其代码、闭包环境等信息)转换为可…

作者头像 李华