中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

DDL、DML和DCL的區別與理解是什么

發布時間:2021-11-30 14:13:23 來源:億速云 閱讀:381 作者:柒染 欄目:數據庫

今天就跟大家聊聊有關DDL、DML和DCL的區別與理解是什么,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

DML、DDL、DCL區別 .

總體解釋: DML(data manipulation language): 它們是SELECT、UPDATE、INSERT、DELETE,就象它的名字一樣,這4條命令是用來對數據庫里的數據進行操作的語言 DDL(data definition language): DDL比DML要多,主要的命令有CREATE、ALTER、DROP等,DDL主要是用在定義或改變表(TABLE)的結構,數據類型,表之間的鏈接和約束等初始化工作上,他們大多在建立表時使用 DCL(Data Control Language): 是數據庫控制功能。是用來設置或更改數據庫用戶或角色權限的語句,包括(grant,deny,revoke等)語句。

在默認狀態下,只有sysadmin,dbcreator,db_owner或db_securityadmin等人員才有權力執行DCL 

詳細解釋: 

一、DDL is Data Definition Language statements. Some examples:數據定義語言,用于定義和管理 SQL 數據庫中的所有對象的語言 

1.CREATE - to create objects in the database 創建 

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]。   

下面是對Truncate語句在MSSQLServer2000中用法和原理的說明:   

Truncate table 表名 速度快,而且效率高,因為:   

TRUNCATE TABLE 在功能上與不帶 WHERE 子句的 DELETE 語句相同:二者均刪除表中的全部行。但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系統和事務日志資源少。   

DELETE 語句每次刪除一行,并在事務日志中為所刪除的每行記錄一項。TRUNCATE TABLE 通過釋放存儲表數據所用的數據頁來刪除數據,并且只在事務日志中記錄頁的釋放。   

TRUNCATE TABLE 刪除表中的所有行,但表結構及其列、約束、索引等保持不變。新行標識所用的計數值重置為該列的種子。如果想保留標識計數值,請改用 DELETE。如果要刪除表定義及其數據,請使用 DROP TABLE 語句。   

對于由 FOREIGN KEY 約束引用的表,不能使用 TRUNCATE TABLE,而應使用不帶 WHERE 子句的 DELETE 語句。由于 TRUNCATE TABLE 不記錄在日志中,所以它不能激活觸發器。   

TRUNCATE TABLE 不能用于參與了索引視圖的表。 

5.COMMENT - add comments to the data dictionary 注釋 

6.GRANT - gives user's access privileges to database 授權 

7.REVOKE - withdraw access privileges given with the GRANT command 收回已經授予的權限 

二、DML is Data Manipulation Language statements. Some examples:數據操作語言,SQL中處理數據等操作統稱為數據操縱語言 

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執行每一條SQL語句,都必須經過Oracle優化器的評估。

所以,了解優化器是如何選擇(搜索)路徑以及索引是如何被使用的,對優化SQL語句有很大的幫助。Explain可以用來迅速方便地查出對于給定SQL語句中的查詢數據是如何得到的即搜索路徑(我們通常稱為Access Path)。從而使我們選擇最優的查詢方式達到最大的優化效果。 

7.LOCK TABLE - control concurrency 鎖,用于控制并發 三、DCL is Data Control Language statements. Some examples:數據控制語言,用來授予或回收訪問數據庫的某種特權,并控制數據庫操縱事務發生的時間及效果,對數據庫實行監視等 

1.COMMIT - save work done 提交 

2.SAVEPOINT - identify a point in a transaction to which you can later roll back 保存點 

3.ROLLBACK - restore database to original since the last COMMIT 回滾 

4.SET TRANSACTION - Change transaction options like what rollback segment to use 設置當前事務的特性,它對后面的事務沒有影響. 

DDL、DML和DCL的理解

1、DDL

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

1-2、DDL的主要語句(操作) Create語句:可以創建數據庫和數據庫的一些對象。 Drop語句:可以刪除數據表、索引、觸發程序、條件約束以及數據表的權限等。 Alter語句:修改數據表定義及屬性。 

1-3、DDL的操作對象(表) 

1-3-1、表的概念 表的創建就是用來存放數據用的,由于我們存放的數據的不通,所以我們需要定義些數據類型,以方便管理。 

1-3-2、表的屬性  主鍵屬性:主鍵就是主鍵約束,只不過起的名字不同了,主鍵的起名偏向于虛的(就是描述描述這件事),主鍵約束起名偏向于實得(就是描述操作的實施),描述的都是同一件事,主鍵約束就是表中的一個屬性;在一個表中最多可以有一個主鍵;一個主鍵可以定義在一個或多個字段;主鍵使一個或多個字段的值必須唯一且不為空,這樣做可以通過該字段或該組字段中的值唯一的代表一條記錄。 唯一屬性:一個表中只能有一個主鍵屬性,為了方表用戶,提出唯一約束;唯一約束可以定義在一個或多個字段上;唯一約束使該字段或該組字段中的值唯一,可以為空,但是,不能重復。 外鍵屬性:又叫外鍵,又叫外鍵約束,跟主鍵和主鍵約束的關系是一樣的;外鍵約束針對的兩個表,如果表A的主關鍵字是表B中的字段,則該字段稱為表B的外鍵,表A稱為主表,表B稱為從表,但要注意,必須要計算機要知道你是這種關系。 核查、Null和缺省屬性:核查屬性又叫核查約束,Null屬性又叫Null約束,缺省屬性又叫缺省約束;這些名稱是描述一件事,描述一種情況,這件事或這張情況我們當然可以人為的那樣特意做(輸入數據是注意就行),但是,他們的本意是實現自動化,也就是讓計算機做這件事。 (你知道為什么建立主鍵和唯一約束的時候,會自動的創建索引嗎?而且是唯一索引,想一想索引大多在那些字段上用,以及索引的作用就會知道了。像主鍵約束、唯一約束、非空約束、外鍵約束、核查約束和缺省約束這些操作都是使表具有某些特性,所以在這里我認為他們都是表的屬性。)

2、DML

2-1、DML的概述 DML(Data Manipulation Language 數據操控語言)用于操作數據庫對象中包含的數據,也就是說操作的單位是記錄。 

2-2、DML的主要語句(操作) Insert語句:向數據表張插入一條記錄。 Delete語句:刪除數據表中的一條或多條記錄,也可以刪除數據表中的所有記錄,但是,它的操作對象仍是記錄。 Update語句:用于修改已存在表中的記錄的內容。 

2-3、DML的操作對象——記錄 

2-3-1、注意 當我們對記錄進行Insert、Delete和Update操作的時候,一定要注意,一定要清楚DDL對其的一些操作。

3、DCL

3-1、DCL的概述 DCL(Data Control Language 數據控制語句)的操作是數據庫對象的權限,這些操作的確定使數據更加的安全。 

3-2、DCL的主要語句(操作) Grant語句:允許對象的創建者給某用戶或某組或所有用戶(PUBLIC)某些特定的權限。 Revoke語句:可以廢除某用戶或某組或所有用戶訪問權限 

3-3、DCL的操作對象(用戶) 此時的用戶指的是數據庫用戶。

看完上述內容,你們對DDL、DML和DCL的區別與理解是什么有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

盱眙县| 长宁县| 芷江| 黔东| 景泰县| 山东| 资兴市| 连城县| 霸州市| 个旧市| 京山县| 双柏县| 胶州市| 陇西县| 根河市| 江门市| 拉萨市| 屯门区| 建昌县| 霞浦县| 吉水县| 东阿县| 咸阳市| 广河县| 玉门市| 防城港市| 云林县| 宁南县| 郯城县| 界首市| 图们市| 古田县| 四平市| 涞源县| 绵阳市| 江永县| 巩义市| 大竹县| 汾西县| 汉中市| 西乌珠穆沁旗|