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

数据库中DQL、DML、DDL、DCL的概念与区别

目录

DQL (Data Query Language)

DML (Data Manipulation Language)

DDL (Data Definition Language)

DCL (Data Control Language)


数据库语言可以根据其功能被分为几个不同的类别:DQL(数据查询语言)、DML(数据操纵语言)、DDL(数据定义语言)和DCL(数据控制语言)。这些类别反映了数据库管理系统中执行的不同类型的操作。

DQL (Data Query Language)

概念: DQL是用于查询数据库中数据的语言,它允许用户执行查询以检索数据库中的数据。这些查询可以是简单的,用于检索特定表中的所有记录,也可以是复杂的,涉及多个表的联合、分组和排序等操作。
关键命令: SELECT。这是DQL的核心命令,用于从一个或多个表中检索数据。

示例:

  SELECT * FROM users WHERE age > 18;

这个例子中,SELECT语句用于检索users表中年龄大于18的所有记录。

DML (Data Manipulation Language)

概念: DML包括用于插入、更新、删除数据库中数据的命令。这些命令允许用户操纵数据库中的数据,进行数据的增删改操作。
关键命令: INSERT, UPDATE, DELETE。
INSERT用于向表中添加新的数据行。
UPDATE用于修改表中的现有数据。
DELETE用于从表中删除数据。
示例:

  INSERT INTO users(name, age) VALUES('John Doe', 30);UPDATE users SET age = 31 WHERE name = 'John Doe';DELETE FROM users WHERE name = 'John Doe';

这些例子分别展示了如何插入新记录、更新现有记录和删除记录。

DDL (Data Definition Language)

概念: DDL包括用于定义或修改数据库结构的命令,如创建或删除表及其他数据库对象(如索引、触发器等)。
关键命令: CREATE, ALTER, DROP。
CREATE用于创建新的数据库对象。
ALTER用于修改现有数据库对象的结构。
DROP用于删除数据库对象。
示例:

  CREATE TABLE users(id INT PRIMARY KEY, name VARCHAR(100), age INT);ALTER TABLE users ADD email VARCHAR(255);DROP TABLE users;

这些例子展示了如何创建表、修改表结构以及删除表。

DCL (Data Control Language)

概念: DCL包括用于控制数据库中数据访问权限的命令。这些命令允许数据库管理员配置谁可以访问数据库中的数据以及他们可以执行哪些操作。
关键命令: GRANT, REVOKE。
GRANT用于授予用户或角色对数据库对象的访问权限。
REVOKE用于撤销之前授予的权限。
示例:

  GRANT SELECT ON users TO some_user;REVOKE SELECT ON users FROM some_user;

这些例子展示了如何授予和撤销用户对users表的SELECT(查询)权限。

每种类型的语言都有其特定的用途和命令集,它们共同支持数据库的全面功能,包括数据的查询、操纵、定义和控制。

http://www.lryc.cn/news/321013.html

相关文章:

  • MacOS---设置Java环境变量
  • 使用 Boot Camp 助理查明您的 Mac 需不需要 Windows 安装介质
  • KY105 整除问题(用Java实现)
  • C++ 接口的实现,及作用通俗理解方式
  • TypeScript:typescript的安装与运行
  • 【代码随想录Day27】
  • 【一】【单片机】有关LED的实验
  • 面试算法-49-缺失的第一个正数
  • 论文笔记:液体管道泄漏综合检测与定位模型
  • 抖音视频批量提取软件|无水印视频下载
  • Linux docker1--环境及docker安装
  • uniapp使用uview - DatetimePicker 时间选择器 /时间戳转化
  • python实现websocket
  • ElasticSearch简介及常见用法
  • js iframe获取documen中的对象为空问题
  • vue3子父组件之间的调用
  • 用 二层口 实现三层口 IP 通信的一个实现方法
  • (学习日记)2024.03.12:UCOSIII第十四节:时基列表
  • 四.流程控制(顺序,分支,循环,嵌套)
  • 了解常用开发模型 -- 瀑布模型、螺旋模型、增量与迭代、敏捷开发
  • 使用 Vue CLI 创建一个 Vue2 项目
  • Linux工具 - 耀眼的git
  • Spring Security的开发
  • C语言 实用调试技巧
  • GPT的实现细节
  • docker安装Milvus
  • HTML静态网页成品作业(HTML+CSS)——世博园介绍(2个页面)
  • 微信小程序订阅消息授权弹窗事件
  • 谷歌的后量子密码学威胁模型
  • 机器人在果园内行巡检仿真