三、關(guān)系數(shù)據(jù)庫的標(biāo)準(zhǔn)語言———SQL
1.SQL概述SQL的英語名稱是結(jié)構(gòu)查詢語言(Structured Query Language)?br> ?/font>實際上它的功能包括查詢(Query)、操縱(Manipulation)、定義(Definition)和控制(Control)
四個方面,是一個綜合的、通用的、功能極強的關(guān)系數(shù)據(jù)庫語言。SQL支持?jǐn)?shù)據(jù)庫的三級模式結(jié)構(gòu)。
2.SQL的數(shù)據(jù)定義功能SQL的數(shù)據(jù)定義功能包括三部分:
定義基本表,定義視圖和定義索引。它們是:CREATE TABLE CREATE VIEW CREATE INDEX DROP TABLE DROP VIEW DROP INDEX SQL的數(shù)據(jù)定義功能可用于定義和修改模式(如基本表),定義外模式(如視圖)和內(nèi)模式(如索引)。
3.基本表的定義與刪除
定義基本表的語句格式為:
CREATE TABLE表名 (列名1 類型[NOT NULL]
。,列名2類型[NOT NULL]]…)
。燮渌麉(shù)];
其中,任選項“其它參數(shù)”是與物理存儲有關(guān)的參數(shù)。根據(jù)具體系統(tǒng)的不同而不同。刪除基本表的語句為:DROP TABLE表名;刪除索引的語句為:DROP INDEX索引名;刪除索引的同時把有關(guān)索引的描述也從數(shù)據(jù)字典中刪去。但表的內(nèi)涵仍存在且其數(shù)據(jù)外延內(nèi)容不變。把一個基本表的定義連同表上所有的記錄、索引以及由此基本表導(dǎo)出的所有視圖全部都刪除,并釋放相應(yīng)的存儲空間。
4.索引的建立與刪除
對一個基本表,可以根據(jù)應(yīng)用環(huán)境的需要建立若干索引,以提供多種存取方式。通常,索引的建立和刪除由DBA或表的主人(即建立表的人)負(fù)責(zé)。用戶不必也不能在存取數(shù)據(jù)時選擇索引。存取路徑的選擇由系統(tǒng)自動進行。索引的描述存放在數(shù)據(jù)字典中。建立索引的語句格式為:
CREATE[UNIQUE] INDEX索引名ON基本表名(列名[次序][,列名[次序]]…)[其他參數(shù)];這里的任選項———其他參數(shù)是與物理存儲有關(guān)的參數(shù)。索引可以建在一列或幾列上。圓括號內(nèi)是索引列的順序說明表。其中的任選項———次序,指定了索引值排序的次序?扇SC(升序)或DESC(降序)。缺省值為升序。UNIQUE表示每一索引值只對應(yīng)唯一的數(shù)據(jù)記錄。
5.SQL的數(shù)據(jù)操縱功能
SQL的數(shù)據(jù)操縱功能包括SELECT,INSERT,DELETE和UPDATE四個語句,即檢索和更新(包括增、刪、改)兩部分工能。檢索就是查詢。
SQL更新語句SQL的更新語句
包括修改,刪除和插入三類語句。
、傩薷模║PDATE)(亦稱為更新)
修改語句的一般格式為:
UPDATE表名
SET字段=表達式[,字段=表達式]…
。踂HERE謂詞];
修改指定表中滿足謂詞(或條件)的元組,把這些元組按SET子句中的表達式修改相應(yīng)屬性或字段上的值。
、趧h除(DELETE)
刪除語句一般格式為:
DELETE FROM表名
。踂HERE謂詞];
從指定表中刪除滿足謂詞的那些記錄。沒有WHERE子句時表示刪去此表中的全部記錄,但此表的定義仍在數(shù)據(jù)字典中,只是一個空表。DELETE只對表外延操作,不對內(nèi)涵操作。
、鄄迦耄↖NSERT)插入語句的一般格式為:
INSERT INTO表名[(字段名[,字段名]…)]
valueS(常量[,常量]…);
或
INSERT
INTO表名[(字段名[,字段名]…)]
子查詢;
第一種格式把一個新記錄插入指定的表中。第二種格式把子查詢的結(jié)果插入表中。若表中有些字段在插入語句中沒有出現(xiàn),則這些字段上的值取空值NULL。當(dāng)然在表定義中說明了NOT NULL的字段在插入時不能取NULL。若插入語句中沒有指出字段名,則新記錄必須在每個字段上均有值。
6.視圖
視圖是從一個或幾個基本表(或視圖)導(dǎo)出的表。某一用戶可以定義若干視圖。因此對某一用戶而言,按ANSI/SPARC報告的觀點,他的外模式是由若干基本表和若干視圖組成的。視圖和基本表不同,視圖是一個虛表,即視圖所對應(yīng)的數(shù)據(jù)不實際存儲在數(shù)據(jù)庫中,數(shù)據(jù)庫中只存儲視圖的定義(存在數(shù)據(jù)字典中)。視圖一經(jīng)定義就可以和基本表一樣被查詢、被刪除(DROP),也可以用來定義新的視圖,但更新(增、刪、改)操作將有一定限制。視圖可以理解成一個數(shù)據(jù)庫,只有內(nèi)涵保存在數(shù)據(jù)庫字典中,而無外延存儲;其外延是在使用時動態(tài)地生成的或計算出來的。
(1)視圖的定義與刪除
SQL建立視圖的語句格式為:
CREATE VIEW視圖名[(字段名[,字段名]…)]
AS子查詢
。踂ITH CHECK OPTION謂詞];
視圖可以刪除,語句格式為:
DROP VIEW視圖名;
視圖的定義就從數(shù)據(jù)字典中刪除。由此視圖導(dǎo)出的其它視圖也將自動被刪除。若導(dǎo)出此視圖的基本表刪除了,則此視圖也將自動刪除。
。2)視圖的查詢語句
視圖定義后,用戶可以如同基本表那樣對視圖查詢。
。3)視圖的更新語句對視圖的更新最終要轉(zhuǎn)換成對基本表的更新(這里的更新,指INSERT,UPDATE和DELETE三類操作)。在關(guān)系數(shù)據(jù)庫中,并非所有的視圖都是可更新的,也就是說,有些視圖的更新不能唯一地有意義地轉(zhuǎn)換成對基本表的更新。
。4)視圖的優(yōu)點視圖的概念具有很多優(yōu)點,主要有:
。1)視圖對于數(shù)據(jù)庫的重構(gòu)造提供了一定程度的邏輯獨立性;
(2)簡化了用戶觀點;
。3)視圖機制使不同的用戶能以不同的方式看待同一數(shù)據(jù);
(4)視圖機制對機密數(shù)據(jù)提供了自動的安全保護功能。
7.SQL的數(shù)據(jù)控制功能
SQL數(shù)據(jù)控制功能是指控制用戶對數(shù)據(jù)的存取權(quán)力。某個用戶對某類數(shù)據(jù)具有何種操作權(quán)力是由DBA決定的。這是個政策問題而不是技術(shù)問題。數(shù)據(jù)庫管理系統(tǒng)的功能是保證這些決定的執(zhí)行。為此它必須能:
。1)把授權(quán)的決定告知系統(tǒng),這是由SQL的GRANT和REVOKE語句來完成的。
(2)把授權(quán)的結(jié)果存入數(shù)據(jù)字典。
(3)當(dāng)用戶提出操作請求時,根據(jù)授權(quán)情況進行檢查,以決定是執(zhí)行操作請求還是拒絕之。授權(quán)語句的一般格式為:
GRANT權(quán)力[,權(quán)力]…[ON對象類型對象名] TO用戶[,用戶]…,
[WITH GRANT OPTION];
對不同類型的操作對象可有不同的操作權(quán)力。
。1)對基本表、視圖及其字段的操作權(quán)力有查詢、插入、更新、刪除以及它們的總和ALL PRIVILEGE。
。2)對基本表的操作權(quán)力還有修改(ALTER)和建立索引(INDEX)。
。3)對數(shù)據(jù)庫的操作權(quán)力有建立表(CREATETAB)。某用戶有了此權(quán)力就可以使用Create table建立基本表。稱他為表的主人,擁有對此表的一切操作權(quán)力。
(4)對表空間的權(quán)力有使用(USE)數(shù)據(jù)庫空間存儲基本表的權(quán)力。
。5)系統(tǒng)權(quán)力有建立新數(shù)據(jù)庫(CREATEDBA)的權(quán)力。GRANT語句中的任選項WITH GRANT OPTION的作用是使獲得某種權(quán)力的用戶可以把權(quán)力再授予別的用戶。
8.嵌入式SQL
把SQL嵌入主語言使用時必須解決三個問題:
。1)區(qū)分SQL語句與主語言語句。這是通過在所有的SQL語句前加前綴EXEC SQL來解決的。SQL語句結(jié)束標(biāo)志隨主語言不同而不同,如PL/1用分號(;),COBOL用EMD-EXEC來表示。SQL語句首先由預(yù)編譯程序加以處理,轉(zhuǎn)換為主語言編譯程序能夠識別的形式,然后交主語言編譯程序進一步處理。
。2)數(shù)據(jù)庫工作單元和程序工作單元之間的通信。SQL語句中可以使用主語言的程序變量(簡稱主變量),這些變量名前加冒號(:)作標(biāo)志,以區(qū)別地字段名,程序中使用的任何表(基本表或視圖)都要用EXEC SQL DECLARE語句加以說明。一則使程序更加清晰,二則使預(yù)編譯程序能作某些語法檢查。SQL語句執(zhí)行后,系統(tǒng)要反饋給應(yīng)用程序若干信息,這些信息送到SQL的通信區(qū)SQL CA。SQL CA用語句EXEC SQL INCLUDE加以定義。在SQL CA中有一個狀態(tài)指示字段SQL CODE。當(dāng)SQL CODE為零時,表示SQL語句執(zhí)行成功,否則返回一個錯誤代碼(負(fù)值)或警告信息(正值)。程序員應(yīng)該在每個SQL語句之后測試SQL CODE的值,以便處理各種情況。
。3)一個SQL語句原則上可產(chǎn)生或處理一組記錄,而主語言一次只能處理一個記錄,為此必須協(xié)調(diào)兩種處理方式。這是用游標(biāo)(Cursor)來解決的。下面首先討論不需要游標(biāo)的DML語句,然后討論使用游標(biāo)的DML語句。
希望與更多計算機等級考試的網(wǎng)友交流,請進入計算機等級考試論壇
更多信息請訪問:考試吧計算機等級考試欄目
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |