19.DCL-用户管理

data control language,数据控制语言,用于管理数据库用于,控制数据库的访问权限

其实DCL语言开发人员用的少,主要是DBA(database administrator 数据库管理员)使用 接下来介绍其中的用户管理部分:

1.查询用户

在mysql数据库管理系统中,用户的信息和用户所具有的权限的信息,都是存放在系统数据库"mysql"中的user表里

可以看到user一列,其中就有root,左边一列host指主机,mysql中创建/删除用户时需要用用户名和主机地址同时定位,即两个信息才能确定一个用户,主机地址指当前这个用户只能在哪一个主机上访问当前mysql服务器

2.创建用户

注意@左右两边不能有空格

2.1

sql 复制代码
create user 'itcast'@'localhost' identified by '123629';

创建好后就会发现user表中确实多了itcast用户

老师想在命令行展示,是在cmd里输入mysql -u itcast -p回车然后输入密码进入itcast用户的mysql的,我平常是直接找到mysql中的unicode点击直接输入密码,用select user();语句后才明白我这种方式只能以root用户进入mysql,而用mysql -u itcast -p的-u其实就是user的意思可以指定用户,-p后可以直接跟密码但不安全建议先回车再输入密码,这样密码是不可见的

发现只能看到两个数据库,而其实root能看到很多数据库,因为刚刚只是创建了itcast用户,它可以访问mysql,但它还没有访问其他数据库的权限

2.2

之前只是在本机创建itcast

如果我们想让任意主机都可以访问该数据库,则可以用%代表任意用户:

sql 复制代码
create user 'heima'@'%' identified by '123629';

这里我有疑问,难道除了我的电脑(也就是localhost),还有别人可以连接我的mysql服务器吗(这里说的mysql服务器就是我电脑上安装的mysql软件):



3.修改用户密码

将黑马的密码改成123456,发现输入用户和主机的时候其实直接输入heima就会出现完整的用户名+主机,引号都不需要自己写

sql 复制代码
alter user 'heima'@'%' identified with  mysql_native_password by '123456';

控制台先退出再用语句进入黑马用户尝试输入123629发现错误,输入123456才行


4.删除用户

sql 复制代码
drop user 'itcast'@'localhost';
相关推荐
要做一个小太阳2 分钟前
数据库索引
运维·数据库
m0_737539372 分钟前
Redis安装与常用命令
数据库·redis·bootstrap
码农阿豪7 分钟前
时序数据库选型指南:我们是怎么评估和选型的
数据库·时序数据库
2301_796588509 分钟前
Go语言如何压缩文件_Go语言gzip压缩教程【基础】
jvm·数据库·python
m0_6178814211 分钟前
c++如何通过重定向rdbuf来捕获第三方库的日志输出到文件【详解】
jvm·数据库·python
IntMainJhy12 分钟前
【flutter for open harmony】第三方库Flutter 国际化多语言的鸿蒙化适配与实战指南
数据库·flutter·华为·sqlite·harmonyos
Greyson120 分钟前
mysql查询执行过程中如何追踪耗时_使用PROFILE分析指令周期
jvm·数据库·python
解救女汉子25 分钟前
CSS如何实现水平垂直居中效果_利用flex布局的justify-content与align-items
jvm·数据库·python
2301_7735536226 分钟前
CSS如何解决栅格重叠问题_使用Grid-area明确划分元素占位
jvm·数据库·python
看海的四叔28 分钟前
【SQL】SQL的日期与时间函数
数据库·hive·sql·数据分析·时间函数·日期函数