




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領
文檔簡介
1、第第8章章 數(shù)據(jù)完整性數(shù)據(jù)完整性 本章內(nèi)容本章內(nèi)容 8.1 數(shù)據(jù)完整性概述數(shù)據(jù)完整性概述 8.2 使用規(guī)則實施數(shù)據(jù)完整性使用規(guī)則實施數(shù)據(jù)完整性 8.3 使用默認值實施數(shù)據(jù)完整性使用默認值實施數(shù)據(jù)完整性 8.4 使用約束實施數(shù)據(jù)完整性使用約束實施數(shù)據(jù)完整性 8.1 數(shù)據(jù)完整性概述數(shù)據(jù)完整性概述 n數(shù)據(jù)完整性防止數(shù)據(jù)庫中存在不符合語義規(guī)定的數(shù)據(jù)和防數(shù)據(jù)完整性防止數(shù)據(jù)庫中存在不符合語義規(guī)定的數(shù)據(jù)和防 止因錯誤信息的輸入輸出造成無效操作或錯誤信息而提出止因錯誤信息的輸入輸出造成無效操作或錯誤信息而提出 的。的。 數(shù)據(jù)完整性有數(shù)據(jù)完整性有4種類型:種類型: 實體完整性實體完整性(Entity Integ
2、rity)、 域完整性域完整性(Domain Integrity)、 參照完整性參照完整性(Referential Integrity)、 用戶定義的完整性用戶定義的完整性(User-defined Integrity)。 n在在SQL Server中可以通過各種規(guī)則中可以通過各種規(guī)則(Rule)、默認、默認(Default)、 約束約束(Constraint)和觸發(fā)器和觸發(fā)器(Trigger)等數(shù)據(jù)庫對象來保證數(shù)等數(shù)據(jù)庫對象來保證數(shù) 據(jù)的完整性。據(jù)的完整性。 8.2 使用規(guī)則實施數(shù)據(jù)完整性使用規(guī)則實施數(shù)據(jù)完整性 8.2.1 創(chuàng)建規(guī)則創(chuàng)建規(guī)則 8.2.2 查看和修改規(guī)則查看和修改規(guī)則 8.2.
3、3 規(guī)則的綁定與松綁規(guī)則的綁定與松綁 8.2.4 刪除規(guī)則刪除規(guī)則 8.2.1 創(chuàng)建規(guī)則創(chuàng)建規(guī)則 n規(guī)則規(guī)則(Rule)就是數(shù)據(jù)庫中對存儲在表的列或用戶定義數(shù)據(jù)就是數(shù)據(jù)庫中對存儲在表的列或用戶定義數(shù)據(jù) 類型中的值的規(guī)定和限制。類型中的值的規(guī)定和限制。 n規(guī)則是單獨存儲的獨立的數(shù)據(jù)庫對象。規(guī)則是單獨存儲的獨立的數(shù)據(jù)庫對象。 n規(guī)則和約束可以同時使用,表的列可以有一個規(guī)則及多個規(guī)則和約束可以同時使用,表的列可以有一個規(guī)則及多個 約束。規(guī)則與檢查約束在功能上相似,但在使用上有所區(qū)約束。規(guī)則與檢查約束在功能上相似,但在使用上有所區(qū) 別。別。 檢查約束是在檢查約束是在CREATE TABLE或或ALTE
4、R TABLE語句中定義的,語句中定義的, 嵌入了被定義的表結(jié)構(gòu),即刪除表的時候檢查約束也就隨之被刪嵌入了被定義的表結(jié)構(gòu),即刪除表的時候檢查約束也就隨之被刪 除。除。 而規(guī)則需要用而規(guī)則需要用CREATE RULE語句定義后才能使用,是獨立于表語句定義后才能使用,是獨立于表 之外的數(shù)據(jù)庫對象,刪除表并不能刪除規(guī)則,需要用之外的數(shù)據(jù)庫對象,刪除表并不能刪除規(guī)則,需要用DROP RULE語句才能刪除。語句才能刪除。 相比之下,使用在相比之下,使用在CREATE TABLE或或ALTER TABLE語句中定義語句中定義 的檢查約束是更標準的限制列值的方法,但檢查約束不能直接作的檢查約束是更標準的限制
5、列值的方法,但檢查約束不能直接作 用于用戶定義數(shù)據(jù)類型。用于用戶定義數(shù)據(jù)類型。 8.2 8.2 使用規(guī)則實施數(shù)據(jù)完整性使用規(guī)則實施數(shù)據(jù)完整性 1用企業(yè)管理器創(chuàng)建規(guī)則用企業(yè)管理器創(chuàng)建規(guī)則 8.2.1 8.2.1 創(chuàng)建規(guī)則創(chuàng)建規(guī)則 n在企業(yè)管理器中選擇數(shù)在企業(yè)管理器中選擇數(shù) 據(jù)庫對象據(jù)庫對象“規(guī)則規(guī)則”,單,單 擊右鍵從快捷菜單中選擊右鍵從快捷菜單中選 擇擇“新建規(guī)則新建規(guī)則”選項,選項, 即會彈出如圖所示的即會彈出如圖所示的 “規(guī)則屬性規(guī)則屬性”對話框。對話框。 n輸入規(guī)則名稱和表達式輸入規(guī)則名稱和表達式 之后,單擊之后,單擊“確定確定”按按 鈕,即完成規(guī)則的創(chuàng)建。鈕,即完成規(guī)則的創(chuàng)建。 2用用
6、CREATE RULE語句創(chuàng)建規(guī)則語句創(chuàng)建規(guī)則 8.2.1 8.2.1 創(chuàng)建規(guī)則創(chuàng)建規(guī)則 nCREATE RULE語句用于在當前數(shù)據(jù)庫中語句用于在當前數(shù)據(jù)庫中 創(chuàng)建規(guī)則,其語法格式如下:創(chuàng)建規(guī)則,其語法格式如下: CREATE RULE rule_name AS condition_expression 8.2.1 8.2.1 創(chuàng)建規(guī)則創(chuàng)建規(guī)則 CREATE RULE hire_date_rule AS hire_date=1980-01-01 and hire_date18) 8.4.4 8.4.4 檢查約束檢查約束 例例8-25 創(chuàng)建一個訂貨表創(chuàng)建一個訂貨表orders,保證各訂單,保證各
7、訂單 的訂貨量必須不小于的訂貨量必須不小于10。 CREATE TABLE orders ( order_id char(8), p_id char(8), p_name char(10) , quantity smallint CONSTRAINT chk_quantity CHECK (quantity=10), CONSTRAINT pk_orders_id PRIMARY KEY (order_id) ) 8.4.4 8.4.4 檢查約束檢查約束 CREATE TABLE transporters ( transporter_id char(4) NOT NULL, transport
8、_name varchar(50), linkman_name char(8), address varchar(50), telephone char(12) NOT NULL CHECK(telephone LIKE 01-90-90-9-1-90-90-90-90-90-90-9 OR telephone LIKE 01-90-9-1-90-90-90-90-90-90-90-9) ) 例例8-26 創(chuàng)建創(chuàng)建transporters表并定義檢查約束表并定義檢查約束 8.4 8.4 使用約束實施數(shù)據(jù)完整性使用約束實施數(shù)據(jù)完整性 8.4.5 默認約束默認約束 n默認默認(Default)約束
9、通過定義列的默認值或使約束通過定義列的默認值或使 用數(shù)據(jù)庫的默認值對象綁定表的列,以確用數(shù)據(jù)庫的默認值對象綁定表的列,以確 保在沒有為某列指定數(shù)據(jù)時,來指定列的保在沒有為某列指定數(shù)據(jù)時,來指定列的 值。值。 n默認值可以是常量,也可以是表達式,還默認值可以是常量,也可以是表達式,還 可以為可以為NULL值。值。 8.4.5 8.4.5 默認約束默認約束 定義默認約束的語法格式定義默認約束的語法格式 CONSTRAINT constraint_name DEFAULT constant_expression FOR column_name 8.4.5 8.4.5 默認約束默認約束 例例8-27
10、在在Sales數(shù)據(jù)庫中,為員工表數(shù)據(jù)庫中,為員工表employee 的的sex列添加默認約束,默認值是列添加默認約束,默認值是“男男”。 ALTER TABLE employee ADD CONSTRAINT sex_default DEFAULT 男男 FOR sex n例例8-28 更改表更改表employee為為hire_date列定義列定義 默認約束。默認約束。 ALTER TABLE employee ADD CONSTRAINT hire_date_df DEFAULT (getdate() FOR hire_date 8.4.5 8.4.5 默認約束默認約束 例例8-29 添加具
11、有默認值的可為空的列添加具有默認值的可為空的列 ALTER TABLE employee ADD hire_date datetime DEFAULT (getdate() WITH VALUES 8.4.5 8.4.5 默認約束默認約束 例例8-30 使用默認約束。使用默認約束。 -創(chuàng)建表創(chuàng)建表purchase_order CREATE TABLE purchase_order ( order_id2 char(6)NOT NULL, goods_id char(6) NOT NULL, employee_id char(4) NOT NULL, supplier_id char(5) NO
12、T NULL, transporter_id char(4), order_num float NOT NULL, discount float DEFAULT (0), order_date datetime NOT NULL DEFAULT (GetDate(), send_date datetime, arrival_date datetime) -使用使用DEFAULT VALUES選項為選項為purchase_order表裝載數(shù)據(jù)。表裝載數(shù)據(jù)。 INSERT INTO purchase_order DEFAULT VALUES-無法執(zhí)行,因為有很多要求非空又沒有默認值的字段無法執(zhí)行,
13、因為有很多要求非空又沒有默認值的字段 8.4.5 8.4.5 默認約束默認約束 例例8-31 為表為表purchase_orders定義多個約束定義多個約束 CREATE TABLE purchase_orders ( order_id2 char(6) NOT NULL, goods_id char(6) NOT NULL, employee_id char(4) NOT NULL, supplier_id char(5) NOT NULL, transporter_id char(4), order_num float NOT NULL, discount float CHECK (dis
14、count=0 AND discount order_date and arrival_date send_date) ) 本章小結(jié)本章小結(jié) (1)數(shù)據(jù)完整性有數(shù)據(jù)完整性有4種類型:實體完整性、域完整性、參照完整性和種類型:實體完整性、域完整性、參照完整性和 用戶定義的完整性。在用戶定義的完整性。在SQL Server 2000中可以通過各種約束、默認、中可以通過各種約束、默認、 規(guī)則和觸發(fā)器等數(shù)據(jù)庫對象來保證數(shù)據(jù)的完整性。規(guī)則和觸發(fā)器等數(shù)據(jù)庫對象來保證數(shù)據(jù)的完整性。 (2)規(guī)則實施數(shù)據(jù)的完整性:規(guī)則就是數(shù)據(jù)庫中對存儲在表的列或規(guī)則實施數(shù)據(jù)的完整性:規(guī)則就是數(shù)據(jù)庫中對存儲在表的列或 用戶定義數(shù)
15、據(jù)類型中的值的規(guī)定和限制??梢酝ㄟ^企業(yè)管理器和用戶定義數(shù)據(jù)類型中的值的規(guī)定和限制??梢酝ㄟ^企業(yè)管理器和 Transact-SQL語句來創(chuàng)建、刪除、查看規(guī)則以及規(guī)則的綁定與松綁。語句來創(chuàng)建、刪除、查看規(guī)則以及規(guī)則的綁定與松綁。 (3)默認值實施數(shù)據(jù)完整性:默認值是用戶輸入記錄時沒有指定具默認值實施數(shù)據(jù)完整性:默認值是用戶輸入記錄時沒有指定具 體數(shù)據(jù)的列中自動插入的數(shù)據(jù)。默認值對象可以用于多個列或用戶定體數(shù)據(jù)的列中自動插入的數(shù)據(jù)。默認值對象可以用于多個列或用戶定 義數(shù)據(jù)類型,它的管理與應用同規(guī)則有許多相似之處。表的一列或一義數(shù)據(jù)類型,它的管理與應用同規(guī)則有許多相似之處。表的一列或一 個用戶定義數(shù)據(jù)類型也只能與一個默認值相綁定。在個用戶定義數(shù)據(jù)類型也只能與一個默認值相綁定。在SQL Server中中 使用企業(yè)管理器和使用企業(yè)管理器和Transact-SQL語句實現(xiàn)默認值的創(chuàng)建、查看、刪語句實現(xiàn)默認值的創(chuàng)建、查看、刪 除以及默認
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025-2030年中國貼劑行業(yè)發(fā)展現(xiàn)狀及前景規(guī)劃研究報告
- 2025-2030年中國稀土冶煉分離市場運行動態(tài)及發(fā)展前景分析報告
- 2025甘肅省安全員考試題庫附答案
- 南京醫(yī)科大學《課程論文寫作與學術規(guī)范》2023-2024學年第二學期期末試卷
- 黔西南民族職業(yè)技術學院《外國建筑史》2023-2024學年第二學期期末試卷
- 青海交通職業(yè)技術學院《傳感檢測技術》2023-2024學年第二學期期末試卷
- 天津商業(yè)大學《學術論文選題與寫作》2023-2024學年第二學期期末試卷
- 湖北大學《財務會計一》2023-2024學年第二學期期末試卷
- 2025上海市建筑安全員考試題庫及答案
- 西藏大學《軟件交互設計》2023-2024學年第二學期期末試卷
- 原材料取樣檢測安全操作規(guī)程
- 創(chuàng)新思維與方法(第2版)PPT全套完整教學課件
- (5.3.2)-2.2雜草的分類農(nóng)田雜草及防除學
- 人教部編道德與法治五年級下冊單元計劃
- 天津武清區(qū)事業(yè)單位考試真題2022
- 鐵路營業(yè)線施工安全管理培訓課件
- 旅行社運營實務電子課件 1.2 了解旅行社核心業(yè)務部門
- 部編版五年級語文下冊課文四字詞總結(jié)
- 綜合交通運輸體系認知
- GM/T 0115-2021信息系統(tǒng)密碼應用測評要求
- YY 0670-2008無創(chuàng)自動測量血壓計
評論
0/150
提交評論