主頁(yè) > 知識(shí)庫(kù) > DDL、DML和DCL的區(qū)別與理解

DDL、DML和DCL的區(qū)別與理解

熱門標(biāo)簽:浙江穩(wěn)定外呼系統(tǒng)供應(yīng)商 電銷外呼系統(tǒng)軟件功能 慶陽(yáng)地圖標(biāo)注 怎么給高德做地圖標(biāo)注 承德地圖標(biāo)注公司名需要花錢嗎 榕城市地圖標(biāo)注 北京400電話辦理多少錢 咸陽(yáng)電腦外呼系統(tǒng)運(yùn)營(yíng)商 美團(tuán)地圖標(biāo)注商戶認(rèn)證注冊(cè)
DML、DDL、DCL區(qū)別 .

總體解釋:

DML(data manipulation language):
它們是SELECT、UPDATE、INSERT、DELETE,就象它的名字一樣,這4條命令是用來(lái)對(duì)數(shù)據(jù)庫(kù)里的數(shù)據(jù)進(jìn)行操作的語(yǔ)言
DDL(data definition language):
DDL比DML要多,主要的命令有CREATE、ALTER、DROP等,DDL主要是用在定義或改變表(TABLE)的結(jié)構(gòu),數(shù)據(jù)類型,表之間的鏈接和約束等初始化工作上,他們大多在建立表時(shí)使用
DCL(Data Control Language):
是數(shù)據(jù)庫(kù)控制功能。是用來(lái)設(shè)置或更改數(shù)據(jù)庫(kù)用戶或角色權(quán)限的語(yǔ)句,包括(grant,deny,revoke等)語(yǔ)句。在默認(rèn)狀態(tài)下,只有sysadmin,dbcreator,db_owner或db_securityadmin等人員才有權(quán)力執(zhí)行DCL

詳細(xì)解釋:

一、DDL is Data Definition Language statements. Some examples:數(shù)據(jù)定義語(yǔ)言,用于定義和管理 SQL 數(shù)據(jù)庫(kù)中的所有對(duì)象的語(yǔ)言
1.CREATE - to create objects in the database 創(chuàng)建
2.ALTER - alters the structure of the database 修改
3.DROP - delete objects from the database 刪除
4.TRUNCATE - remove all records from a table, including all spaces allocated for the records are removed
TRUNCATE TABLE [Table Name]。
  下面是對(duì)Truncate語(yǔ)句在MSSQLServer2000中用法和原理的說(shuō)明:
  Truncate table 表名 速度快,而且效率高,因?yàn)?
  TRUNCATE TABLE 在功能上與不帶 WHERE 子句的 DELETE 語(yǔ)句相同:二者均刪除表中的全部行。但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系統(tǒng)和事務(wù)日志資源少。
  DELETE 語(yǔ)句每次刪除一行,并在事務(wù)日志中為所刪除的每行記錄一項(xiàng)。TRUNCATE TABLE 通過(guò)釋放存儲(chǔ)表數(shù)據(jù)所用的數(shù)據(jù)頁(yè)來(lái)刪除數(shù)據(jù),并且只在事務(wù)日志中記錄頁(yè)的釋放。
  TRUNCATE TABLE 刪除表中的所有行,但表結(jié)構(gòu)及其列、約束、索引等保持不變。新行標(biāo)識(shí)所用的計(jì)數(shù)值重置為該列的種子。如果想保留標(biāo)識(shí)計(jì)數(shù)值,請(qǐng)改用 DELETE。如果要?jiǎng)h除表定義及其數(shù)據(jù),請(qǐng)使用 DROP TABLE 語(yǔ)句。
  對(duì)于由 FOREIGN KEY 約束引用的表,不能使用 TRUNCATE TABLE,而應(yīng)使用不帶 WHERE 子句的 DELETE 語(yǔ)句。由于 TRUNCATE TABLE 不記錄在日志中,所以它不能激活觸發(fā)器。
  TRUNCATE TABLE 不能用于參與了索引視圖的表。
5.COMMENT - add comments to the data dictionary 注釋
6.GRANT - gives user's access privileges to database 授權(quán)
7.REVOKE - withdraw access privileges given with the GRANT command 收回已經(jīng)授予的權(quán)限

二、DML is Data Manipulation Language statements. Some examples:數(shù)據(jù)操作語(yǔ)言,SQL中處理數(shù)據(jù)等操作統(tǒng)稱為數(shù)據(jù)操縱語(yǔ)言

1.SELECT - retrieve data from the a database 查詢
2.INSERT - insert data into a table 添加
3.UPDATE - updates existing data within a table 更新
4.DELETE - deletes all records from a table, the space for the records remain 刪除
5.CALL - call a PL/SQL or Java subprogram
6.EXPLAIN PLAN - explain access path to data
Oracle RDBMS執(zhí)行每一條SQL語(yǔ)句,都必須經(jīng)過(guò)Oracle優(yōu)化器的評(píng)估。所以,了解優(yōu)化器是如何選擇(搜索)路徑以及索引是如何被使用的,對(duì)優(yōu)化SQL語(yǔ)句有很大的幫助。Explain可以用來(lái)迅速方便地查出對(duì)于給定SQL語(yǔ)句中的查詢數(shù)據(jù)是如何得到的即搜索路徑(我們通常稱為Access Path)。從而使我們選擇最優(yōu)的查詢方式達(dá)到最大的優(yōu)化效果。
7.LOCK TABLE - control concurrency 鎖,用于控制并發(fā)

三、DCL is Data Control Language statements. Some examples:數(shù)據(jù)控制語(yǔ)言,用來(lái)授予或回收訪問(wèn)數(shù)據(jù)庫(kù)的某種特權(quán),并控制數(shù)據(jù)庫(kù)操縱事務(wù)發(fā)生的時(shí)間及效果,對(duì)數(shù)據(jù)庫(kù)實(shí)行監(jiān)視等

1.COMMIT - save work done 提交
2.SAVEPOINT - identify a point in a transaction to which you can later roll back 保存點(diǎn)
3.ROLLBACK - restore database to original since the last COMMIT 回滾
4.SET TRANSACTION - Change transaction options like what rollback segment to use 設(shè)置當(dāng)前事務(wù)的特性,它對(duì)后面的事務(wù)沒(méi)有影響.

DDL、DML和DCL的理解 (張青山)

先給出一個(gè)圖:





1、DDL

      1-1、DDL的概述
               DDL(Data Definition Language 數(shù)據(jù)定義語(yǔ)言)用于操作對(duì)象和對(duì)象的屬性,這種對(duì)象包括數(shù)據(jù)庫(kù)本身,以及數(shù)據(jù)庫(kù)對(duì)象,像:表、視圖等等,DDL對(duì)這些對(duì)象和屬性的管理和定義具體表現(xiàn)在Create、Drop和Alter上。特別注意:DDL操作的“對(duì)象”的概念,”對(duì)象“包括對(duì)象及對(duì)象的屬性,而且對(duì)象最小也比記錄大個(gè)層次。以表舉例:Create創(chuàng)建數(shù)據(jù)表,Alter可以更改該表的字段,Drop可以刪除這個(gè)表,從這里我們可以看到,DDL所站的高度,他不會(huì)對(duì)具體的數(shù)據(jù)進(jìn)行操作。

      1-2、DDL的主要語(yǔ)句(操作)
               Create語(yǔ)句:可以創(chuàng)建數(shù)據(jù)庫(kù)和數(shù)據(jù)庫(kù)的一些對(duì)象。
               Drop語(yǔ)句:可以刪除數(shù)據(jù)表、索引、觸發(fā)程序、條件約束以及數(shù)據(jù)表的權(quán)限等。
               Alter語(yǔ)句:修改數(shù)據(jù)表定義及屬性。
      1-3、DDL的操作對(duì)象(表)
               1-3-1、表的概念
                           表的創(chuàng)建就是用來(lái)存放數(shù)據(jù)用的,由于我們存放的數(shù)據(jù)的不通,所以我們需要定義些數(shù)據(jù)類型,以方便管理。
               1-3-2、表的屬性   
                           主鍵屬性:主鍵就是主鍵約束,只不過(guò)起的名字不同了,主鍵的起名偏向于虛的(就是描述描述這件事),主鍵約束起名偏向于實(shí)得(就是描述操作的實(shí)施),描述的都是同一件事,主鍵約束就是表中的一個(gè)屬性;在一個(gè)表中最多可以有一個(gè)主鍵;一個(gè)主鍵可以定義在一個(gè)或多個(gè)字段;主鍵使一個(gè)或多個(gè)字段的值必須唯一且不為空,這樣做可以通過(guò)該字段或該組字段中的值唯一的代表一條記錄。
                           唯一屬性:一個(gè)表中只能有一個(gè)主鍵屬性,為了方表用戶,提出唯一約束;唯一約束可以定義在一個(gè)或多個(gè)字段上;唯一約束使該字段或該組字段中的值唯一,可以為空,但是,不能重復(fù)。
                           外鍵屬性:又叫外鍵,又叫外鍵約束,跟主鍵和主鍵約束的關(guān)系是一樣的;外鍵約束針對(duì)的兩個(gè)表,如果表A的主關(guān)鍵字是表B中的字段,則該字段稱為表B的外鍵,表A稱為主表,表B稱為從表,但要注意,必須要計(jì)算機(jī)要知道你是這種關(guān)系。

               核查、Null和缺省屬性:核查屬性又叫核查約束,Null屬性又叫Null約束,缺省屬性又叫缺省約束;這些名稱是描述一件事,描述一種情況,這件事或這張情況我們當(dāng)然可以人為的那樣特意做(輸入數(shù)據(jù)是注意就行),但是,他們的本意是實(shí)現(xiàn)自動(dòng)化,也就是讓計(jì)算機(jī)做這件事。
            (你知道為什么建立主鍵和唯一約束的時(shí)候,會(huì)自動(dòng)的創(chuàng)建索引嗎?而且是唯一索引,想一想索引大多在那些字段上用,以及索引的作用就會(huì)知道了。像主鍵約束、唯一約束、非空約束、外鍵約束、核查約束和缺省約束這些操作都是使表具有某些特性,所以在這里我認(rèn)為他們都是表的屬性。)

2、DML

      2-1、DML的概述
               DML(Data Manipulation Language 數(shù)據(jù)操控語(yǔ)言)用于操作數(shù)據(jù)庫(kù)對(duì)象中包含的數(shù)據(jù),也就是說(shuō)操作的單位是記錄。
      2-2、DML的主要語(yǔ)句(操作)
               Insert語(yǔ)句:向數(shù)據(jù)表張插入一條記錄。
               Delete語(yǔ)句:刪除數(shù)據(jù)表中的一條或多條記錄,也可以刪除數(shù)據(jù)表中的所有記錄,但是,它的操作對(duì)象仍是記錄。
               Update語(yǔ)句:用于修改已存在表中的記錄的內(nèi)容。
      2-3、DML的操作對(duì)象——記錄
               2-3-1、注意
                           當(dāng)我們對(duì)記錄進(jìn)行Insert、Delete和Update操作的時(shí)候,一定要注意,一定要清楚DDL對(duì)其的一些操作。

3、DCL

       3-1、DCL的概述
                DCL(Data Control Language 數(shù)據(jù)控制語(yǔ)句)的操作是數(shù)據(jù)庫(kù)對(duì)象的權(quán)限,這些操作的確定使數(shù)據(jù)更加的安全。
       3-2、DCL的主要語(yǔ)句(操作)
                Grant語(yǔ)句:允許對(duì)象的創(chuàng)建者給某用戶或某組或所有用戶(PUBLIC)某些特定的權(quán)限。
                Revoke語(yǔ)句:可以廢除某用戶或某組或所有用戶訪問(wèn)權(quán)限
       3-3、DCL的操作對(duì)象(用戶)
                此時(shí)的用戶指的是數(shù)據(jù)庫(kù)用戶。 

您可能感興趣的文章:
  • Sql學(xué)習(xí)第二天——SQL DML與CTE概述
  • 詳解SQL四種語(yǔ)言:DDL DML DCL TCL

標(biāo)簽:上海 江蘇 重慶 新鄉(xiāng) 呼和浩特 昭通 拉薩 貴州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《DDL、DML和DCL的區(qū)別與理解》,本文關(guān)鍵詞  DDL,DML,和,DCL,的,區(qū)別,與,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《DDL、DML和DCL的區(qū)別與理解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于DDL、DML和DCL的區(qū)別與理解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章