亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

試題 百分網(wǎng)手機站

計算機四級考試數(shù)據(jù)庫工程師考點:SQL

時間:2020-09-15 12:52:08 試題 我要投稿

計算機四級考試數(shù)據(jù)庫工程師考點:SQL

  SQL概述SQL的英語名稱是結(jié)構(gòu)查詢語言(Structured Query Language)。下面是小編為大家?guī)淼年P(guān)于SQL的知識,歡迎閱讀。

計算機四級考試數(shù)據(jù)庫工程師考點:SQL

  1.SQL概述SQL的英語名稱是結(jié)構(gòu)查詢語言(Structured Query Language)

  實際上它的功能包括查詢(Query)、操縱(Manipulation)、定義(Definition)和控制(Control)

  四個方面,是一個綜合的、通用的、功能極強的關(guān)系數(shù)據(jù)庫語言。SQL支持數(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或表的主人(即建立表的人)負責(zé)。用戶不必也不能在存取數(shù)據(jù)時選擇索引。存取路徑的選擇由系統(tǒng)自動進行。索引的描述存放在數(shù)據(jù)字典中。建立索引的語句格式為:

  CREATE[UNIQUE] INDEX索引名ON基本表名(列名[次序][,列名[次序]]…)[其他參數(shù)];這里的任選項———其他參數(shù)是與物理存儲有關(guān)的參數(shù)。索引可以建在一列或幾列上。圓括號內(nèi)是索引列的順序說明表。其中的任選項———次序,指定了索引值排序的次序。可取ASC(升序)或DESC(降序)。缺省值為升序。UNIQUE表示每一索引值只對應(yīng)唯一的數(shù)據(jù)記錄。

  5.SQL的數(shù)據(jù)操縱功能

  SQL的數(shù)據(jù)操縱功能包括SELECT,INSERT,DELETE和UPDATE四個語句,即檢索和更新(包括增、刪、改)兩部分工能。檢索就是查詢。

  SQL更新語句SQL的更新語句

  包括修改,刪除和插入三類語句。

  ①修改(UPDATE)(亦稱為更新)

  修改語句的一般格式為:

  UPDATE表名

  SET字段=表達式[,字段=表達式]…

  [WHERE謂詞];

  修改指定表中滿足謂詞(或條件)的元組,把這些元組按SET子句中的表達式修改相應(yīng)屬性或字段上的值。

 、趧h除(DELETE)

  刪除語句一般格式為:

  DELETE FROM表名

  [WHERE謂詞];

  從指定表中刪除滿足謂詞的那些記錄。沒有WHERE子句時表示刪去此表中的全部記錄,但此表的定義仍在數(shù)據(jù)字典中,只是一個空表。DELETE只對表外延操作,不對內(nèi)涵操作。

 、鄄迦(INSERT)插入語句的一般格式為:

  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子查詢

  [WITH 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í)行成功,否則返回一個錯誤代碼(負值)或警告信息(正值)。程序員應(yīng)該在每個SQL語句之后測試SQL CODE的值,以便處理各種情況。

  (3)一個SQL語句原則上可產(chǎn)生或處理一組記錄,而主語言一次只能處理一個記錄,為此必須協(xié)調(diào)兩種處理方式。這是用游標(biāo)(Cursor)來解決的。下面首先討論不需要游標(biāo)的DML語句,然后討論使用游標(biāo)的DML語句。

  9.不用游標(biāo)的DML語句

  不需要游標(biāo)的DML語句有:查詢結(jié)果為單記錄的SELECT語句UPDATE(除了CURRENT形式的UPDATE)語句DELETE(除了CURRENT形式的DELETE)語句INSERT語句

  (1)查詢結(jié)果為單記錄的SELECT語句這類語句的一般格式是:(主語言為PL/1)EXEC SQL SELECT目標(biāo)列INTO主變量[空值標(biāo)志]FROM基本表(或視圖)[WHERE條件表達式];SELECT語句從數(shù)據(jù)庫中找到符合條件的記錄,把結(jié)果放到主變量中。

  (2)UPDATE語句

  (3)DELETE語句

  (4)INSERT語句

  10.使用游標(biāo)的DML語句

  一般情況下SELECT語句的查詢結(jié)果是記錄的集合而不是單個記錄,為此需要用游標(biāo)機制作為橋梁,把集合操作轉(zhuǎn)換為單記錄處理。與游標(biāo)有關(guān)的語句有四個:

  (1)定義游標(biāo)。游標(biāo)是與某一查詢結(jié)果相聯(lián)系的符號名。用DECLARE語句定義。這是一個說明語句。與游標(biāo)相對應(yīng)的SELECT語句這時并不執(zhí)行。

  (2)打開(OPEN)游標(biāo)。打開游標(biāo)語句使游標(biāo)處于活動狀態(tài)。與游標(biāo)相應(yīng)的查詢語句被執(zhí)行。游標(biāo)指向查詢結(jié)果集中的第一個記錄之前。

  (3)推進(FETCH)游標(biāo)。把游標(biāo)向前推進一個記錄,并把游標(biāo)指向的當(dāng)前記錄中的字段值取出,放到INTO子句后相應(yīng)的主變量中。FETCH語句常常用于循環(huán),以借助主語言功能逐一處理結(jié)果集中的數(shù)據(jù)。

  (4)關(guān)閉(CLOSE)游標(biāo)。關(guān)閉游標(biāo),使它不再和原來的查詢結(jié)果相聯(lián)系。關(guān)閉了的游標(biāo)可以再次被打開,與新的查詢結(jié)果集相聯(lián)系。使用CURRENT形式的UPDATE和刪除語句應(yīng)注意:

  (1)若游標(biāo)定義中的SELECT語句帶有UNION或ORDER BY子句,或者這個SELECT語句相當(dāng)于定義了一個不可更新的視圖,則不能用這兩個更新語句。

  (2)若使用CURRENT形式的UPDATE語句,則游標(biāo)定義中要包括FOR UPDATE子句,指出更新的字段(SET子句中使用的字段)。因此,游標(biāo)定義語句的一般格式為:EXEC SQL DECLARE游標(biāo)名CURSOR FOR子查詢UNION子查詢…[FOR UPDATE OF字段名[,字段名]…|ORDER-BY-子句];

  11.SQL的事務(wù)處理功能

  (1)事務(wù)處理的概述所謂事務(wù)(Transaction)是指一系列動作的組合,這些動作被當(dāng)作一個整體來處理。這些動作或者相繼都被執(zhí)行,或者什么也不做。在數(shù)據(jù)庫中,一個動作是指一個SQL語句。事務(wù)是一組SQL語句組成的一個邏輯單位。要么這些SQL語句全部被按順序正確執(zhí)行,要么在某SQL語句執(zhí)行失敗時,按照用戶要求,取消已執(zhí)行的SQL語句對數(shù)據(jù)庫中數(shù)據(jù)的修改;蛘咭词聞(wù)中SQL語句都被正確執(zhí)行,完成該事務(wù)對數(shù)據(jù)庫中數(shù)據(jù)的所有操作;或者要么相當(dāng)于一條SQL語句也未執(zhí)行,數(shù)據(jù)庫數(shù)據(jù)未做任何改動。

  (2)SQL語言的事務(wù)處理語句SQL語言有3條語句用于事務(wù)處理,它們是:

  (1)Commit語句,對于正確執(zhí)行了的事務(wù)進行提交,進行提交即對數(shù)據(jù)庫中數(shù)據(jù)的修改永久化。同時還釋放事務(wù)和封鎖,標(biāo)志該事務(wù)結(jié)束。

  (2)Save point語句,定義事務(wù)中的一個回滾保留點,它是事務(wù)恢復(fù)時的一個標(biāo)記點。

  (3)rollback語句,無論事務(wù)執(zhí)行的當(dāng)前位置在哪里,該語句的執(zhí)行要么取消事務(wù)執(zhí)行以來對數(shù)據(jù)庫的全部修改,要么取消至某個指定回滾點后對數(shù)據(jù)庫的全部修改。釋放自保留點之后的全部表或行的封鎖(沒有保留點,相當(dāng)于回滾到事務(wù)開始處,終止該事務(wù))。事務(wù)的恢復(fù)(回滾)是根據(jù)事務(wù)執(zhí)行前保存下的當(dāng)時數(shù)據(jù)庫狀態(tài)來實現(xiàn)的。一遇到rollback語句,就將數(shù)據(jù)庫中數(shù)據(jù)恢復(fù)到原來的狀態(tài),相當(dāng)于撤消事務(wù)中已執(zhí)行了的SQL語句。

  12、數(shù)據(jù)庫的存儲結(jié)構(gòu)

  數(shù)據(jù)庫的存儲結(jié)構(gòu)不同于一般文件系統(tǒng)的存儲結(jié)構(gòu)。數(shù)據(jù)庫數(shù)據(jù)的特點是各種記錄型之間彼此有聯(lián)系,數(shù)據(jù)是結(jié)構(gòu)化的。數(shù)據(jù)的存儲結(jié)構(gòu)不僅涉及每種記錄型的記錄如何存儲,而且要使數(shù)據(jù)的存儲反映各種記錄型之間的聯(lián)系。在DB多級模式中引入內(nèi)模式(存儲模式)的主要目的是使模式的數(shù)據(jù)結(jié)構(gòu)的描述同它的存儲表示的描述分開,以致DBA為了協(xié)調(diào)數(shù)據(jù)庫性能而對數(shù)據(jù)庫數(shù)據(jù)的存儲方法進行修改時,可不必修改模式,以提高數(shù)據(jù)庫的物理獨立性。在各個數(shù)據(jù)庫管理系統(tǒng)中,對內(nèi)模式的定義功能各不相同。在關(guān)系數(shù)據(jù)庫管理系統(tǒng)中有些DDL語句可影響數(shù)據(jù)庫的存儲結(jié)構(gòu)。在DBMS中各級模式的存儲結(jié)構(gòu)是恒定的或唯一的,而數(shù)據(jù)庫內(nèi)容(或其記錄)的存儲方式是不唯一的。數(shù)據(jù)庫存儲結(jié)構(gòu)設(shè)計的好壞直接影響系統(tǒng)的性能。在存儲結(jié)構(gòu)中主要是涉及存儲記錄的設(shè)計。存儲記錄與概念記錄之間具有對應(yīng)關(guān)系,如果存儲記錄與概念記錄之間具有一一對應(yīng)關(guān)系,在這種情況下存儲記錄的設(shè)計就比較簡單,不需要進一步討論。概念記錄是指在邏輯結(jié)構(gòu)中的記錄。但當(dāng)一個概念記錄對應(yīng)多個不同類型的存儲記錄時,存在如何設(shè)計存儲記錄的問題。對于這樣的概念記錄,其存儲記錄可以有以下幾種設(shè)計:

  1.順序組織

  將存儲記錄設(shè)計成與概念記錄一一對應(yīng),按SNO大小(或按記錄到來)的順序?qū)⒂涗浗M成一個順序組織的文件。這樣組織的優(yōu)點是結(jié)構(gòu)簡單,缺點是會浪費存儲空間。

  2.順序帶鏈的組織

  順序帶鏈組織允許記錄中帶有指針(Pointer),這樣可以大大節(jié)省存儲空間。

  3.帶次關(guān)鍵字索引的順序組織

  為了適應(yīng)對多項內(nèi)容的檢索,可以建立索引文件,上述組織可改為帶次關(guān)鍵字索引的順序組織。

  4.多表組織

  在次關(guān)鍵字索引中,由于一個次關(guān)鍵字值對應(yīng)于多個記錄值,它們的個數(shù)是不固定的,所以對應(yīng)的指針數(shù)目是可變的。這種可變性給管理帶來困難,為了解決這個困難,引入了多表組織。多表組織的實現(xiàn)思想比較簡單,在索引中多個指針分散存放在每個記錄值中,索引項中的指針指向第一個記錄,在第一個記錄中的指針指向第二個記錄等等。

  5.完全倒排組織在一個記錄型中,對主關(guān)鍵字以外的數(shù)據(jù)項都建立索引,這樣的組織稱之為完全倒排組織。

  6.Hash定址組織對于每一個存儲記錄值存放在數(shù)據(jù)庫的什么地方,可通過對該記錄的主關(guān)鍵字值的雜湊函數(shù)計算得出。這種組織為Hash定址組織。雜湊函數(shù)種類很多,如質(zhì)數(shù)除余法、基數(shù)轉(zhuǎn)換法、平方取中法、折疊法、位移法及各位數(shù)字分析法等等。關(guān)鍵是如何選擇一個雜湊函數(shù),盡可能避免發(fā)生碰撞。對于不同的主關(guān)鍵字值通過計算而得到同一個地址的映象,稱之為碰撞。

  7.聯(lián)系的存儲

  在關(guān)系數(shù)據(jù)庫中,通過外來關(guān)鍵字(Foreign Key)來表示概念記錄之間的聯(lián)系。例如,為了表達學(xué)生和學(xué)校的聯(lián)系,可以在學(xué)生記錄中增加外來關(guān)鍵字“學(xué)校號”來表示聯(lián)系。


【計算機四級考試數(shù)據(jù)庫工程師考點:SQL】相關(guān)文章:

計算機四級考試數(shù)據(jù)庫工程師考點:數(shù)據(jù)模型10-05

計算機四級數(shù)據(jù)庫工程師考點筆記10-15

全國計算機四級數(shù)據(jù)庫考試重點考點08-18

計算機四級《數(shù)據(jù)庫工程師》考試內(nèi)容05-07

計算機四級《數(shù)據(jù)庫工程師》第五章考點匯總07-15

計算機四級《數(shù)據(jù)庫工程師》第三章復(fù)習(xí)考點07-15

計算機四級考試網(wǎng)絡(luò)工程師考點:Internet09-03

計算機四級數(shù)據(jù)庫數(shù)據(jù)模型考點11-11

計算機四級《數(shù)據(jù)庫技術(shù)》考點:數(shù)據(jù)庫應(yīng)用系統(tǒng)生命周期10-01