實驗五 索引和數據完整性_第1頁
實驗五 索引和數據完整性_第2頁
實驗五 索引和數據完整性_第3頁
實驗五 索引和數據完整性_第4頁
實驗五 索引和數據完整性_第5頁
已閱讀5頁,還剩5頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、實驗五 索引和數據完整性1、目的與要求(1)掌握索引的使用方法。(2)掌握數據完整性的實現方法。2、實驗準備(1)了解索引的作用與分類。(2)掌握索引的創(chuàng)建方法。(3)理解數據完整性的概念及分類。(4)掌握各種數據完整性的實現方法。3、實驗內容(1)建立索引。 使用CREATE INDEX語句創(chuàng)建索引。 A、對YGGL數據庫的Employees表中的DepartmentID列建立索引。 在“查詢分析器”窗口中輸入如下程序并執(zhí)行。 B、在Employees表的Name列和Address列上建立復合索引。 C、對Department表上的DepartmentName列建立唯一非聚集索引。 【思考與

2、練習】 A、索引創(chuàng)建后在對象資源管理器中查看表的索引。上面分別創(chuàng)建了Employees表和Department表的索引,在對象資源管理器中的表中將相應的表打開,在“索引”中顯示該表中建立的索引。詳細結果如上面截圖中顯示。B、了解索引的分類情況。按索引的組織方式能夠將索引分為聚集索引和非聚集索引兩種類型。聚集索引將數據行的鍵值在表內排序并存儲對應的數據記錄,使得數據表物理順序與索引順序一致。非聚集索引完全獨立于數據行的結構。C、使用CREATE INDEX語句能夠創(chuàng)建主鍵嗎?D、在什么情況下能夠看到建立索引的好處? 數據庫索引是為了增加查詢速度而對表字段附加的一種標識。數據庫的索引并不是只有好處

3、或者只有壞處的。當我們的數據庫足夠大,恰當的建立索引就會大大的提高查詢搜索的速度;在這里舉個反例,像查詢性別這種大量重復的字段時候,是否建立索引是沒有多大區(qū)別的;還有當表內數據不是很多的時候建立索引也是沒有多大意義的,因為索引也是要占用資源的。但是當我們數據庫非常大時候,經常進行GROUP BY查詢時候,若將GROUP BY字段上建立索引就會很大程度上面較少查詢搜索所花費的時間。 使用界面方式創(chuàng)建索引。 使用界面方式在Employees表的PhoneNumber列上創(chuàng)建索引。啟動SQL Server Managerment Studio,在對象資源管理器中展開數據庫YGGL,展開表Employ

4、ees,右擊“索引”,選擇“新建索引”選項。在新建索引的窗口中填寫索引的名稱和類型,單擊“添加”按鈕,在列框中選擇要創(chuàng)建索引的列,選擇完單擊“確定”按鈕即完成創(chuàng)建的工作?!舅伎寂c練習】A、使用界面方式創(chuàng)建一個復合索引。B、在Employees表的設計窗口中選擇Address列,右擊選擇“索引/鍵”菜單項,在新窗口中為Address創(chuàng)建一個唯一索引。C、創(chuàng)建一個數據量很大的新表,查看使用索引和不使用索引的區(qū)別。(2)重建索引。 重建Employees表中的所有索引?!舅伎寂c練習】重建表Employees中EmployeeID列上的索引。(3)刪除索引。 使用DROP INDEX語句刪除表Empl

5、oyees上的索引depart_ind,使用如下T-SQL語句。 從上面截圖中可以顯示,之前在Employees表中創(chuàng)建的depart_ind索引已經被刪除?!舅伎寂c練習】A、使用DROP INDEX一次刪除Employees表上的多個索引。B、使用界面方式刪除Department表上的索引。在數據庫YGGL中的Department表中打開“索引”,找到表Department表上的索引Dep_ind,右鍵刪除,在彈出的“刪除對象”窗口中選擇“確定”,刪除索引Dep_ind。(4)數據完整性。 創(chuàng)建一個表Employees5,只含EmployeeID、Name、Sex和Education列。將N

6、ame設為主鍵,作為列Name的約束。對EmployeeID列進行UNIQUE約束,并將其作為表的約束。 刪除上列中創(chuàng)建的UNIQUE約束。 【思考與練習】A、使用T-SQL命令創(chuàng)建一個新表,使用一個復合列作為主鍵,作為表的約束,并為其命令。B、使用ALTER TABLE語句為表Employees5添加一個新列Address,并未該列定義UNIQUE約束。C、使用界面方式為一個新表定義主鍵和UNIQUE約束,并了解如何使用圖形向導方式刪除主鍵和UNIQUE約束。 創(chuàng)建新表student,只考慮“號碼”和“性別”兩列,性別只能夠包含男或女?!舅伎寂c練習】向該表中插入數據,“性別”列插入“男”和“

7、女”以外字符,查看會發(fā)生什么情況?模擬用戶不小心輸入漢字錯誤: 創(chuàng)建新表Salary2表,結構與表Salary相同,但是表Salary2不允許OutCome大于InCome列?!舅伎寂c練習】 A、向表中插入數據,查看OutCome比InCome大時會發(fā)生什么情況?在“查詢分析器”中輸入上面截圖中的代碼,執(zhí)行后出現下面這樣的錯誤。原因:在創(chuàng)建表Salary2的時候,規(guī)定了InCome大于OutCome,如果輸入的數據不滿足這樣的條件,那么就會出現錯誤與規(guī)定沖突。 B、創(chuàng)建表Employees6表,只考慮“學號”和“出生日期”兩列,出生日期必須晚于1980年1月1日。在“查詢分析器”中輸入上面的代

8、碼,在下面的結果欄中發(fā)現命令已經執(zhí)行。 對YGGL數據庫中Employees表進行修改,增加“DepartmentID”字段的CHECK約束。在“查詢分析器”窗口中輸入下面程序并執(zhí)行:執(zhí)行上面的代碼,但是出現了這樣的問題?!舅伎寂c練習】測試CHECK約束的有效性。在Employees表中進行增加修改,設置Check約束,使得DepartmentID在15之間。如上面T-SQL命令所示,向表Employees中插入數據時,在結果欄中顯示了check約束提示錯誤: 從上面的T-SQL命令和結果欄中消息提示可以得出,該CHECK約束有效。 創(chuàng)建一個規(guī)則對象,用限制輸入到該規(guī)則所綁定的列中的值只能是該

9、規(guī)則中列出的值。在“查詢分析器”中輸入上面截圖中的代碼,顯示規(guī)則已經綁定?!舅伎寂c練習】 A、建立一個規(guī)則對象,限制值在020,然后把它綁定到Employees表的WorkYear字段上。 B、刪除上述建立的規(guī)則對象名。 創(chuàng)建表Salary3,要求所有表Salary3上EmployeeID列的值都要出現在表Salary中,利用參照完整性約束實現,要求當刪除或修改Salary表上的EmployeeID列時,Salary3表中的EmployeeID值也會隨之變化。使用T-SQL語句:執(zhí)行上面截圖中的命令,表Salary3已經成功建好?!舅伎寂c練習】 A、創(chuàng)建表Salary3后,初始化該表的數據與S

10、alary表相同。刪除Salary表中一行數據,在查看表Salary3中內容,看看會發(fā)生什么?在左側對象資源管理器中查看新建的的Salary3表及其數據: 利用參照完整性約束實現,當刪除或修改Salary表上的EmployeeID列時,Salary3表中的EmployeeID值也會隨之變化。 B、使用ALTER TABLE語句向Salary表中的EmployeeID列上添加一個外鍵,要求當Employees表中要求刪除或修改EmployeeID值有關的行時,堅持Salary表中有沒有與該EmployeeID值有關的記錄,如果存在,則拒絕更新Employees表。 C、在對象資源管理器中建立Departments、Employees 和Salary 3個表之間的參照關系。4、實驗總結 通過本次實驗我了解了索引和CHECK約束的大致用法,例如:在表中約束輸入性別只準“男

溫馨提示

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

評論

0/150

提交評論