mysql创建用户和分配权限

本文详细介绍了MySQL 8.0的版本信息、用户权限创建、分配与撤销、远程登录设置,包括grant, revoke, flush privileges等关键操作,并提到了如何查看和调整用户权限。

mysql --version结果:mysql  Ver 8.0.22-0ubuntu0.20.04.3 for Linux on x86_64 ((Ubuntu))

已经创建了数据库test

创建用户

格式:create user 'username'@'host' identified by 'password';

username的单引号可以省略,host为localhost表示仅允许本地登录,host为%表示允许从任意地址登录

create user 'user1'@'%' identified by 'USER1';

分配权限/用户授权

格式:grant privileges on databasename.tablename to 'username'@'host';

databasename.tablename中,*代表所有。下面的写法都可以,划掉的除外,不过划掉的可能可以在8之前的版本使用,未测试8之前的版本

grant select on test.* to 'user1'@'%'; 

grant select on test.* to user1;

grant select,insert,delete,update on test.* to 'user1'@'%';

grant select,insert,delete,update on test.* to 'user1';

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

grant all on test.* to 'user1';

grant all privileges on test.* to 'user1'@'%' identified by 'USER1'; # 不行

grant select privileges on test.* to 'user1'@'%'; # 不行

grant select privileges on test.* to 'user1'; # 不行

grant select on test.* to 'user1'@'%' identified by 'USER1'; # 不行

权限列表

ALTER: 修改表和索引。

CREATE: 创建数据库和表。

DELETE: 删除表中已有的记录。

DROP: 抛弃(删除)数据库和表。

INDEX: 创建或抛弃索引。

INSERT: 向表中插入新行。

REFERENCE: 未用。

SELECT: 检索表中的记录。

UPDATE: 修改现存表记录。

FILE: 读或写服务器上的文件。

PROCESS: 查看服务器中执行的线程信息或杀死线程。

RELOAD: 重载授权表或清空日志、主机缓存或表缓存。

SHUTDOWN: 关闭服务器。

ALL: 所有权限,ALL PRIVILEGES同义词。

USAGE: 特殊的 "无权限" 权限。

可根据上面的权限字段 为用户分配相应的权限。

注意:(参考链接)

用以上命令授权的用户不能给其他用户授权,如果想这个用户能够给其他用户授权,就要在后面加上 WITH GRANT OPTION 如:

grant all on test.* to 'root'@'localhost' with grant option;

查看授权/查看权限

两种写法都可以

show grants for 'user1'@'%'; 

show grants for 'user1';

刷新权限

flush privileges;

取消授权

下面的写法都可以,划掉的除外,不过划掉的可能可以在8之前的版本使用,未测试8之前的版本

revoke select  on test.* from 'user1'@'%';

revoke all privileges on test.* from 'user1'@'%';

revoke all on test.* from 'user1'@'%';

revoke select privileges on test.* from 'user1'@'%'; # 不行

删除用户

drop user 'user1'@'%';

允许远程登录

navicat连接mysql需要设置,否则连接报错,参考链接

另写了文章详细解决报错

sudo mysql_secure_installation # (之前文章设置过了)

sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf # 将bind-address=127.0.0.1改成0.0.0.0或直接注释掉这一句,127.0.0.1与localhost都表示本地

service mysql restart

给root用户最高权限并允许远程登录root

use mysql;

update user set host='%' where user='root'; # 之前文章里设置的'root'@'localhost',改成%允许任意地址登录,前提是已设置上面的允许远程登录

grant all on *.* to 'root'@'%' with grant option;

额外总结:想要远程登录,需先设置上面的允许远程登录,再将要远程登录的用户的主机设为%

查看已有用户和允许其登录的主机和身份认证方式

use mysql;

select user,host,plugin from user; # caching_sha2_password是mysql8.0.4开始的方式,之前是mysql_native_password。之前文章中改密码的第三步有身份认证方式介绍

### 如何在 MySQL创建用户分配权限 #### 创建用户MySQL 中,可以通过 `CREATE USER` 命令来创建新的用户账户。以下是具体的语法: ```sql CREATE USER 'username'@'host' IDENTIFIED BY 'password'; ``` - `'username'`: 新用户的名称。 - `'host'`: 定义该用户可以从哪个主机连接到数据库。可以指定为单个 IP 地址、域名或者通配符 `%` 表示任何主机[^4]。 - `'password'`: 设置登录密码。 例如,如果希望创建一个名为 `lyy` 的用户,并仅允许其从本地访问,则执行如下命令: ```sql CREATE USER 'lyy'@'localhost' IDENTIFIED BY '123456'; ``` 而为了使此用户能够从任意远程地址访问数据库,应改为以下语句: ```sql CREATE USER 'lyy'@'%' IDENTIFIED BY '123456'; ``` #### 刷新权限表 每当修改了用户定义或权限配置之后,都需要运行 `FLUSH PRIVILEGES` 来重新加载这些更改至内存中以便立即生效。 ```sql FLUSH PRIVILEGES; ``` #### 分配权限 一旦创建用户后,就可以利用 `GRANT` 语句赋予相应的权限。基本形式如下所示: ```sql GRANT privileges_type ON database_name.table_name TO 'username'@'host' [IDENTIFIED BY 'password']; ``` 这里有一些常见的例子展示不同类型的权限授予方式: - **给予某个特定数据库的所有权限** ```sql GRANT ALL PRIVILEGES ON testdb.* TO 'lyy'@'%'; ``` - **给予全局范围内的全部权限(谨慎使用)** ```sql GRANT ALL PRIVILEGES ON *.* TO 'lyy'@'%'; ``` 注意,在某些情况下可能还需要再次确认刷新特权以确保最新设定被应用上去了。 以上就是关于如何在MySQL里头建立新使用者帐号连同指派适当存取权能的相关指导说明[^1][^2][^3].
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值