2021年全國(guó)計(jì)算機(jī)四級(jí)考試《數(shù)據(jù)庫(kù)》知識(shí)點(diǎn)_第1頁(yè)
2021年全國(guó)計(jì)算機(jī)四級(jí)考試《數(shù)據(jù)庫(kù)》知識(shí)點(diǎn)_第2頁(yè)
2021年全國(guó)計(jì)算機(jī)四級(jí)考試《數(shù)據(jù)庫(kù)》知識(shí)點(diǎn)_第3頁(yè)
2021年全國(guó)計(jì)算機(jī)四級(jí)考試《數(shù)據(jù)庫(kù)》知識(shí)點(diǎn)_第4頁(yè)
2021年全國(guó)計(jì)算機(jī)四級(jí)考試《數(shù)據(jù)庫(kù)》知識(shí)點(diǎn)_第5頁(yè)
已閱讀5頁(yè),還剩4頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、2021 年全國(guó)計(jì)算機(jī)四級(jí)考試數(shù)據(jù)庫(kù)知識(shí)點(diǎn)為大家提供“20_年全國(guó)計(jì)算機(jī)四級(jí)考試數(shù)據(jù)庫(kù)知識(shí)點(diǎn)”供廣大考生參考,更多資訊請(qǐng)關(guān)注我們網(wǎng)站的更新。20_年全國(guó)計(jì)算機(jī)四級(jí)考試數(shù)據(jù)庫(kù)知識(shí)點(diǎn)三、關(guān)系數(shù)據(jù)庫(kù)的標(biāo)準(zhǔn)語(yǔ)言 SQLQL概述SQL!勺英語(yǔ)名稱是2構(gòu)查詢語(yǔ)言(Structured Query Language)實(shí)際上它的功能包括查詢 (Query) 、操縱 (Manipulation) 、定義 (Definition) 和控制 (Control)四個(gè)方面,是一個(gè)綜合的、通用的、功能極強(qiáng)的關(guān)系數(shù)據(jù)庫(kù)語(yǔ)言。SQLJ持?jǐn)?shù)據(jù)庫(kù)的三級(jí)模式結(jié)構(gòu)。QL的數(shù)據(jù)定義功能SQLB數(shù)據(jù)定義功能包括三部分:定義基本表,定義視

2、圖和定義索引。它們是:CREATE TABLE CREATE VIEWCREATE INDE_ DROP TABLE DROP VIEW DROP INDE_SQ據(jù)定義功能可用于定 義和修改模式(如基本表 ) ,定義外模式(如視圖 ) 和內(nèi)模式 (如索引 ) ?;颈淼亩x與刪除定義基本表的語(yǔ)句格式為 :CREATE TABLE名(歹U名 1 類型NOT NULL,列名2類型NOT NULL) 其他參數(shù);其中,任選項(xiàng)“其它參數(shù)”是與物理存儲(chǔ)有關(guān)的參數(shù)。根據(jù)具體系統(tǒng)的不同而不同。刪除基本表的語(yǔ)句為:DROP TABLES名;刪除索引的語(yǔ)句為:DROP INDE索 引名 ; 刪除索引的同時(shí)把有關(guān)索

3、引的描述也從數(shù)據(jù)字典中刪去。但表的內(nèi)涵仍存在且其數(shù)據(jù)外延內(nèi)容不變。把一個(gè)基本表的定義連同表上所有的記錄、索引以及由此基本表導(dǎo)出的所有視圖全部都刪除,并釋放相應(yīng)的存儲(chǔ)空間。索引的建立與刪除對(duì)一個(gè)基本表,可以根據(jù)應(yīng)用環(huán)境的需要建立若干索引,以提供多種存取方式。通常,索引的建立和刪除由 DBAE表的主人(即建立表的人)負(fù)責(zé)。用戶不必也 不能在存取數(shù)據(jù)時(shí)選擇索引。存取路徑的選擇由系統(tǒng)自動(dòng)進(jìn)行。索引的描述存放在數(shù)據(jù)字典中。建立索引的語(yǔ)句格式為 :CREATEUNIQUE IND時(shí)引名ON基本表名(列名次序,列名次序)其他參數(shù);這里的任選項(xiàng)其他參數(shù)是與物理存儲(chǔ)有關(guān)的參數(shù)。索引可以建在一列或幾列上。圓括號(hào)內(nèi)

4、是索引列的順序說(shuō)明表。其中的任選項(xiàng)次序,指定了索引值排序的次序??扇?ASC葉序)或DESC降序)。缺省值為升序。UNIQUES示每一索引信只對(duì)應(yīng)唯一的數(shù)據(jù)記錄。5.SQL的數(shù)據(jù)操縱功能SQU勺數(shù)據(jù)操縱功能包括 SELECT INSERT DELET醫(yī)口 UPDATEI個(gè)語(yǔ)句,即檢索和更新( 包括增、刪、改 ) 兩部分工能。檢索就是查詢。SQLM新語(yǔ)句SQL的更新語(yǔ)句包括修改,刪除和插入三類語(yǔ)句。修改(UPDATE)亦稱為更新)修改語(yǔ)句的一般格式為 :UPDATEDSET字段=表達(dá)式,字段=表達(dá)式WHEREI 詞;修改指定表中滿足謂詞(或條件)的元組,把這些元組按SET子句中的表達(dá)式 修改相應(yīng)

5、屬性或字段上的值。刪除 (DELETE)刪除語(yǔ)句一般格式為 :DELETE FROM 名WHEREI 詞;從指定表中刪除滿足謂詞的那些記錄。沒有 WHERE何時(shí)表示刪去此表中的 全部記錄,但此表的定義仍在數(shù)據(jù)字典中,只是一個(gè)空表。DELETER對(duì)表外延操作,不對(duì)內(nèi)涵操作。插入(INSERT)插入語(yǔ)句的一般格式為:INSERT INTOft名(字段名,字段名 )valueS(常量,常量);或INSERTINTO表名(字段名,字段名)子查詢 ;第一種格式把一個(gè)新記錄插入指定的表中。第二種格式把子查詢的結(jié)果插入表中。若表中有些字段在插入語(yǔ)句中沒有出現(xiàn),則這些字段上的值取空值NULL。當(dāng)然在表定義中說(shuō)

6、明了 NOT NULL勺字段在插入時(shí)不能取NULL若插入語(yǔ)句中沒有 指出字段名,則新記錄必須在每個(gè)字段上均有值。視圖視圖是從一個(gè)或幾個(gè)基本表( 或視圖 ) 導(dǎo)出的表。某一用戶可以定義若干視圖。因此對(duì)某一用戶而言,按 ANSI/SPARC艮告的觀點(diǎn),他的外模式是由若干基本 表和若干視圖組成的。視圖和基本表不同,視圖是一個(gè)虛表,即視圖所對(duì)應(yīng)的數(shù)據(jù)不實(shí)際存儲(chǔ)在數(shù)據(jù)庫(kù)中,數(shù)據(jù)庫(kù)中只存儲(chǔ)視圖的定義( 存在數(shù)據(jù)字典中 ) 。視圖一經(jīng)定義就可以和基本表一樣被查詢、被刪除(DROP)也可以用來(lái)定義新的視圖,但更 新(增、刪、改) 操作將有一定限制。視圖可以理解成一個(gè)數(shù)據(jù)庫(kù),只有內(nèi)涵保存在數(shù)據(jù)庫(kù)字典中,而無(wú)外延

7、存儲(chǔ); 其外延是在使用時(shí)動(dòng)態(tài)地生成的或計(jì)算出來(lái)的。視圖的定義與刪除SQLM立視圖的語(yǔ)句格式為:CREATE VIEW1圖名(字段名,字段名 )AS子查詢WITH CHECK OPTIO慵詞;視圖可以刪除,語(yǔ)句格式為 :DROP VIEVWL圖名;視圖的定義就從數(shù)據(jù)字典中刪除。由此視圖導(dǎo)出的其它視圖也將自動(dòng)被刪除。若導(dǎo)出此視圖的基本表刪除了,則此視圖也將自動(dòng)刪除。視圖的查詢語(yǔ)句視圖定義后,用戶可以如同基本表那樣對(duì)視圖查詢。視圖的更新語(yǔ)句對(duì)視圖的更新最終要轉(zhuǎn)換成對(duì)基本表的更新(這里的更新,指INSERT UPDATE口 DELETED類操作)。在關(guān)系數(shù)據(jù)庫(kù)中,并非所有的視圖 都是可更新的,也就是說(shuō)

8、,有些視圖的更新不能唯一地有意義地轉(zhuǎn)換成對(duì)基本表的更新。 TOC o 1-5 h z 視圖的優(yōu)點(diǎn)視圖的概念具有很多優(yōu)點(diǎn),主要有:視圖對(duì)于數(shù)據(jù)庫(kù)的重構(gòu)造提供了一定程度的邏輯獨(dú)立性;簡(jiǎn)化了用戶觀點(diǎn) ;視圖機(jī)制使不同的用戶能以不同的方式看待同一數(shù)據(jù);視圖機(jī)制對(duì)機(jī)密數(shù)據(jù)提供了自動(dòng)的安全保護(hù)功能。QL的數(shù)據(jù)控制功能SQ做據(jù)控制功能是指控制用戶對(duì)數(shù)據(jù)的存取權(quán)力。某個(gè)用戶對(duì)某類數(shù)據(jù)具 有何種操作權(quán)力是由DBA決定的。這是個(gè)政策問(wèn)題而不是技術(shù)問(wèn)題。數(shù)據(jù)庫(kù)管理系 統(tǒng)的功能是保證這些決定的執(zhí)行。為此它必須能:(1)把授權(quán)的決定告知系統(tǒng),這是由 SQL的GRANTS REVOKE1旬來(lái)完成的c把授權(quán)的結(jié)果存入數(shù)據(jù)字

9、典。當(dāng)用戶提出操作請(qǐng)求時(shí),根據(jù)授權(quán)情況進(jìn)行檢查,以決定是執(zhí)行操作請(qǐng)求還是拒絕之。授權(quán)語(yǔ)句的一般格式為 :GRAN權(quán)力,權(quán)力ON對(duì)象類型對(duì)象名TO用戶,用戶,WITH GRANT OPTION;對(duì)不同類型的操作對(duì)象可有不同的操作權(quán)力。對(duì)基本表、視圖及其字段的操作權(quán)力有查詢、插入、更新、刪除以及它們的總和 ALL PRIVILEGE。(2)對(duì)基本表的操作權(quán)力還有修改(ALTER劉建立索引(INDE_)0(3)對(duì)數(shù)據(jù)庫(kù)的操作權(quán)力有建立表(CREATETAB)某用戶有了此權(quán)力就可以使 用 Create table 建立基本表。稱他為表的主人,擁有對(duì)此表的一切操作權(quán)力。(4)對(duì)表空間的權(quán)力有使用(USE

10、)數(shù)據(jù)庫(kù)空間存儲(chǔ)基本表的權(quán)力。(5)系統(tǒng)權(quán)力有建立新數(shù)據(jù)庫(kù)(CREATEDBA)權(quán)力。GRAN語(yǔ)句中的任選項(xiàng) WITH GRANT OPTION作用是使獲得某種權(quán)力的用戶可以把權(quán)力再授予別的用戶。8. 嵌入式 SQL把SQL嵌入主語(yǔ)言使用時(shí)必須解決三個(gè)問(wèn)題:(1)區(qū)分SQL語(yǔ)句與主語(yǔ)言語(yǔ)句。這是通過(guò)在所有的 SQL語(yǔ)句前加前綴E_EC SQL#解決的。SQL語(yǔ)句結(jié)束標(biāo)志隨主語(yǔ)言不同而不同,如 PL/1用分號(hào)(;),COBOL 用EMD-E_ECE表示。SQL句首先由預(yù)編譯程序加以處理,轉(zhuǎn)換為主語(yǔ)言編譯程 序能夠識(shí)別的形式,然后交主語(yǔ)言編譯程序進(jìn)一步處理。(2)數(shù)據(jù)庫(kù)工作單元和程序工作單元之間的

11、通信。SQL句中可以使用主語(yǔ)言 的程序變量( 簡(jiǎn)稱主變量) ,這些變量名前加冒號(hào)(:) 作標(biāo)志,以區(qū)別地字段名,程序中使用的任何表(基本表或視圖)都要用E_EC SQL DECLARE旬加以說(shuō)明。一則 使程序更加清晰,二則使預(yù)編譯程序能作某些語(yǔ)法檢查。SQL旬執(zhí)行后,系統(tǒng)要反饋給應(yīng)用程序若干信息,這些信息送到 SQL的通彳9區(qū)SQL CA SQL CAffl語(yǔ)句 E_EC SQL INCLUDE以定義。在 SQL CA中有一個(gè)狀態(tài)指示字段 SQL CODE當(dāng)SQL COD的零時(shí),表示SQL語(yǔ)句執(zhí)行成功,否則返回一個(gè)錯(cuò)誤代碼(負(fù)值)或警告信息 (正值)。程序員應(yīng)該在每個(gè)SQL語(yǔ)句之后測(cè)試SQL

12、COD的值,以便處理各種情 況。一個(gè)SQL語(yǔ)句原則上可產(chǎn)生或處理一組記錄,而主語(yǔ)言一次只能處理一個(gè) 記錄,為此必須協(xié)調(diào)兩種處理方式。這是用游標(biāo)(Cursor) 來(lái)解決的。下面首先討論不需要游標(biāo)的DML句,然后討論使用游標(biāo)的 DM印句。.不用游標(biāo)的DM印句不需要游標(biāo)的DM印句有:查詢結(jié)果為單記錄的SELECTS旬UPDAT隧了 CURRENT式的 UPDAT幫旬 DELETE除了 CURRENT式的 DELETE旬 INSERT語(yǔ) 句(1)查詢結(jié)果為單記錄的SELECTS旬這類語(yǔ)句白一般格式是:(主語(yǔ)言為 PL/1)E_EC SQL SELECTS標(biāo)歹U INTO主變量空值標(biāo)志FROMtt本表(

13、或視圖)WHERE 條件表達(dá)式;SELECT語(yǔ)句從數(shù)據(jù)庫(kù)中找到符合條件的記錄,把結(jié)果放到主變量 中。(2)UPDATE 句(3)DELETE 語(yǔ)句(4)INSERT 語(yǔ)句.使用游標(biāo)的DML句一般情況下SELECTS句的查詢結(jié)果是記錄的集合而不是單個(gè)記錄,為此需要 用游標(biāo)機(jī)制作為橋梁,把集合操作轉(zhuǎn)換為單記錄處理。與游標(biāo)有關(guān)的語(yǔ)句有四個(gè):(1)定義游標(biāo)。游標(biāo)是與某一查詢結(jié)果相聯(lián)系的符號(hào)名。用DECLARE旬定義。這是一個(gè)說(shuō)明語(yǔ)句。與游標(biāo)相對(duì)應(yīng)的 SELECTS旬這時(shí)并不執(zhí)行。(2)打開(OPEN游標(biāo)。打開游標(biāo)語(yǔ)句使游標(biāo)處于活動(dòng)狀態(tài)。與游標(biāo)相應(yīng)的查詢 語(yǔ)句被執(zhí)行。游標(biāo)指向查詢結(jié)果集中的第一個(gè)記錄之前

14、。(3)推進(jìn)(FETCH)B標(biāo)。把游標(biāo)向前推進(jìn)一個(gè)記錄,并把游標(biāo)指向的當(dāng)前記錄 中的字段值取出,放到INTO子句后相應(yīng)的主變量中。FETCH句常常用于循環(huán), 以借助主語(yǔ)言功能逐一處理結(jié)果集中的數(shù)據(jù)。(4)關(guān)閉(CLOSE游標(biāo)。關(guān)閉游標(biāo),使它不再和原來(lái)的查詢結(jié)果相聯(lián)系。關(guān)閉 了的游標(biāo)可以再次被打開,與新的查詢結(jié)果集相聯(lián)系。使用CURRENT式的UPDATE口刪除語(yǔ)句應(yīng)注意:(1)若游標(biāo)定義中的SELECTS旬帶有UNIONS ORDER BY句,或者這個(gè) SELECTS旬相當(dāng)于定義了一個(gè)不可更新的視圖,則不能用這兩個(gè)更新語(yǔ)句。(2)若使用CURRENT式的UPDAT踣句,則游標(biāo)定義中要包括 FO

15、R UPDATE 旬,指出更新的字段(SET子句中使用的字段)。因此,游標(biāo)定義語(yǔ)句的一般格式 為:E_EC SQL DECLARE標(biāo)名 CURSOR FOR查詢 UNION?查詢FOR UPDATE OF 字段名,字段名|ORDERBY-子句;11.SQL 的事務(wù)處理功能(1) 事務(wù)處理的概述所謂事務(wù)(Transaction) 是指一系列動(dòng)作的組合,這些動(dòng)作被當(dāng)作一個(gè)整體來(lái)處理。這些動(dòng)作或者相繼都被執(zhí)行,或者什么也不做。在數(shù)據(jù)庫(kù)中,一個(gè)動(dòng)作是指一個(gè)SQL語(yǔ)句。事務(wù)是一組SQL語(yǔ)句組成的一個(gè)邏輯單位。要 么這些SQL語(yǔ)句全部被按順序正確執(zhí)行,要么在某SQL語(yǔ)句執(zhí)行失敗時(shí),按照用戶要求,取消已執(zhí)行

16、的SQL語(yǔ)句對(duì)數(shù)據(jù)庫(kù)中數(shù)據(jù)的修改?;蛘咭词聞?wù)中SQL語(yǔ)句都被正確執(zhí)行,完成該事務(wù)對(duì)數(shù)據(jù)庫(kù)中數(shù)據(jù)的所有操作;或者要么相當(dāng)于一條SQL語(yǔ)句也未執(zhí)行,數(shù)據(jù)庫(kù)數(shù)據(jù)未做任何改動(dòng)。(2)SQL語(yǔ)言的事務(wù)處理語(yǔ)句SQL言有3條語(yǔ)句用于事務(wù)處理,它們是: (1)Commit 語(yǔ)句,對(duì)于正確執(zhí)行了的事務(wù)進(jìn)行提交,進(jìn)行提交即對(duì)數(shù)據(jù)庫(kù)中數(shù)據(jù)的修改永久化。同時(shí)還釋放事務(wù)和封鎖,標(biāo)志該事務(wù)結(jié)束。(2)Save point 語(yǔ)句,定義事務(wù)中的一個(gè)回滾保留點(diǎn),它是事務(wù)恢復(fù)時(shí)的一 個(gè)標(biāo)記點(diǎn)。(3)rollback 語(yǔ)句,無(wú)論事務(wù)執(zhí)行的當(dāng)前位置在哪里,該語(yǔ)句的執(zhí)行要么取消事務(wù)執(zhí)行以來(lái)對(duì)數(shù)據(jù)庫(kù)的全部修改,要么取消至某個(gè)指定回滾

17、點(diǎn)后對(duì)數(shù)據(jù)庫(kù)的全部修改。釋放自保留點(diǎn)之后的全部表或行的封鎖 ( 沒有保留點(diǎn),相當(dāng)于回滾到事務(wù)開始處,終止該事務(wù)) 。事務(wù)的恢復(fù)(回滾 ) 是根據(jù)事務(wù)執(zhí)行前保存下的當(dāng)時(shí)數(shù)據(jù)庫(kù)狀態(tài)來(lái)實(shí)現(xiàn)的。一遇到 rollback 語(yǔ)句,就將數(shù)據(jù)庫(kù)中數(shù)據(jù)恢復(fù)到原來(lái)的狀態(tài),相當(dāng)于撤消事務(wù)中已執(zhí)行了的SQL語(yǔ)句。四、數(shù)據(jù)庫(kù)的存儲(chǔ)結(jié)構(gòu)數(shù)據(jù)庫(kù)的存儲(chǔ)結(jié)構(gòu)不同于一般文件系統(tǒng)的存儲(chǔ)結(jié)構(gòu)。數(shù)據(jù)庫(kù)數(shù)據(jù)的特點(diǎn)是各種記錄型之間彼此有聯(lián)系,數(shù)據(jù)是結(jié)構(gòu)化的。數(shù)據(jù)的存儲(chǔ)結(jié)構(gòu)不僅涉及每種記錄型的記錄如何存儲(chǔ),而且要使數(shù)據(jù)的存儲(chǔ)反映各種記錄型之間的聯(lián)系。在DB多級(jí)模式中引入內(nèi)模式(存儲(chǔ)模式 ) 的主要目的是使模式的數(shù)據(jù)結(jié)構(gòu)的描述同它的存儲(chǔ)表示的

18、描述分開,以致DBA了協(xié)調(diào)數(shù)據(jù)庫(kù)性能而對(duì)數(shù)據(jù)庫(kù)數(shù)據(jù)的存儲(chǔ)方法進(jìn)行修改時(shí),可不必修改模式,以提高數(shù)據(jù)庫(kù)的物理獨(dú)立性。在各個(gè)數(shù)據(jù)庫(kù)管理系統(tǒng)中,對(duì)內(nèi)模式的定義功能各不相同。在關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng)中有些DDL語(yǔ)句可影響數(shù)據(jù)庫(kù)的存儲(chǔ)結(jié)構(gòu)。在DBM外各級(jí)模式的存儲(chǔ)結(jié)構(gòu)是恒定白或唯一的,而數(shù)據(jù)庫(kù)內(nèi)容 (或 其記錄 ) 的存儲(chǔ)方式是不唯一的。數(shù)據(jù)庫(kù)存儲(chǔ)結(jié)構(gòu)設(shè)計(jì)的好壞直接影響系統(tǒng)的性能。在存儲(chǔ)結(jié)構(gòu)中主要是涉及存儲(chǔ)記錄的設(shè)計(jì)。存儲(chǔ)記錄與概念記錄之間具有對(duì)應(yīng)關(guān)系,如果存儲(chǔ)記錄與概念記錄之間具有一一對(duì)應(yīng)關(guān)系,在這種情況下存儲(chǔ)記錄的設(shè)計(jì)就比較簡(jiǎn)單,不需要進(jìn)一步討論。概念記錄是指在邏輯結(jié)構(gòu)中的記錄。但當(dāng)一個(gè)概念記錄對(duì)應(yīng)多個(gè)不同類型的存儲(chǔ)記錄時(shí),存在如何設(shè)計(jì)存儲(chǔ)記錄的問(wèn)題。對(duì)于這樣的概念記錄,其存儲(chǔ)記錄可以有以下幾種設(shè)計(jì):順序組織將存儲(chǔ)記錄設(shè)計(jì)成與概念記錄一一對(duì)應(yīng),按SNO*:小(或按記錄到

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論