数据库中的 DDL、DML 和 DCL

server/2025/1/12 21:46:09/

数据库中的 DDL、DML 和 DCL

数据库的定义与操作中,DDLDMLDCL 是三个核心概念,分别用于不同层面的数据库管理与操作。


1. DDL(Data Definition Language) - 数据定义语言

定义

DDL 用于定义和管理数据库的结构或模式。它负责创建、修改、删除数据库对象(如表、视图、索引等)。

常见操作

  • CREATE:创建数据库对象(如表、视图、索引)。
    CREATE TABLE students (id INT PRIMARY KEY,name VARCHAR(50),age INT
    );
    
  • ALTER:修改数据库对象的结构。
    ALTER TABLE students ADD COLUMN gender VARCHAR(10);
    
  • DROP:删除数据库对象。
    DROP TABLE students;
    
  • TRUNCATE:清空表的数据,但保留表结构。
    TRUNCATE TABLE students;
    

特点

  • DDL 操作通常会隐式提交事务,不能回滚。
  • 改变的是数据库结构,而不是数据内容。

高级特性

  • 模式迁移工具支持:与数据库迁移工具(如 Liquibase、Flyway)集成,可实现版本化管理。
  • 生成脚本:支持自动生成脚本以备份和迁移数据库
  • 支持多种存储引擎:可根据需求选择不同的存储引擎(如 InnoDB 或 MyISAM)。

2. DML(Data Manipulation Language) - 数据操作语言

定义

DML 用于操作数据库中的数据,包括插入、更新、删除和查询等操作。

常见操作

  • SELECT:查询数据。
    SELECT * FROM students;
    
  • INSERT:插入数据。
    INSERT INTO students (id, name, age) VALUES (1, 'Alice', 20);
    
  • UPDATE:更新数据。
    UPDATE students SET age = 21 WHERE id = 1;
    
  • DELETE:删除数据。
    DELETE FROM students WHERE id = 1;
    

特点

  • DML 操作需要显式提交事务(如 COMMITROLLBACK)。
  • 主要用于操作数据内容,而不是结构。

高级特性

  • 批量操作:支持批量插入、更新和删除,提高效率。
  • 事务控制:结合事务管理,可以确保数据操作的原子性、一致性、隔离性和持久性(ACID)。
  • 优化查询:支持查询优化器,提供索引、分区和子查询等高级功能。
  • 多表联结:支持复杂的多表关联操作(如 JOIN)。

3. DCL(Data Control Language) - 数据控制语言

定义

DCL 用于控制对数据库的访问权限,管理用户权限和安全性。

常见操作

  • GRANT:授予用户权限。
    GRANT SELECT, INSERT ON students TO user1;
    
  • REVOKE:撤销用户权限。
    REVOKE INSERT ON students FROM user1;
    

特点

  • DCL 操作通常需要管理员权限。
  • 涉及数据库的安全性和权限控制。

高级特性

  • 角色管理:支持角色的创建和分配,简化权限管理。
  • 细粒度权限控制:可以精确到表、列或行级别授予权限。
  • 审计功能:记录权限变更和访问情况,增强数据库安全性。
  • 数据屏蔽:结合数据安全功能,可以对敏感数据进行屏蔽处理。

主要区别总结

类别全称作用关键操作影响范围
DDL数据定义语言定义数据库结构CREATE, ALTER, DROP数据库结构
DML数据操作语言操作和管理数据SELECT, INSERT, UPDATE, DELETE数据库中的数据内容
DCL数据控制语言管理用户权限和安全性GRANT, REVOKE数据库访问权限


http://www.ppmy.cn/server/157858.html

相关文章

基于spingboot+html技术的博客网站

博主介绍:硕士研究生,专注于信息化技术领域开发与管理,会使用java、标准c/c等开发语言,以及毕业项目实战✌ 从事基于java BS架构、CS架构、c/c 编程工作近16年,拥有近12年的管理工作经验,拥有较丰富的技术架…

C语言gdb调试

目录 1.gdb介绍 2.设置断点 2.1.测试代码 2.2.设置函数断点 2.3.设置文件行号断点 2.4.设置条件断点 2.5.多线程调试 3.删除断点 3.1.删除指定断点 3.2.删除全部断点 4.查看变量信息 4.1.p命令 4.2.display命令 4.3.watch命令 5.coredump日志 6.总结 1.gdb介绍…

深入探索AI核心模型:CNN、RNN、GAN与Transformer

在人工智能的飞速发展中,众多深度学习模型和算法不断涌现,推动了许多领域的进步。特别是在图像识别、自然语言处理、生成建模等方向,AI模型的应用越来越广泛。本文将介绍几种最常用的AI模型,包括卷积神经网络(CNN&…

[ComfyUI]接入Google的Whisk,巨物融合玩法介绍

一、介紹​ 前段时间,谷歌推出了一个图像生成工具whisk,有一个很好玩的图片融合玩法,分别提供三张图片,就可以任何组合来生成图片。​ ​ 最近我发现有人开发了对应的ComfyUI插件,对whisk做了支持,就来体验了下&#…

MySQL表格练习(单表查询,多表查询)

一,单表查询 素材: 素材: 表名:worker-- 表中字段均为中文,比如 部门号 工资 职工号 参加工作 等 CREATE TABLE worker ( 部门号 int(11) NOT NULL, 职工号 int(11) NOT NULL, 工作时间 date NOT NULL, 工资 float(8,2) NOT NUL…

后台管理系统-axios网络请求的封装

此博客是针对开源项目:vue3-element-admin 的学习记录,为了帮助自己理清开发这个系统的逻辑. 安装依赖 npm install axios , qsAxios实例封装 // 创建 axios 实例 ,同时给出一些预设配置,比如baseURL,超时时间等等 const service axios.create({base…

JavaWeb—Servlet详解

前言: 本章节主要学习Servlet基础知识点,收录于JavaWeb系列,该系列主要讲解Servlet、JSP、Filter过滤器、Session、分层开发概念等知识点,欢迎童鞋们互相交流。觉得不错可以三连订阅喔。 目标: 一、概念 二、入门程…

1. Doris分布式环境搭建

一. 环境准备 本次测试集群采用3台机器hadoop1、hadoop2、hadoop3, Frontend和Backend部署在同一台机器上,Frontend部署3台组成高可用,Backend部署3个节点,组成3副本存储。 主机IP操作系统FrontendBackendhadoop1192.168.47.128Centos7Foll…