当前位置: 首页 > article >正文

SQL的DCL,DDL,DML和DQL分别是什么

SQL(Structured Query Language)包括以下四种主要语言类别,分别用于不同的数据库操作:

1. DCL(Data Control Language,数据控制语言)

用于控制数据库访问权限和安全。

常见命令
  • GRANT:授予用户或角色权限。

    GRANT SELECT, INSERT ON table_name TO user_name;
    
  • REVOKE:撤销用户或角色的权限。

    REVOKE SELECT, INSERT ON table_name FROM user_name;
    
应用场景
  • 管理用户权限(如 SELECT、INSERT、UPDATE、DELETE)。
  • 控制数据库对象(如表、视图)的访问。

2. DDL(Data Definition Language,数据定义语言)

用于定义和管理数据库对象(如表、索引、视图等)的结构。

常见命令
  • CREATE:创建数据库对象。

    CREATE TABLE table_name (
        column1 datatype,
        column2 datatype,
        ...
    );
    
  • ALTER:修改数据库对象。

    ALTER TABLE table_name ADD column_name datatype;
    
  • DROP:删除数据库对象。

    DROP TABLE table_name;
    
  • TRUNCATE:清空表中的数据(保留表结构)。

    TRUNCATE TABLE table_name;
    
应用场景
  • 创建、修改或删除表、索引、视图等。
  • 定义数据库架构。

3. DML(Data Manipulation Language,数据操作语言)

用于操作数据库中的数据(增删改查)。

常见命令
  • INSERT:插入数据。

    INSERT INTO table_name (column1, column2) VALUES (value1, value2);
    
  • UPDATE:更新数据。

    UPDATE table_name SET column1 = value1 WHERE condition;
    
  • DELETE:删除数据。

    DELETE FROM table_name WHERE condition;
    
应用场景
  • 操作表中的数据(增删改)。
  • 执行事务(如 BEGIN TRANSACTIONCOMMITROLLBACK)。

4. DQL(Data Query Language,数据查询语言)

用于查询数据库中的数据。

常见命令
  • SELECT:查询数据。

    SELECT column1, column2 FROM table_name WHERE condition;
    
应用场景
  • 检索和过滤数据。
  • 聚合和分析数据(如 GROUP BYHAVINGORDER BY)。

总结对比

类别功能常见命令应用场景
DCL控制权限GRANT, REVOKE管理用户权限和访问控制
DDL定义结构CREATE, ALTER, DROP, TRUNCATE创建、修改或删除数据库对象
DML操作数据INSERT, UPDATE, DELETE增删改数据,执行事务
DQL查询数据SELECT检索、过滤和分析数据

示例场景

  1. 创建表并插入数据(DDL + DML)

    CREATE TABLE users (
        id INT PRIMARY KEY,
        name VARCHAR(50),
        age INT
    );
    
    INSERT INTO users (id, name, age) VALUES (1, 'Alice', 25);
    
  2. 查询数据并授予权限(DQL + DCL)

    SELECT * FROM users WHERE age > 20;
    
    GRANT SELECT ON users TO user1;
    
  3. 更新数据并提交事务(DML)

    SQLBEGIN TRANSACTION;
    UPDATE users SET age = 30 WHERE id = 1;
    COMMIT;
    

通过理解 DCL、DDL、DML 和 DQL 的区别和用法,可以更好地管理和操作数据库!


http://www.kler.cn/a/598484.html

相关文章:

  • 2025-03-21 Unity 序列化 —— 自定义2进制序列化
  • 面试常问系列(一)-神经网络参数初始化
  • NLP高频面试题(十一)——RLHF的流程有哪些
  • ModuleNotFoundError: No module named ‘flask‘ 错误
  • 堆的相关要点以及模拟实现
  • 《可爱风格 2048 游戏项目:HTML 实现全解析》
  • 前后端开发概述:架构、技术栈与未来趋势
  • Linux系统移植篇(十)根文件系统构建 V3 - Yocto
  • 第8章:Docker数据持久化与卷管理
  • 基于Matlab的大气湍流光束传输特性的研究
  • Android Compose 层叠布局(ZStack、Surface)源码深度剖析(十三)
  • Android 根据Url使用Retrofit框架进行文件下载
  • 从复杂到集成:APVSG系列多通道相参矢量信号源重塑量子比特(Qubit )信号生成技术
  • qt 对QObject::tr()函数进行重定向
  • Haption Virtuose力反馈设备在CAVE投影系统中提供真实训练交互
  • 基于虚拟知识图谱的语义化决策引擎
  • 机器人前沿技术的发展与展望
  • 跨平台RTSP高性能实时播放器实现思路
  • 使用Pygame构建贪吃蛇游戏:从零开始的Python游戏开发之旅
  • 【Vue3入门2】02-记事本案例