《編程設(shè)計及數(shù)據(jù)庫基礎(chǔ)》課件-數(shù)據(jù)庫完整性_第1頁
《編程設(shè)計及數(shù)據(jù)庫基礎(chǔ)》課件-數(shù)據(jù)庫完整性_第2頁
《編程設(shè)計及數(shù)據(jù)庫基礎(chǔ)》課件-數(shù)據(jù)庫完整性_第3頁
《編程設(shè)計及數(shù)據(jù)庫基礎(chǔ)》課件-數(shù)據(jù)庫完整性_第4頁
《編程設(shè)計及數(shù)據(jù)庫基礎(chǔ)》課件-數(shù)據(jù)庫完整性_第5頁
已閱讀5頁,還剩6頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

編程設(shè)計及數(shù)據(jù)庫基礎(chǔ)數(shù)據(jù)庫完整性

本節(jié)主要內(nèi)容:1.了解數(shù)據(jù)庫完整性2.掌握約束的創(chuàng)建數(shù)據(jù)完整性數(shù)據(jù)庫完整性是指數(shù)據(jù)庫中數(shù)據(jù)在邏輯上的一致性、正確性、有效性和相容性。它能防止合法用戶向數(shù)據(jù)庫添加錯誤數(shù)據(jù),提高系統(tǒng)的可用性。重復(fù)記錄1900/2/120:00:00錯誤數(shù)據(jù)數(shù)據(jù)庫完整性有三類:實體完整性:保證實體的唯一性,確保每張表都有一個唯一的標(biāo)識符。域完整性:確保字段值符合預(yù)定義的類型、格式和取值范圍。參照完整性:也稱為引用完整性,確保在表之間建立的關(guān)系是合理且一致的。學(xué)生信息表學(xué)院信息表

MySQL利用約束來實現(xiàn)數(shù)據(jù)完整性,主要有以下幾種約束:字段名稱數(shù)據(jù)類型注釋約束college_idint學(xué)院編號主鍵college_namevarchar(20)學(xué)院名稱不能為空leaderchar(4)院長唯一課堂實例:在學(xué)生管理數(shù)據(jù)庫中創(chuàng)建學(xué)院信息表tb_college,該表包含學(xué)院編號,學(xué)院名稱和院長。createtabletb_college(college_idintcomment'學(xué)院編號'primarykey,college_namevarchar(20)comment'學(xué)院名稱'notnull,leaderchar(10)comment'院長'unique);字段名稱數(shù)據(jù)類型注釋約束stu_idchar(8)學(xué)號主鍵stu_namechar(10)姓名不能為空genderchar(1)性別默認(rèn)為女birthdaydate出生日期collegeint學(xué)院外鍵(參照學(xué)院信息表中的學(xué)院編號)課堂實例:在學(xué)生管理數(shù)據(jù)庫中,創(chuàng)建學(xué)生表tb_student,該表包含了學(xué)號,姓名,性別,出生日期和所在學(xué)院信息,其中學(xué)號是主鍵,姓名不能為空,性別默認(rèn)值為‘女’,所在學(xué)院為外鍵。createtabletb_student(stu_idchar(8)comment'學(xué)號'primarykey,stu_namechar(10)comment'姓名'notnull,genderchar(1)comment'性別'default'女',birthdaydatecomment'出生日期',collegeintcomment'學(xué)院',constraintfk1foreignkey(college)referencestb_college(col_id));字段名稱數(shù)據(jù)類型注釋約束course_idchar(5)課程編號主鍵course_namevarchar(20)課程名不能為空credittinyint學(xué)分在1到10之間pre_coursechar(5)預(yù)選課程teacherchar(4)授課教師課堂實例:在學(xué)生管理數(shù)據(jù)庫中創(chuàng)建課程信息表tb_course,該表包含課程編號,課程名稱,學(xué)分,課時和授課教師,其中課程編號是該表的主鍵,課程名稱不能為空,學(xué)分在1到10之間。createtabletb_course(course_idchar(5)comment'課程編號'primarykey,course_namevarchar(20)comment'課程名'notnull,credit tinyint comment'學(xué)分’check(credit>0&&credit<=10),pre_coursechar(5)comment‘預(yù)選課程',teacher char(10)comment'授課教師');課堂實例:在學(xué)生管理數(shù)據(jù)庫中創(chuàng)建成績表tb_score,用于保存學(xué)生選修課程的成績信息,該表包含了學(xué)號,課程號和成績,該表的主鍵是由學(xué)號和課程號共同構(gòu)成的,成為組合的主鍵。學(xué)號是外鍵,課程號也是外鍵。字段名稱數(shù)據(jù)類型注釋約束stu_idchar(8)學(xué)號外鍵(參照學(xué)生信息表中的學(xué)號)course_idchar(5)課程編號外鍵(參照課程信息表中的課程號)scoreint成績在0到100之間createtabletb_score(stu_id char(9) comment'學(xué)號',course_idchar(5)comment'課程編號',Scoreintcomment'成績',constraintpk_scoreprimarykey(stu_id,course_id),constraintfk_score1foreignkey(stu_id)referencestb_student(stu_id

溫馨提示

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

評論

0/150

提交評論