网站首页 > 技术文章 正文
MySQL 是一个开源的关系型数据库管理系统,常用于存储和管理大量的结构化数据。在使用 MySQL 进行数据管理时,为了安全和方便管理,通常需要创建新用户并授予相应的权限。本文将介绍如何在 MySQL 中创建新用户并授予权限的方法。
创建新用户
在 MySQL 中,可以使用 CREATE USER 命令创建新用户。其基本语法如下:
CREATE USER 'username'@'host' IDENTIFIED BY 'password';
其中,username 表示要创建的用户名,host 表示该用户可以从哪个主机登录 MySQL,password 表示该用户的密码。例如,要创建一个名为 newuser,密码为 newpassword,可以从任何主机登录 MySQL 的新用户,可以执行以下命令:
CREATE USER 'newuser'@'%' IDENTIFIED BY 'newpassword';
其中,% 表示该用户可以从任何主机登录 MySQL。
如果要限制该用户只能从特定的主机登录 MySQL,可以将 host 参数设置为相应的主机名或 IP 地址。例如,要创建一个名为 newuser,密码为 newpassword,只能从 IP 地址为 192.168.1.100 的主机登录 MySQL,可以执行以下命令:
CREATE USER 'newuser'@'192.168.1.100' IDENTIFIED BY 'newpassword';
注意,当使用 CREATE USER 命令创建用户时,该用户没有任何权限。要为该用户授予权限,需要使用 GRANT 命令。
嵌入式物联网需要学的东西真的非常多,千万不要学错了路线和内容,导致工资要不上去!
无偿分享大家一个资料包,差不多150多G。里面学习内容、面经、项目都比较新也比较全!某鱼上买估计至少要好几十。
点击这里找小助理0元领取:加微信领取资料
授予权限
在 MySQL 中,可以使用 GRANT 命令授予用户不同的权限。其基本语法如下:
GRANT privileges ON database.table TO 'username'@'host';
其中,privileges 表示要授予的权限,可以是一个或多个权限,例如 SELECT、INSERT、UPDATE、DELETE 等。database 和 table 分别表示要授予权限的数据库和表名。如果要授予所有数据库或表的权限,可以使用 * 通配符。username 和 host 与创建用户时的语法相同。
例如,要授予名为 newuser 的用户在 mydb 数据库中所有表的 SELECT 和 INSERT 权限,可以执行以下命令:
GRANT SELECT, INSERT ON mydb.* TO 'newuser'@'%';
如果要授予该用户在所有数据库中所有表的所有权限,可以执行以下命令:
GRANT ALL PRIVILEGES ON *.* TO 'newuser'@'%';
在实际应用中,为了安全起见,应尽可能限制用户的权限,只授予其必要的权限。例如,如果只需要让用户查询 mydb 数据库中的某个表,可以使用以下命令授予该用户仅查询该表的权限:
GRANT SELECT ON mydb.mytable TO 'newuser'@'%';
如果需要撤销用户的权限,可以使用 REVOKE 命令。其基本语法如下:
REVOKE privileges ON database.table FROM 'username'@'host';
其中,privileges、database、table、username 和 host 的含义与 GRANT 命令相同。
例如,要撤销名为 newuser 的用户在 mydb 数据库中所有表的所有权限,可以执行以下命令:
REVOKE ALL PRIVILEGES ON mydb.* FROM 'newuser'@'%';
修改用户密码
在 MySQL 中,可以使用 SET PASSWORD 命令修改用户密码。其基本语法如下:
SET PASSWORD FOR 'username'@'host' = 'newpassword';
其中,username 和 host 的含义与创建用户时的语法相同。newpassword 表示新的密码。
例如,要将名为 newuser 的用户的密码修改为 newpassword,可以执行以下命令:
SET PASSWORD FOR 'newuser'@'%' = 'newpassword';
查看用户权限
在 MySQL 中,可以使用 SHOW GRANTS 命令查看用户的权限。其基本语法如下:
SHOW GRANTS FOR 'username'@'host';
例如,要查看名为 newuser 的用户在所有数据库中所有表的所有权限,可以执行以下命令:
SHOW GRANTS FOR 'newuser'@'%';
总结
本文介绍了在 MySQL 中创建新用户并授予权限的方法。通过创建新用户和授予不同的权限,可以实现对 MySQL 数据库的安全管理和方便的权限控制。在实际应用中,应尽可能限制用户的权限,只授予其必要的权限,从而提高数据库的安全性。同时,也需要注意保护好数据库管理员账号和密码,避免因为账号密码泄露导致数据库安全事故的发生。
转载自:运维漫谈
文章来源于介绍如何在 MySQL 中创建新用户并授予权限?
原文链接:
https://mp.weixin.qq.com/s/xM2ZGbWdB1_s6p60KeYkcA
猜你喜欢
- 2025-03-29 在MySQL登录时出现Access denied for user ~~ (using password: YES)
- 2025-03-29 MySQL版本区别及管理(mysql数据库的版本)
- 2025-03-29 Windows 安装解压版本的 MySql(mysql解压版和安装版有什么区别)
- 2025-03-29 Mysql8忘记密码/重置密码(mysql8忘记密码怎么办)
- 2025-03-29 Mysql 8.4数据库安装、新建用户和数据库、表单
- 2025-03-29 MySQL进行整库数据备份「表(结构+数据)、视图、函数、事件」
- 2025-03-29 Linux中安装mysql5.6(Linux中安装软件命令)
- 2025-03-29 数据库密码配置项都不加密?心也太大了吧!
- 2025-03-29 0825-7.1.4-如何重置Ranger Admin Web UI登录密码
- 2025-03-29 MySQL管理授权和数据库的备份和还原详解
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)