基础-SQL-DCL

一、MySQL基础

在数据库的世界里,DCL(Data Control Language,数据控制语言)是守护数据安全的"隐形卫士"。它不直接操作数据,却决定着谁能在何时、以何种方式访问数据库。

1. DCL

DCL是SQL的子集,专注于数据库访问权限的控制。它确保只有经过授权的用户才能执行特定操作,是数据库安全体系的基石。

💡 关键认知:DCL不是"数据操作语言",而是"数据访问控制语言"。它不处理数据本身,而是控制"谁可以操作数据"。

1.1 DCL的核心使命:安全与权限

DCL的四大核心使命:

  1. 授权:指定用户可以执行的操作(如SELECT、INSERT)
  2. 撤销:收回已授予的权限
  3. 角色管理:将权限组合成角色,简化管理
  4. 审计:记录用户操作,便于追踪和安全审查

🌟 现实场景:想象一家电商公司,销售团队需要查看订单数据,但不能修改;财务团队需要修改订单状态,但不能查看客户信息。DCL正是实现这种精细权限控制的关键。

1. 查询用户

默认有四个用户,其他没有用过,只有一个你刚开始创建数据库项目时使用的账号比如root。

localhost指的是:主机。我们要去创建一个用户和删除一个用户,需要通过用户名和host主机地址同时定位。这个主机指的是当前这个用户只能够在哪一个主机上访问当前的MySQL服务器。那么localhost代表了只能在本机访问,不能远程访问。

2. 创建用户

通过sql创建用户会发现是没有任何权限的,可以访问MySQL但是没有访问其他数据库的权限

  1. 修改用户名

权限控制

常用的权限设置

sql 复制代码
-- 查询权限
-- GRANT USAGE ON *.* TO `huama`@`%`
-- 查询到上面的权限说明:你仅仅只能通过该用户连接并登入mysql而已
show grants for 'huama'@'%';

-- 授予权限
-- GRANT ALL PRIVILEGES ON `tables`.* TO `huama`@`%`
-- 这样就将tables的所有权限授权给了该用户
grant all on tables.* to 'huama'@'%';

-- 撤销权限
revoke all on tables.* from 'huama'@'%';
语言 全称 核心功能 关键操作
DCL Data Control Language 数据访问控制 GRANTREVOKE
DDL Data Definition Language 数据库结构定义 CREATEALTERDROP
DML Data Manipulation Language 数据操作 INSERTUPDATEDELETE
DQL Data Query Language 数据查询 SELECT
相关推荐
灵感菇_3 分钟前
Java 锁机制全面解析
java·开发语言
wdfk_prog4 分钟前
[Linux]学习笔记系列 -- [drivers][mmc][mmc_sdio]
linux·笔记·学习
果果燕11 分钟前
今日学习笔记:双向链表、循环链表、栈
笔记·学习·链表
wazmlp00188736915 分钟前
python第三次作业
开发语言·python
娇娇乔木16 分钟前
模块十一--接口/抽象方法/多态--尚硅谷Javase笔记总结
java·开发语言
觉醒大王20 分钟前
AI写的青基中了
人工智能·笔记·深度学习·学习·职场和发展·学习方法
明月醉窗台28 分钟前
qt使用笔记六之 Qt Creator、Qt Widgets、Qt Quick 详细解析
开发语言·笔记·qt
wangjialelele32 分钟前
平衡二叉搜索树:AVL树和红黑树
java·c语言·开发语言·数据结构·c++·算法·深度优先
lili-felicity39 分钟前
CANN性能调优与实战问题排查:从基础优化到排障工具落地
开发语言·人工智能
独自破碎E41 分钟前
【BISHI15】小红的夹吃棋
android·java·开发语言