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

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

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

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

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

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

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

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

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

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

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

    SQL 复制代码
    ALTER TABLE table_name ADD column_name datatype;
  • DROP:删除数据库对象。

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

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

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

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

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

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

    SQL 复制代码
    UPDATE table_name SET column1 = value1 WHERE condition;
  • DELETE:删除数据。

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

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

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

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

    SQL 复制代码
    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)

    SQL 复制代码
    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)

    SQL 复制代码
    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 的区别和用法,可以更好地管理和操作数据库!

相关推荐
m0_46652529几秒前
绿盟科技风云卫AI安全能力平台成果重磅发布
大数据·数据库·人工智能·安全
爱学习的阿磊37 分钟前
使用Fabric自动化你的部署流程
jvm·数据库·python
枷锁—sha43 分钟前
【SRC】SQL注入快速判定与应对策略(一)
网络·数据库·sql·安全·网络安全·系统安全
惜分飞1 小时前
ORA-600 kcratr_nab_less_than_odr和ORA-600 4193故障处理--惜分飞
数据库·oracle
chian-ocean1 小时前
CANN 生态进阶:利用 `profiling-tools` 优化模型性能
数据库·mysql
m0_550024631 小时前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python
AC赳赳老秦1 小时前
代码生成超越 GPT-4:DeepSeek-V4 编程任务实战与 2026 开发者效率提升指南
数据库·数据仓库·人工智能·科技·rabbitmq·memcache·deepseek
啦啦啦_99991 小时前
Redis-2-queryFormat()方法
数据库·redis·缓存
玄同7652 小时前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
吾日三省吾码2 小时前
别只会“加索引”了!这 3 个 PostgreSQL 反常识优化,能把性能和成本一起打下来
数据库·postgresql