資料庫 DML、DDL、DCL區別 .

来源:http://www.cnblogs.com/renjiaqi/archive/2016/12/21/6207719.html
-Advertisement-
Play Games

總體解釋: DML(data manipulation language): 它們是SELECT、UPDATE、INSERT、DELETE,就象它的名字一樣,這4條命令是用來對資料庫里的數據進行操作的語言 DDL(data definition language): DDL比DML要多,主要的命令有 ...


總體解釋:

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的操作對象(用戶)
                此時的用戶指的是資料庫用戶。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 第一步: protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) ...
  • 一、文件保存數據介紹 Activity提供了openFileOutput()方法可以用於把數據輸出到文件中,具體的實現過程與在J2SE環境中保存數據到文件中是一樣的。文件可用來存放大量數據,如文本、圖書、音頻等。 File對象適合按照從開始到結束的順序不跳過地讀取或寫入大量數據。例如,它適合於圖片文 ...
  • 問題: 在和Unity交互的過程中,從Unity開發工具打包出來的項目文件,在添加AFNetworking庫,運行時報出以下錯誤: Undefined symbols for architecture armv7: "_kUTTagClassMIMEType", referenced from: - ...
  • 昨天上架到appStore的時候碰到個問題,構建好後上傳到itunesconnect的的包都用不了, 顯示錯誤為:此構建版本無效。 或者英文顯示為:ITC.apps.preReleaseBuild.errors.invalidBinary 由於和itunesconnect帳號綁定的郵箱暫時進不去,沒 ...
  • 本期內容包括: Google的物聯網平臺Android Things; FileProvider; Android Studio的Layout Preview使用; Retrofit2使用; Google Sign-In和SmartLock; 把敏感信息放入NDK的解決方式. 設計部分討論了調色板... ...
  • 使用快遞100查詢介面實現 源碼地址:https://github.com/chenjie200280/weizhang 測試安裝包:http://files.cnblogs.com/files/ttsofts/weizhang.apk 1.查詢界面 2.查詢結果1 (有違章的信息) 3.查詢結果3 ...
  • 很多人會遇到 初次運行 react native run android的時候 gradle下載極慢,甚至會失敗的問題 如下圖 實際上這個問題好解決的 1. 首先 把對應版本的 下載到本地任意一個磁碟里 比如說我在到了 2. 然後拖拽 文件夾到 瀏覽器 就會得到 的訪問地址 後面加上文件名 得到 的 ...
  • 廢話不多說,直接上乾貨 14:13:23 事務 概括:事務是一種機制,一個操作序列,包含一組資料庫操作命令,並且把所有的命令作為一個整體一起 向系統提交或撤銷操作 請求。 事務的特性: 1.原子性:事務是一個完整的操作,事務的各元素都是不可分的(原子的)。事務中的一組命令要麼都執行,要麼都不執 行。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...