MySQL数据库创建用户并赋予数据库的操作和登录权限

本文介绍了如何在MySQL中创建用户并授予不同级别的权限。方法一通过`CREATE USER`和`GRANT`命令创建新用户test,并允许从任意IP登录,可赋予全部或特定表的增删改查权限。方法二直接操作`mysql.user`表插入用户信息,设置权限。总结了两种方法的关键步骤,包括权限刷新和限制IP操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


前言

两种方法,第一种方法确保你的账号拥有全部权限,你安装数据库的时候默认的 root 用户就拥有全部权限。

第二张方法可以是你的账号不具备管理员权限,所以要直接操作 mysql 表,使用 insert 语句添加用户。

可以设置用户对某个数据库的某个表的增删改查权限,还能限制操作 IP


第一种方法

一、创建一个新用户 test ,密码设置为 123456

@‘%’ 的意思是允许 test 用户在任意 IP 登录,如果是 @‘localhost’,意思就是只能在本机登录不能远程登录,如果是 @‘111.111.111.111’,意思是只能在 IP 为111.111.111.111 的设备上登录

CREATE USER 'test'@'%' IDENTIFIED BY '123456';

二、赋予用户权限

赋予全部权限

all代表全部权限(增删改查),*.* 代表全部的数据库的全部表,后面的@'%'是在任何 IP 都可以拥有这些权限

grant all privileges on *.* to 'test'@'%';

如果是修改已有用户的权限,这样写

grant all privileges on *.* to 'root'@'%' identified by 'yourPassword' with grant option;

赋予部分表的部分权限

下面这种写法自定义权限和表

我先创建个数据库 school,数据库里我又建了个表 students

create database school;
create table students;

这个意思是把 school 这个数据库下面的 students 表的 select 权限赋给 test 用户,而且限制 IP 为111.111.111.111

grant select on school.students to test@111.111.111.111;

三、刷新权限

必须刷新,不然不生效

flush privileges;

第二种方法

字段意思和上面的一样,意思是在 mysql 数据库里的 user 表,插入一条数据, mysql这个表是自带的,里面存储的都是用户的信息。

use mysql;
INSERT INTO user(host,user,password,select_priv,insert_priv,update_priv) VALUES('%','test',password('123456'),'y','y','y');
flush privileges;

总结

### 创建 MySQL 用户授予多个数据库权限 为了创建一个新的 MySQL 用户向该用户提供对多个特定数据库操作权限,可以遵循如下方法: #### 创建用户 首先,在 MySQL 命令行工具或其他支持 SQL 查询执行环境中输入命令来创建新的用户账号。假设要创建名为 `newuser` 的用户设置密码为 `password`。 ```sql CREATE USER 'newuser'@'localhost' IDENTIFIED BY 'password'; ``` 此命令会在本地主机上创建一个具有指定用户密码的新用户[^1]。 #### 授予单个数据库权限 如果只想给这个新用户分配访问单一数据库的权利,则可以通过下面这条指令完成操作: ```sql GRANT ALL PRIVILEGES ON databasename.* TO 'newuser'@'localhost'; ``` 这里 `databasename` 是目标数据库的名字;而 `ALL PRIVILEGES` 表示给予全部类型的权限,当然也可以根据实际需求调整为更具体的权限集,比如只允许读取数据(`SELECT`) 或者修改数据 (`INSERT`, `UPDATE`, `DELETE`) 等等[^2]。 #### 对多个数据库授予权限 当涉及到向同一个用户赋予跨越多于两个以上不同名称的数据厍时,有两种方式处理这个问题: - **逐一授权**: 使用上述针对单个数据库的方法重复多次,每次更换不同的数据库名。 ```sql GRANT SELECT, INSERT, UPDATE, DELETE ON database1.* TO 'newuser'@'localhost'; GRANT SELECT, INSERT, UPDATE, DELETE ON database2.* TO 'newuser'@'localhost'; ``` - **通配符授权**: 如果这些被授权的数据库共享某种模式或命名规律(例如都属于某个项目),那么可以用通配符 `%` 来简化过程。请注意这种方式的安全风险较高,因为它可能意外地开放了更多不必要的资源访问权。 ```sql GRANT SELECT, INSERT, UPDATE, DELETE ON project%.* TO 'newuser'@'localhost'; ``` 最后一步总是记得刷新权限以使更改生效: ```sql FLUSH PRIVILEGES; ``` 通过这样的配置,就可以成功建立了一个拥有适当权限级别的 MySQL 账户用于管理操作所定义的一个或多个数据库实例[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

繁华尽头满是殇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值