区分DML,DDL,DCL,DQL

本文详细解释了SQL语言中的四个关键部分:数据定义语言(DDL)、数据操作语言(DML)、数据控制语言(DCL)及数据查询语言(DQL)。涵盖了各自的用途、常见语句及其应用场景。
 

区分DML,DDL,DCL,DQL

    SQL 语言(结构化程序设计语言)的组成部分。SQL语言包括三种主要程序设计语言类别的语句:数据定义语言(DDL),数据操作语言(DML)以及数据控制语言(DCL)

DML

DML包括:INSERT、UPDATE、DELETE。注意,select语句属于DQL(Data Query Language)。

DML(Data Manipulation Language – 数据操作语言) 可以在下列条件下执行:

       向表中插入数据

   修改现存数据

       删除现存数据

DDL

数据库模式定义语言DDL(Data Definition Language),是用于描述数据库中要存储的现实世界实体的语言。一个数据库模式包含该数据库中所有实体的描述定义。

 

这些定义包括结构定义、操作方法定义等。  数据库模式定义语言,DDL并不是程序语言

 

数据库模式的定义通常有两种方式: 交互方式定义模式和通过数据描述语言DDL 描述文本定义模式。

常见的DDL语句

       创建数据库 create database

       创建数据库表格 create table

       修改数据库表格 alter table

       删除数据库表格 delete table

      

       创建查询命令 create view

       修改查询命令  alter view

       删除查询命令  delete view

       删除数据表内容  truncate table

DCL

DCL(Data Control Language)是数据库控制语言。是用来设置或更改数据库用户或角色权限的语句,包括(grant,deny,revoke等)语句。

 在默认状态下,只有sysadmin,dbcreator,db_owner或db_securityadmin等人员才有权力执行DCL

 

语言概述

  一.对话框形象、直观,可以随意输入、随时修改,鼠标、键盘并用,是一种深受用户欢迎的界面。   

  

    二.对话框用DCL语言(Dialog Control Language)定义,得到"DCL类型的文件,用AutoLISP或C程序驱动。

   

    三.AutoCAD提供了两个重要的DCL文件:ACAD.DCL存放AutoCAD系统定义的对话框,BASE.DCL为用户提供了一些常用的对话框标准控件。

 

对话框的特点

   ①、语法简单.

   ②、各DCL对象所需要的属性定义不同,需要熟记各种属性定义。

  ③、编写的环境不挑剔(以一般的文版编辑软件,如记事本即可)通过AutoLISP         专属的DCL函数调用,才能被激活与执行。

   ④、横跨AutoCAD各作业平台,悠然自得。

 

DQL

 

DQL是数据查询语言 运用select,此处省略select用法。

 

1、事务概念:

 概念:在数据库中事务是工作的逻辑单元,一个事务是由一个或多个完成一组的

 

相关行为的SQL语句组成,通过事务机制确保这一组SQL语句所作的操作要么完

 

全成功执行,完成整个工作单元操作,要么一点也不执行。

 

  主要特性:确保数据库的完整性。

事务的控制语句

   在oracle数据库中,没有提供开始事务处理语句,所有的事务都是隐式开始的,也就是说在oracle中,用户不可以显示使用命令来开始一个事务.oracle任务第一条修改数据库的语句,或者一些要求事务处理的场合都是事务的隐式开始。但是当用户想要终止一个事务处理时,必须显示使用commit和rollback语句结束。

  根据事务ACID属性,oracle提供了如下的事务控制语句:

   Set transaction 设置事物属性

   Set constrains  设置事物的约束模式

   约束模式是指:在事务中修改数据时,数据库中的约束立即应用于数据,还是将约束推迟到当前事务结束后应用。

   Savepoint 在事务中建立一个存储的点.当事务处理发生异常而回滚事务时,可指定事务回滚到某存储点.然后从该存储点重新执行。

   Release  savepoint  删除存储点

   Rollback 回滚事务 取消对数据库所作的任何操作

   Commit 提交事务 对数据库的操作做持久的保存。

 

 

 

 

 

<think>好的,我现在需要帮助用户理解数据库DDLDMLDCLDQL和TCL的定义及其区别。首先,我应该回顾用户提供的引用内容,确保准确涵盖每个术语。用户提到五个类别,其中TCL在引用中也有部分涉及,比如引用5提到了DDL操作是隐性提交的,不能回滚,这可能和TCL相关。 首先,我需要逐个定义每个术语,并引用正确的来源。比如,DDL是数据定义语言,涉及创建、修改和删除数据库对象,如CREATE、ALTER、DROP,这在引用1、2、3、4、5中都有提到。DML是数据操作语言,包括INSERT、UPDATE、DELETE,引用1、3、4、5都提到。DCL是数据控制语言,如GRANT和REVOKE,引用1、3、5。DQL是数据查询语言,主要是SELECT,引用1、3、4。TCL可能涉及事务控制,如COMMIT和ROLLBACK,引用2和5提到TCL,但需要确认用户提供的引用是否有足够信息。 接下来要区分它们的区别。根据引用4,DDLDML的主要区别在于DDL操作数据库对象结构,而DML操作表内数据。DCL负责权限,DQL负责查询。TCL处理事务,如提交和回滚。需要注意的是,用户提到的引用中,引用2和5提到了TCL,但可能信息较少,需要结合一般数据库知识补充。 然后,考虑如何结构化回答。按每个术语的定义和常见语句列表,然后对比它们的区别。可能需要表格来清晰展示。同时,用户要求生成相关问题,所以最后要添加相关问题部分。 需要检查是否有遗漏,比如TCL是否被正确涵盖。根据引用5,TCL可能未被详细讨论,但用户的问题明确提到TCL,所以需要补充其定义,即使引用信息有限,可能需要结合外部知识,但根据指示应尽可能使用提供的引用。引用5提到DDL操作是隐性提交,不能回滚,这可能与TCL有关,但需要明确TCL的定义,如COMMIT、ROLLBACK、SAVEPOINT,这可能不在引用中,但用户的问题需要回答,所以可能需要适当说明。 最后,确保回答符合格式要求:使用中文,数学公式正确,引用标识正确,相关问题生成。需要确认所有引用标记正确对应,例如引用[^1]、[^2]等是否正确关联到用户提供的引用内容。</think>### 数据库DDLDMLDCLDQL、TCL的定义与区别 #### 1. **DDL(数据定义语言)** 用于定义数据库结构和对象(如表、索引、视图等)。 - **常见语句**:`CREATE`(创建)、`ALTER`(修改)、`DROP`(删除)、`TRUNCATE`(清空表)[^1][^2][^5]。 - **特点**: - 操作对象是数据库结构,而非数据本身。 - DDL语句执行后会自动提交(隐性提交),无法回滚[^5][^4]。 #### 2. **DML(数据操作语言)** 用于对数据库中的数据进行增删改操作。 - **常见语句**:`INSERT`(插入)、`UPDATE`(更新)、`DELETE`(删除)[^1][^3][^4]。 - **特点**: - 操作对象是表中的数据,不影响表结构。 - 需要显式提交(如`COMMIT`)或回滚(如`ROLLBACK`)[^4][^5]。 #### 3. **DQL(数据查询语言)** 用于从数据库中检索数据。 - **核心语句**:`SELECT`(查询)[^1][^4]。 - **特点**: - 仅用于数据查询,不修改数据或结构。 - 支持复杂操作,如聚合函数、分组、排序等[^5]。 #### 4. **DCL(数据控制语言)** 用于管理数据库访问权限和安全控制。 - **常见语句**:`GRANT`(授权)、`REVOKE`(撤销权限)[^1][^3]。 - **特点**: - 控制用户对数据库对象的操作权限。 - 通常由数据库管理员(DBA)使用[^3][^4]。 #### 5. **TCL(事务控制语言)** 用于管理数据库事务的提交与回滚。 - **常见语句**:`COMMIT`(提交事务)、`ROLLBACK`(回滚事务)、`SAVEPOINT`(设置保存点)[^2][^5]。 - **特点**: - 与事务逻辑相关,确保数据一致性。 - DML操作需要配合TCL实现事务的最终生效或撤销[^5]。 --- ### **核心区别对比** | 类别 | 作用范围 | 常见语句 | 是否可回滚 | 操作对象 | |------|--------------------|--------------------------------------|------------|----------------| | DDL | 定义数据库结构 | `CREATE`, `ALTER`, `DROP` | 否[^5] | 表、索引等对象 | | DML | 操作数据 | `INSERT`, `UPDATE`, `DELETE` | 是[^4] | 表中的数据 | | DQL | 查询数据 | `SELECT` | 不涉及 | 数据检索 | | DCL | 权限控制 | `GRANT`, `REVOKE` | 否 | 用户权限 | | TCL | 事务控制 | `COMMIT`, `ROLLBACK` | 是 | 事务逻辑 | --- ### **示例说明** - **DDL示例**: ```sql CREATE TABLE students (id INT PRIMARY KEY, name VARCHAR(50)); ``` - **DML示例**: ```sql INSERT INTO students VALUES (1, 'Alice'); ``` - **DCL示例**: ```sql GRANT SELECT ON students TO user1; ``` ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值