什么是DQL、DML、DDL、DCL
SQL(Structure Query Language)語言是數(shù)據(jù)庫的核心語言。
SQL的發(fā)展是從1974年開始的,其發(fā)展過程如下:
1974年-----由Boyce和Chamberlin提出,當(dāng)時稱SEQUEL。
1976年-----IBM公司的Sanjase研究所在研制RDBMS SYSTEM R
時改為SQL。
1979年-----ORACLE公司發(fā)表第一個基于SQL的商業(yè)化RDBMS產(chǎn)品。
1982年-----IBM公司出版第一個RDBMS語言SQL/DS。
1985年-----IBM公司出版第一個RDBMS語言DB2。
1986年-----美國國家標(biāo)準(zhǔn)化組織ANSI宣布SQL作為數(shù)據(jù)庫工業(yè)標(biāo)準(zhǔn)。
SQL是一個標(biāo)準(zhǔn)的數(shù)據(jù)庫語言,是面向集合的描述性非過程化語言。
它功能強(qiáng),效率高,簡單易學(xué)易維護(hù)(迄今為止,我還沒見過比它還好
學(xué)的語言)。然而SQL語言由于以上優(yōu)點,同時也出現(xiàn)了這樣一個問題:
它是非過程性語言,即大多數(shù)語句都是獨立執(zhí)行的,與上下文無關(guān),而
絕大部分應(yīng)用都是一個完整的過程,顯然用SQL完全實現(xiàn)這些功能是很困
難的。所以大多數(shù)數(shù)據(jù)庫公司為了解決此問題,作了如下兩方面的工作:
(1)擴(kuò)充SQL,在SQL中引入過程性結(jié)構(gòu);(2)把SQL嵌入到高級語言中,
以便一起完成一個完整的應(yīng)用。
二 SQL語言的分類
SQL語言共分為四大類:數(shù)據(jù)查詢語言DQL,數(shù)據(jù)操縱語言DML,
數(shù)據(jù)定義語言DDL,數(shù)據(jù)控制語言DCL。
1 數(shù)據(jù)查詢語言DQL
數(shù)據(jù)查詢語言DQL基本結(jié)構(gòu)是由SELECT子句,FROM子句,WHERE
子句組成的查詢塊:
SELECT <字段名表>
FROM <表或視圖名>
WHERE <查詢條件>
2 數(shù)據(jù)操縱語言
數(shù)據(jù)操縱語言DML主要有三種形式:
1) 插入:INSERT
2) 更新:UPDATE
3) 刪除:DELETE
3 數(shù)據(jù)定義語言DDL
數(shù)據(jù)定義語言DDL用來創(chuàng)建數(shù)據(jù)庫中的各種對象-----表、視圖、
索引、同義詞、聚簇等如:
CREATE TABLE/VIEW/INDEX/SYN/CLUSTER
| | | | |
表 視圖 索引 同義詞 簇
4 數(shù)據(jù)控制語言DCL
數(shù)據(jù)控制語言DCL用來授予或回收訪問數(shù)據(jù)庫的某種特權(quán),并控制
數(shù)據(jù)庫操縱事務(wù)發(fā)生的時間及效果,對數(shù)據(jù)庫實行監(jiān)視等。如:
1) GRANT:授權(quán)。
2) ROLLBACK TO :回退到某一點。
回滾---ROLLBACK
回滾命令使數(shù)據(jù)庫狀態(tài)回到上次最后提交的狀態(tài)。其格式為:
SQL>ROLLBACK;
3) COMMIT :提交。
在數(shù)據(jù)庫的插入、刪除和修改操作時,只有當(dāng)事務(wù)在提交到數(shù)據(jù)
庫時才算完成。在事務(wù)提交前,只有操作數(shù)據(jù)庫的這個人才能有權(quán)看
到所做的事情,別人只有在最后提交完成后才可以看到。
提交數(shù)據(jù)有三種類型:顯式提交、隱式提交及自動提交。下面分
別說明這三種類型。
(1) 顯式提交
用COMMIT命令直接完成的提交為顯式提交。其格式為:
SQL>COMMIT;
(2) 隱式提交
用SQL命令間接完成的提交為隱式提交。這些命令是:
ALTER,AUDIT,COMMENT,CONNECT,CREATE,DISCONNECT,DROP,
EXIT,GRANT,NOAUDIT,QUIT,REVOKE,RENAME。
(3) 自動提交
若把AUTOCOMMIT設(shè)置為ON,則在插入、修改、刪除語句執(zhí)行后,
系統(tǒng)將自動進(jìn)行提交,這就是自動提交。其格式為:
SQL>SET AUTOCOMMIT ON;
總結(jié)
以上是生活随笔為你收集整理的什么是DQL、DML、DDL、DCL的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: silverlight,WPF动画终极攻
- 下一篇: 【SAS NOTE】substr函数