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';
相关推荐
数据组小组4 小时前
免费数据库管理工具深度横评:NineData 社区版、Bytebase 社区版、Archery,2026 年开发者该选哪个?
数据库·测试·数据库管理工具·数据复制·迁移工具·ninedata社区版·naivicat平替
悟空聊架构10 小时前
基于KaiwuDB在游乐场“刷卡+投币”双模消费系统中的落地实践
数据库·后端·架构
IvorySQL10 小时前
PostgreSQL 技术日报 (3月4日)|硬核干货 + 内核暗流一网打尽
数据库·postgresql·开源
进击的丸子14 小时前
虹软人脸服务器版SDK(Linux/ARM Pro)多线程调用及性能优化
linux·数据库·后端
NineData1 天前
NineData智能数据管理平台新功能发布|2026年1-2月
数据库·sql·数据分析
IvorySQL1 天前
双星闪耀温哥华:IvorySQL 社区两项议题入选 PGConf.dev 2026
数据库·postgresql·开源
ma_king1 天前
入门 java 和 数据库
java·数据库·后端
jiayou642 天前
KingbaseES 实战:审计追踪配置与运维实践
数据库
NineData2 天前
NineData 迁移评估功能正式上线
数据库·dba
NineData2 天前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算