DCL-(Data Control Language)

DCL(Data Control Language):数据控制语言,用来管理数据库用户、控制数据库的访问权限。

管理用户

查询用户

use mysql;
select * from user;

查询的结果如下:
image
其中Host代表当前用户访问的主机, 如果为localhost, 仅代表只能够在当前本机访问,是不可以远程访问的。User代表的是访问该数据库的用户名。在MySQL中需要通过Host和User来唯一标识一个用户。

创建用户

create user '用户名'@'主机名' identified by '密码';
/*例*/
create user 'hjy'@'localhost' identified by '123456';
/*创建用户可以在任意主机访问该数据库*/
create user 'hjy2'@'%' identified by '123456';

修改用户密码

alter user '用户名'@'主机名' identified with mysql_native_password by '新密码';
/*例*/
alter user 'hjy'@'localhost' identified with mysql_native_password by '123';

删除用户

drop user '用户名'@'主机名';
/*例*/
drop user 'hjy'@'%';

注意事项:

  • 在MySQL中需要通过用户名@主机名的方式,来唯一标识一个用户。
  • 主机名可以使用%通配。
  • 这类SQL开发人员操作的比较少,主要是DBA( Database Administrator 数据库管理员)使用。

权限控制

MySQL中定义了很多种权限,但是常用的就以下几种:

权限 说明
all, all privileges 所有权限
select 查询数据
insert 插入数据
update 修改数据
delete 删除数据
alter 修改表
drop 删除数据库/表/视图
create 创建数据库/表

上述只是简单罗列了常见的几种权限描述,其他权限描述及含义,可以直接参考官方文档。

查询权限

show grants for '用户名'@'主机名';
/*例*/
show grants for 'hjy'@'localhost';

授予权限

grant 权限列表 on 数据库名.表名 to '用户名'@'主机名';
/*例*/
grant all on restaurant.* to 'hjy'@'localhost';

撤销权限

revoke 权限列表 on 数据库名.表名 from '用户名'@'主机名';
/*例*/
revoke all on restaurant.* from 'hjy'@'localhost';

注意事项

  • 多个权限之间,使用逗号分隔
  • 授权时,数据库名和表名可以使用 * 进行通配,代表所有。
posted @ 2023-01-10 16:00  wandoubaguo  阅读(37)  评论(0编辑  收藏  举报