數(shù)據(jù)庫(kù)系統(tǒng)概論第五章數(shù)據(jù)庫(kù)的完整性

數(shù)據(jù)庫(kù)系統(tǒng)概論第五章數(shù)據(jù)庫(kù)的完整性

ID:39712134

大小:295.50 KB

頁(yè)數(shù):60頁(yè)

時(shí)間:2019-07-09

數(shù)據(jù)庫(kù)系統(tǒng)概論第五章數(shù)據(jù)庫(kù)的完整性_第1頁(yè)
數(shù)據(jù)庫(kù)系統(tǒng)概論第五章數(shù)據(jù)庫(kù)的完整性_第2頁(yè)
數(shù)據(jù)庫(kù)系統(tǒng)概論第五章數(shù)據(jù)庫(kù)的完整性_第3頁(yè)
數(shù)據(jù)庫(kù)系統(tǒng)概論第五章數(shù)據(jù)庫(kù)的完整性_第4頁(yè)
數(shù)據(jù)庫(kù)系統(tǒng)概論第五章數(shù)據(jù)庫(kù)的完整性_第5頁(yè)
資源描述:

《數(shù)據(jù)庫(kù)系統(tǒng)概論第五章數(shù)據(jù)庫(kù)的完整性》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在教育資源-天天文庫(kù)。

1、數(shù)據(jù)庫(kù)系統(tǒng)概論AnIntroductiontoDatabaseSystem第五章數(shù)據(jù)庫(kù)完整性10/4/20211AnIntroductiontoDatabaseSystem數(shù)據(jù)庫(kù)完整性數(shù)據(jù)庫(kù)的完整性數(shù)據(jù)的正確性和相容性數(shù)據(jù)的完整性和安全性是兩個(gè)不同概念數(shù)據(jù)的完整性防止數(shù)據(jù)庫(kù)中存在不符合語(yǔ)義的數(shù)據(jù),也就是防止數(shù)據(jù)庫(kù)中存在不正確的數(shù)據(jù)防范對(duì)象:不合語(yǔ)義的、不正確的數(shù)據(jù)數(shù)據(jù)的安全性保護(hù)數(shù)據(jù)庫(kù)防止惡意的破壞和非法的存取防范對(duì)象:非法用戶和非法操作10/4/20212AnIntroductiontoDatabaseSystem數(shù)據(jù)庫(kù)完整性(續(xù))為維護(hù)數(shù)據(jù)庫(kù)的完整性,DBMS必須:提供定義

2、完整性約束條件的機(jī)制提供完整性檢查的方法違約處理10/4/20213AnIntroductiontoDatabaseSystem第五章數(shù)據(jù)庫(kù)完整性5.1實(shí)體完整性5.2參照完整性5.3用戶定義的完整性5.4完整性約束命名子句*5.5域中的完整性限制5.6觸發(fā)器5.7小結(jié)10/4/20214AnIntroductiontoDatabaseSystem5.1實(shí)體完整性5.1.1實(shí)體完整性定義5.1.2實(shí)體完整性檢查和違約處理10/4/20215AnIntroductiontoDatabaseSystem5.1.1實(shí)體完整性定義關(guān)系模型的實(shí)體完整性CREATETABLE中用PRIMA

3、RYKEY定義單屬性構(gòu)成的碼有兩種說明方法定義為列級(jí)約束條件定義為表級(jí)約束條件對(duì)多個(gè)屬性構(gòu)成的碼只有一種說明方法定義為表級(jí)約束條件10/4/20216AnIntroductiontoDatabaseSystem實(shí)體完整性定義(續(xù))(1)在列級(jí)定義主碼CREATETABLEStudent(SnoCHAR(9)PRIMARYKEY,SnameCHAR(20)NOTNULL,SsexCHAR(2),SageSMALLINT,SdeptCHAR(20));[例1]將Student表中的Sno屬性定義為碼10/4/20217AnIntroductiontoDatabaseSystem實(shí)體

4、完整性定義(續(xù))(2)在表級(jí)定義主碼CREATETABLEStudent(SnoCHAR(9),SnameCHAR(20)NOTNULL,SsexCHAR(2),SageSMALLINT,SdeptCHAR(20),PRIMARYKEY(Sno));10/4/20218AnIntroductiontoDatabaseSystem實(shí)體完整性定義(續(xù))CREATETABLESC(SnoCHAR(9)NOTNULL,CnoCHAR(4)NOTNULL,GradeSMALLINT,PRIMARYKEY(Sno,Cno)/*只能在表級(jí)定義主碼*/);[例2]將SC表中的Sno,Cno屬性

5、組定義為碼10/4/20219AnIntroductiontoDatabaseSystem5.1實(shí)體完整性5.1.1實(shí)體完整性定義5.1.2實(shí)體完整性檢查和違約處理10/4/202110AnIntroductiontoDatabaseSystem5.1.2實(shí)體完整性檢查和違約處理插入或?qū)χ鞔a列進(jìn)行更新操作時(shí),RDBMS按照實(shí)體完整性規(guī)則自動(dòng)進(jìn)行檢查。包括:檢查主碼值是否唯一,如果不唯一則拒絕插入或修改檢查主碼的各個(gè)屬性是否為空,只要有一個(gè)為空就拒絕插入或修改10/4/202111AnIntroductiontoDatabaseSystem實(shí)體完整性檢查和違約處理(續(xù))檢查記錄中

6、主碼值是否唯一的一種方法是進(jìn)行全表掃描10/4/202112AnIntroductiontoDatabaseSystem實(shí)體完整性檢查和違約處理(續(xù))另一個(gè)是索引(如B+樹索引)517193122551667179933712152025304151546566686971849376787910/4/202113AnIntroductiontoDatabaseSystem第五章數(shù)據(jù)庫(kù)完整性5.1實(shí)體完整性5.2參照完整性5.3用戶定義的完整性5.4完整性約束命名子句*5.5域中的完整性限制5.6觸發(fā)器5.7小結(jié)10/4/202114AnIntroductiontoDataba

7、seSystem5.2參照完整性5.2.1參照完整性定義5.2.2參照完整性檢查和違約處理10/4/202115AnIntroductiontoDatabaseSystem5.2.1參照完整性定義關(guān)系模型的參照完整性定義在CREATETABLE中用FOREIGNKEY短語(yǔ)定義哪些列為外碼用REFERENCES短語(yǔ)指明這些外碼參照哪些表的主碼10/4/202116AnIntroductiontoDatabaseSystem參照完整性定義(續(xù))[例3]定義SC中的參照完整性CREATETABLE

當(dāng)前文檔最多預(yù)覽五頁(yè),下載文檔查看全文

此文檔下載收益歸作者所有

當(dāng)前文檔最多預(yù)覽五頁(yè),下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學(xué)公式或PPT動(dòng)畫的文件,查看預(yù)覽時(shí)可能會(huì)顯示錯(cuò)亂或異常,文件下載后無此問題,請(qǐng)放心下載。
2. 本文檔由用戶上傳,版權(quán)歸屬用戶,天天文庫(kù)負(fù)責(zé)整理代發(fā)布。如果您對(duì)本文檔版權(quán)有爭(zhēng)議請(qǐng)及時(shí)聯(lián)系客服。
3. 下載前請(qǐng)仔細(xì)閱讀文檔內(nèi)容,確認(rèn)文檔內(nèi)容符合您的需求后進(jìn)行下載,若出現(xiàn)內(nèi)容與標(biāo)題不符可向本站投訴處理。
4. 下載文檔時(shí)可能由于網(wǎng)絡(luò)波動(dòng)等原因無法下載或下載錯(cuò)誤,付費(fèi)完成后未能成功下載的用戶請(qǐng)聯(lián)系客服處理。