版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、第第8章章 數(shù)據(jù)完整性數(shù)據(jù)完整性 本章內(nèi)容本章內(nèi)容 8.1 數(shù)據(jù)完整性概述數(shù)據(jù)完整性概述 8.2 使用規(guī)則實(shí)施數(shù)據(jù)完整性使用規(guī)則實(shí)施數(shù)據(jù)完整性 8.3 使用默認(rèn)值實(shí)施數(shù)據(jù)完整性使用默認(rèn)值實(shí)施數(shù)據(jù)完整性 8.4 使用約束實(shí)施數(shù)據(jù)完整性使用約束實(shí)施數(shù)據(jù)完整性 8.1 數(shù)據(jù)完整性概述數(shù)據(jù)完整性概述 n數(shù)據(jù)完整性防止數(shù)據(jù)庫中存在不符合語義規(guī)定的數(shù)據(jù)和防數(shù)據(jù)完整性防止數(shù)據(jù)庫中存在不符合語義規(guī)定的數(shù)據(jù)和防 止因錯(cuò)誤信息的輸入輸出造成無效操作或錯(cuò)誤信息而提出止因錯(cuò)誤信息的輸入輸出造成無效操作或錯(cuò)誤信息而提出 的。的。 數(shù)據(jù)完整性有數(shù)據(jù)完整性有4種類型:種類型: 實(shí)體完整性實(shí)體完整性(Entity Integ
2、rity)、 域完整性域完整性(Domain Integrity)、 參照完整性參照完整性(Referential Integrity)、 用戶定義的完整性用戶定義的完整性(User-defined Integrity)。 n在在SQL Server中可以通過各種規(guī)則中可以通過各種規(guī)則(Rule)、默認(rèn)、默認(rèn)(Default)、 約束約束(Constraint)和觸發(fā)器和觸發(fā)器(Trigger)等數(shù)據(jù)庫對(duì)象來保證數(shù)等數(shù)據(jù)庫對(duì)象來保證數(shù) 據(jù)的完整性。據(jù)的完整性。 8.2 使用規(guī)則實(shí)施數(shù)據(jù)完整性使用規(guī)則實(shí)施數(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ù)庫中對(duì)存儲(chǔ)在表的列或用戶定義數(shù)據(jù)就是數(shù)據(jù)庫中對(duì)存儲(chǔ)在表的列或用戶定義數(shù)據(jù) 類型中的值的規(guī)定和限制。類型中的值的規(guī)定和限制。 n規(guī)則是單獨(dú)存儲(chǔ)的獨(dú)立的數(shù)據(jù)庫對(duì)象。規(guī)則是單獨(dú)存儲(chǔ)的獨(dú)立的數(shù)據(jù)庫對(duì)象。 n規(guī)則和約束可以同時(shí)使用,表的列可以有一個(gè)規(guī)則及多個(gè)規(guī)則和約束可以同時(shí)使用,表的列可以有一個(gè)規(guī)則及多個(gè) 約束。規(guī)則與檢查約束在功能上相似,但在使用上有所區(qū)約束。規(guī)則與檢查約束在功能上相似,但在使用上有所區(qū) 別。別。 檢查約束是在檢查約束是在CREATE TABLE或或ALTE
4、R TABLE語句中定義的,語句中定義的, 嵌入了被定義的表結(jié)構(gòu),即刪除表的時(shí)候檢查約束也就隨之被刪嵌入了被定義的表結(jié)構(gòu),即刪除表的時(shí)候檢查約束也就隨之被刪 除。除。 而規(guī)則需要用而規(guī)則需要用CREATE RULE語句定義后才能使用,是獨(dú)立于表語句定義后才能使用,是獨(dú)立于表 之外的數(shù)據(jù)庫對(duì)象,刪除表并不能刪除規(guī)則,需要用之外的數(shù)據(jù)庫對(duì)象,刪除表并不能刪除規(guī)則,需要用DROP RULE語句才能刪除。語句才能刪除。 相比之下,使用在相比之下,使用在CREATE TABLE或或ALTER TABLE語句中定義語句中定義 的檢查約束是更標(biāo)準(zhǔn)的限制列值的方法,但檢查約束不能直接作的檢查約束是更標(biāo)準(zhǔn)的限制
5、列值的方法,但檢查約束不能直接作 用于用戶定義數(shù)據(jù)類型。用于用戶定義數(shù)據(jù)類型。 8.2 8.2 使用規(guī)則實(shí)施數(shù)據(jù)完整性使用規(guī)則實(shí)施數(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ù)庫對(duì)象據(jù)庫對(duì)象“規(guī)則規(guī)則”,單,單 擊右鍵從快捷菜單中選擊右鍵從快捷菜單中選 擇擇“新建規(guī)則新建規(guī)則”選項(xiàng),選項(xiàng), 即會(huì)彈出如圖所示的即會(huì)彈出如圖所示的 “規(guī)則屬性規(guī)則屬性”對(duì)話框。對(duì)話框。 n輸入規(guī)則名稱和表達(dá)式輸入規(guī)則名稱和表達(dá)式 之后,單擊之后,單擊“確定確定”按按 鈕,即完成規(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語句用于在當(dāng)前數(shù)據(jù)庫中語句用于在當(dāng)前數(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)建一個(gè)訂貨表創(chuàng)建一個(gè)訂貨表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í)施數(shù)據(jù)完整性使用約束實(shí)施數(shù)據(jù)完整性 8.4.5 默認(rèn)約束默認(rèn)約束 n默認(rèn)默認(rèn)(Default)約束
9、通過定義列的默認(rèn)值或使約束通過定義列的默認(rèn)值或使 用數(shù)據(jù)庫的默認(rèn)值對(duì)象綁定表的列,以確用數(shù)據(jù)庫的默認(rèn)值對(duì)象綁定表的列,以確 保在沒有為某列指定數(shù)據(jù)時(shí),來指定列的保在沒有為某列指定數(shù)據(jù)時(shí),來指定列的 值。值。 n默認(rèn)值可以是常量,也可以是表達(dá)式,還默認(rèn)值可以是常量,也可以是表達(dá)式,還 可以為可以為NULL值。值。 8.4.5 8.4.5 默認(rèn)約束默認(rèn)約束 定義默認(rèn)約束的語法格式定義默認(rèn)約束的語法格式 CONSTRAINT constraint_name DEFAULT constant_expression FOR column_name 8.4.5 8.4.5 默認(rèn)約束默認(rèn)約束 例例8-27
10、在在Sales數(shù)據(jù)庫中,為員工表數(shù)據(jù)庫中,為員工表employee 的的sex列添加默認(rèn)約束,默認(rèn)值是列添加默認(rèn)約束,默認(rèn)值是“男男”。 ALTER TABLE employee ADD CONSTRAINT sex_default DEFAULT 男男 FOR sex n例例8-28 更改表更改表employee為為hire_date列定義列定義 默認(rèn)約束。默認(rèn)約束。 ALTER TABLE employee ADD CONSTRAINT hire_date_df DEFAULT (getdate() FOR hire_date 8.4.5 8.4.5 默認(rèn)約束默認(rèn)約束 例例8-29 添加具
11、有默認(rèn)值的可為空的列添加具有默認(rèn)值的可為空的列 ALTER TABLE employee ADD hire_date datetime DEFAULT (getdate() WITH VALUES 8.4.5 8.4.5 默認(rèn)約束默認(rèn)約束 例例8-30 使用默認(rèn)約束。使用默認(rèn)約束。 -創(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選項(xiàng)為選項(xiàng)為purchase_order表裝載數(shù)據(jù)。表裝載數(shù)據(jù)。 INSERT INTO purchase_order DEFAULT VALUES-無法執(zhí)行,因?yàn)橛泻芏嘁蠓强沼譀]有默認(rèn)值的字段無法執(zhí)行,
13、因?yàn)橛泻芏嘁蠓强沼譀]有默認(rèn)值的字段 8.4.5 8.4.5 默認(rèn)約束默認(rèn)約束 例例8-31 為表為表purchase_orders定義多個(gè)約束定義多個(gè)約束 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種類型:實(shí)體完整性、域完整性、參照完整性和種類型:實(shí)體完整性、域完整性、參照完整性和 用戶定義的完整性。在用戶定義的完整性。在SQL Server 2000中可以通過各種約束、默認(rèn)、中可以通過各種約束、默認(rèn)、 規(guī)則和觸發(fā)器等數(shù)據(jù)庫對(duì)象來保證數(shù)據(jù)的完整性。規(guī)則和觸發(fā)器等數(shù)據(jù)庫對(duì)象來保證數(shù)據(jù)的完整性。 (2)規(guī)則實(shí)施數(shù)據(jù)的完整性:規(guī)則就是數(shù)據(jù)庫中對(duì)存儲(chǔ)在表的列或規(guī)則實(shí)施數(shù)據(jù)的完整性:規(guī)則就是數(shù)據(jù)庫中對(duì)存儲(chǔ)在表的列或 用戶定義數(shù)
15、據(jù)類型中的值的規(guī)定和限制。可以通過企業(yè)管理器和用戶定義數(shù)據(jù)類型中的值的規(guī)定和限制??梢酝ㄟ^企業(yè)管理器和 Transact-SQL語句來創(chuàng)建、刪除、查看規(guī)則以及規(guī)則的綁定與松綁。語句來創(chuàng)建、刪除、查看規(guī)則以及規(guī)則的綁定與松綁。 (3)默認(rèn)值實(shí)施數(shù)據(jù)完整性:默認(rèn)值是用戶輸入記錄時(shí)沒有指定具默認(rèn)值實(shí)施數(shù)據(jù)完整性:默認(rèn)值是用戶輸入記錄時(shí)沒有指定具 體數(shù)據(jù)的列中自動(dòng)插入的數(shù)據(jù)。默認(rèn)值對(duì)象可以用于多個(gè)列或用戶定體數(shù)據(jù)的列中自動(dòng)插入的數(shù)據(jù)。默認(rèn)值對(duì)象可以用于多個(gè)列或用戶定 義數(shù)據(jù)類型,它的管理與應(yīng)用同規(guī)則有許多相似之處。表的一列或一義數(shù)據(jù)類型,它的管理與應(yīng)用同規(guī)則有許多相似之處。表的一列或一 個(gè)用戶定義數(shù)據(jù)類型也只能與一個(gè)默認(rèn)值相綁定。在個(gè)用戶定義數(shù)據(jù)類型也只能與一個(gè)默認(rèn)值相綁定。在SQL Server中中 使用企業(yè)管理器和使用企業(yè)管理器和Transact-SQL語句實(shí)現(xiàn)默認(rèn)值的創(chuàng)建、查看、刪語句實(shí)現(xiàn)默認(rèn)值的創(chuàng)建、查看、刪 除以及默認(rèn)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024施工混凝土合同范本
- 2024年中英文對(duì)照技術(shù)文檔制作與審核合同3篇
- 2024年高端住宅銷售代理協(xié)議版
- 2025年度甜品連鎖店品牌授權(quán)合作合同范本3篇
- 2024幼兒園幼兒安全與健康管理聘用協(xié)議書3篇
- 2024幼兒園教師學(xué)生個(gè)性發(fā)展與教育引導(dǎo)合同3篇
- 2024年電子商務(wù)用戶隱私保護(hù)協(xié)議3篇
- 2024年電子產(chǎn)品物流配送合同
- 2025年度冷鏈倉儲(chǔ)與配送服務(wù)合同范本3篇
- 2024物流運(yùn)輸合同涉及的責(zé)任與義務(wù)
- GB∕T 41627-2022 動(dòng)物源空腸彎曲菌檢測(cè)方法
- 供貨保障措施
- (完整版)常用樂高零件清單匯總
- 消防四個(gè)能力
- 機(jī)動(dòng)車環(huán)檢標(biāo)準(zhǔn)方法驗(yàn)證模板
- AQL標(biāo)準(zhǔn)抽樣檢驗(yàn)表
- 美國Control4智能家居設(shè)計(jì)方案解說資料
- DES算法Matlab代碼
- 交通事故快速處理單(正反打印)
- 電纜熱穩(wěn)定校驗(yàn)計(jì)算書
- 2020國際大專辯論賽順境或逆境更有利于人的成長
評(píng)論
0/150
提交評(píng)論