亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Access > 正文

數據庫設計范式

2024-09-07 19:03:37
字體:
來源:轉載
供稿:網友

關系數據庫設計之時是要遵守一定的規則的。尤其是數據庫設計范式 現簡單介紹1NF(第一范式),2NF(第二范式),3NF(第三范式)和BCNF,另有第四范式和第五范式留到以后再介紹。 在你設計數據庫之時,若能符合這幾個范式,你就是數據庫設計的高手。

第一范式(1NF):在關系模式R中的每一個具體關系r中,如果每個屬性值 都是不可再分的最小數據單位,則稱R是第一范式的關系。例:如職工號,姓名,電話號碼組成一個表(一個人可能有一個辦公室電話 和一個家里電話號碼) 規范成為1NF有三種方法:

一是重復存儲職工號和姓名。這樣,關鍵字只能是電話號碼。

二是職工號為關鍵字,電話號碼分為單位電話和住宅電話兩個屬性

三是職工號為關鍵字,但強制每條記錄只能有一個電話號碼。

以上三個方法,第一種方法最不可取,按實際情況選取后兩種情況。

第二范式(2NF):如果關系模式R(U,F)中的所有非主屬性都完全依賴于任意一個候選關鍵字,則稱關系R 是屬于第二范式的。

例:選課關系 SCI(SNO,CNO,GRADE,CREDIT)其中SNO為學號, CNO為課程號,GRADEGE 為成績,CREDIT 為學分。 由以上條件,關鍵字為組合關鍵字(SNO,CNO)

在應用中使用以上關系模式有以下問題:

a.數據冗余,假設同一門課由40個學生選修,學分就 重復40次。

b.更新異常,若調整了某課程的學分,相應的元組CREDIT值都要更新,有可能會出現同一門課學分不同。

c.插入異常,如計劃開新課,由于沒人選修,沒有學號關鍵字,只能等有人選修才能把課程和學分存入。

d.刪除異常,若學生已經結業,從當前數據庫刪除選修記錄。某些門課程新生尚未選修,則此門課程及學分記錄無法保存。

原因:非關鍵字屬性CREDIT僅函數依賴于CNO,也就是CREDIT部分依賴組合關鍵字(SNO,CNO)而不是完全依賴。

解決方法:分成兩個關系模式 SC1(SNO,CNO,GRADE),C2(CNO,CREDIT)。新關系包括兩個關系模式,它們之間通過SC1中的外關鍵字CNO相聯系,需要時再進行自然聯接,恢復了原來的關系

第三范式(3NF):如果關系模式R(U,F)中的所有非主屬性對任何候選關鍵字都不存在傳遞信賴,則稱關系R是屬于第三范式的。

例:如S1(SNO,SNAME,DNO,DNAME,LOCATION) 各屬性分別代表學號,姓名,所在系,系名稱,系地址。

關鍵字SNO決定各個屬性。由于是單個關鍵字,沒有部分依賴的問題,肯定是2NF。但這關系肯定有大量的冗余,有關學生所在的幾個屬性DNO,DNAME,LOCATION將重復存儲,插入,刪除和修改時也將產生類似以上例的情況。

原因:關系中存在傳遞依賴造成的。即SNO -> DNO。 而DNO -> SNO卻不存在,DNO -> LOCATION, 因此關鍵遼 SNO 對 LOCATION 函數決定是通過傳遞依賴 SNO -> LOCATION 實現的。也就是說,SNO不直接決定非主屬性LOCATION。

解決目地:每個關系模式中不能留有傳遞依賴。

解決方法:分為兩個關系 S(SNO,SNAME,DNO),D(DNO,DNAME,LOCATION)

注意:關系S中不能沒有外關鍵字DNO。否則兩個關系之間失去聯系。

BCNF:如果關系模式R(U,F)的所有屬性(包括主屬性和非主屬性)都不傳遞依賴于R的任何候選關鍵字,那么稱關系R是屬于BCNF的?;蚴顷P系模式R,如果每個決定因素都包含關鍵字(而不是被關鍵字所包含),則RCNF的關系模式。

例:配件管理關系模式 WPE(WNO,PNO,ENO,QNT)分別表倉庫號,配件號,職工號,數量。有以下條件

a.一個倉庫有多個職工。

b.一個職工僅在一個倉庫工作。

c.每個倉庫里一種型號的配件由專人負責,但一個人可以管理幾種配件。

d.同一種型號的配件可以分放在幾個倉庫中。

分析:由以上得 PNO 不能確定QNT,由組合屬性(WNO,PNO)來決定,存在函數依賴(WNO,PNO) -> ENO。由于每個倉庫里的一種配件由專人負責,而一個人可以管理幾種配件,所以有組合屬性(WNO,PNO)才能確定負責人,有(WNO,PNO)-> ENO。因為 一個職工僅在一個倉庫工作,有ENO -> WNO。由于每個倉庫里的一種配件由專人負責,而一個職工僅在一個倉庫工作,有 (ENO,PNO)-> QNT。

找一下候選關鍵字,因為(WNO,PNO) -> QNT,(WNO,PNO)-> ENO ,因此 (WNO,PNO)可以決定整個元組,是一個候選關鍵字。根據ENO->WNO,(ENO,PNO)->QNT,故(ENO,PNO)也能決定整個元組,為另一個候選關鍵字。屬性ENO,WNO,PNO 均為主屬性,只有一個非主屬性QNT。它對任何一個候選關鍵字都是完全函數依賴的,并且是直接依賴,所以該關系模式是3NF。

分析一下主屬性。因為ENO->WNO,主屬性ENO是WNO的決定因素,但是它本身不是關鍵字,只是組合關鍵字的一部分。這就造成主屬性WNO對另外一個候選關鍵字(ENO,PNO)的部 分依賴,因為(ENO,PNO)-> ENO但反過來不成立,而P->WNO,故(ENO,PNO)-> WNO 也是傳遞依賴。

雖然沒有非主屬性對候選關鍵遼的傳遞依賴,但存在主屬性對候選關鍵字的傳遞依賴,同樣也會帶來麻煩。如一個新職工分配到倉庫工作,但暫時處于實習階段,沒有獨立負責對某些配件的管理任務。由于缺少關鍵字的一部分PNO而無法插入到該關系中去。又如某個人改成不管配件了去負責安全,則在刪除配件的同時該職工也會被刪除。

解決辦法:分成管理EP(ENO,PNO,QNT),關鍵字是(ENO,PNO)工作EW(ENO,WNO)其關鍵字是ENO

缺點:分解后函數依賴的保持性較差。如此例中,由于分解,函數依賴(WNO,PNO)-> ENO 丟失了, 因而對原來的語義有所破壞。沒有體現出每個倉庫里一種部件由專人負責。有可能出現 一部件由兩個人或兩個以上的人來同時管理。因此,分解之后的關系模式降低了部分完整性約束。

一個關系分解成多個關系,要使得分解有意義,起碼的要求是分解后不丟失原來的信息。這些信息不僅包括數據本身,而且包括由函數依賴所表示的數據之間的相互制約。進行分解的目標是達到更高一級的規范化程度,但是分解的同時必須考慮兩個問題:無損聯接性和保持函數依賴。有時往往不可能做到既有無損聯接性,又完全保持函數依賴。需要根據需要進行權衡。

1NF直到BCNF的四種范式之間有如下關系:

BCNF包含了3NF包含2NF包含1NF

小結:

目地:規范化目的是使結構更合理,消除存儲異常,使數據冗余盡量小,便于插入、刪除和更新

原則:遵從概念單一化 "一事一地"原則,即一個關系模式描述一個實體或實體間的一種聯系。規范的實質就是概念的單一化。

方法:將關系模式投影分解成兩個或兩個以上的關系模式。

要求:分解后的關系模式集合應當與原關系模式"等價",即經過自然聯接可以恢復原關系而不丟失信息,并保持屬性間合理的聯系。

注意:一個關系模式結這分解可以得到不同關系模式集合,也就是說分解方法不是唯一的。最小冗余的要求必須以分解后的數據庫能夠表達原來數據庫所有信息為前提來實現。其根本目標是節省存儲空間,避免數據不一致性,提高對關系的操作效率,同時滿足應用需求。實際上,并不一定要求全部模式都達到BCNF不可。有時故意保留部分冗余可能更方便數據查詢。尤其對于那些更新頻度不高,查詢頻度極高的數據庫系統更是如此。

在關系數據庫中,除了函數依賴之外還有多值依賴,聯接依賴的問題,從而提出了第四范式,第五范式等更高一級的規范化要求。在此,以后再談。

各位朋友,你看過后有何感想,其實,任何一本數據庫基礎理論的書都會講這些東西,考慮到很多網友是半途出家,來做數據庫。特找一本書大抄特抄一把,各位有什么問題,也別問我了,自已去找一本關系數據庫理論的書去看吧,說不定,對各位大有幫助。說是說以上是基礎理論的東西,請大家想想,你在做數據庫設計的時候有沒有考慮過遵過以上幾個范式呢,有沒有在數據庫設計做得不好之時,想一想,對比以上所講,到底是違反了第幾個范式呢?

我見過的數據庫設計,很少有人做到很符合以上幾個范式的,一般說來,第一范式大家都可以遵守,完全遵守第二第三范式的人很少了,遵守的人一定就是設計數據庫的高手了,BCNF的范式出現機會較少,而且會破壞完整性,你可以在做設計之時不考慮它,當然在Oracle中可通過觸發器解決其缺點。以后我們共同做設計之時,也希望大家遵守以上幾個范式。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲成人av资源网| 日韩av网站电影| 欧美性一区二区三区| 日韩成人av网址| 欧美视频在线观看 亚洲欧| 国产亚洲人成a一在线v站| 国产剧情久久久久久| 日韩少妇与小伙激情| 日韩有码在线电影| 精品精品国产国产自在线| 亚洲国产天堂网精品网站| 欧美一级视频在线观看| 精品无人区乱码1区2区3区在线| 欧美日韩性视频在线| 亚洲va欧美va国产综合久久| 91亚洲国产成人久久精品网站| 精品日本高清在线播放| 日韩在线免费视频观看| 亚洲自拍偷拍区| 国产精品麻豆va在线播放| 美女久久久久久久| 日日摸夜夜添一区| 亚洲第一精品夜夜躁人人躁| 美女扒开尿口让男人操亚洲视频网站| 欧美日本啪啪无遮挡网站| 成人444kkkk在线观看| 欧美黄色性视频| 亚洲成人激情在线观看| 亚洲第一精品自拍| 日韩精品免费视频| xxx一区二区| 欧美亚洲午夜视频在线观看| 国产精品欧美激情在线播放| 国产狼人综合免费视频| 亚洲人成电影在线观看天堂色| 国产精品激情av电影在线观看| 国产精品九九久久久久久久| 精品一区二区电影| 国产欧美一区二区| 91视频国产精品| 亚洲一区二区三区sesese| 欧美做爰性生交视频| 日韩三级影视基地| 久久成年人免费电影| 成人免费网站在线看| 欧美性在线视频| 精品国产区一区二区三区在线观看| 亚洲色图13p| 97超碰蝌蚪网人人做人人爽| 中文字幕国内精品| www欧美xxxx| 亚洲人成亚洲人成在线观看| 亚洲a级在线播放观看| 亚洲精品av在线| 久久久久久久久久久91| 91精品91久久久久久| 揄拍成人国产精品视频| 亚洲国产精品视频在线观看| 日韩亚洲一区二区| 国产精品久久久久久久久久新婚| 国产精品久久久久久久7电影| 亚洲综合中文字幕在线观看| 国外成人在线视频| 日韩欧美一区视频| 亚洲国产精品久久91精品| 一本色道久久88综合日韩精品| 欧美激情第三页| 91免费高清视频| 九九精品在线播放| 国产精品夜色7777狼人| 国模私拍视频一区| 亚洲欧美国产精品久久久久久久| 一区二区三区四区精品| 97精品国产97久久久久久| 亚洲女人初尝黑人巨大| 亚洲桃花岛网站| 久久久综合免费视频| 欧美大片免费看| 国产精品入口免费视频一| 亚洲精品456在线播放狼人| 亚洲精品成人av| 97在线视频观看| 日韩有码片在线观看| 欧美成人免费全部观看天天性色| 午夜精品久久久久久久99热| 日韩视频在线一区| 久久久久亚洲精品国产| 国产精品免费久久久久影院| 国产精品毛片a∨一区二区三区|国| 亚洲精品白浆高清久久久久久| 日韩大胆人体377p| 国产精品视频999| 欧美中文在线字幕| 日韩免费黄色av| 亚洲视频自拍偷拍| 在线观看日韩av| 亚州国产精品久久久| 久久精品亚洲94久久精品| 亚洲欧美日韩图片| 最新日韩中文字幕| 最新91在线视频| 亚洲激情小视频| 国产精品高精视频免费| 成人久久一区二区| 欧美午夜精品久久久久久浪潮| 国产精品免费一区二区三区都可以| 欧美激情图片区| 亚洲电影免费观看| 中文字幕久热精品在线视频| 中文字幕亚洲一区二区三区五十路| 亚洲va欧美va国产综合剧情| 中文字幕亚洲激情| 亚洲第一黄色网| 国产精品久久久一区| 欧美日韩免费看| 亚洲精品国产品国语在线| 国产精品爽爽ⅴa在线观看| 岛国av在线不卡| 亚洲精品一区中文| 日本成人激情视频| 日本成人在线视频网址| 午夜精品久久久久久久久久久久| 欧美电影在线观看网站| 激情成人中文字幕| 高清欧美性猛交xxxx| 中文字幕亚洲精品| 久久久噜噜噜久久久| 欧美一区二粉嫩精品国产一线天| 欧美国产视频一区二区| 国产精品免费福利| 成人h视频在线观看播放| 国模精品视频一区二区三区| 久久影视三级福利片| 欧美午夜性色大片在线观看| 国产精品视频一| 久久久久日韩精品久久久男男| 欧美猛少妇色xxxxx| 欧美一级大片在线观看| 国产极品jizzhd欧美| 91丝袜美腿美女视频网站| 国产午夜精品免费一区二区三区| 国产一区二区欧美日韩| 欧美成人午夜免费视在线看片| 国产日产欧美精品| 日韩欧美在线网址| 久久久久久久久久亚洲| 国产精品看片资源| 国产成人精品久久| 日韩在线观看免费高清完整版| 国产精品稀缺呦系列在线| 91香蕉国产在线观看| 国产成人啪精品视频免费网| 欧美久久久精品| 久久精品欧美视频| 国产美女被下药99| 日韩中文字幕精品视频| 欧美色xxxx| 91在线视频成人| 亚洲国产成人av在线| 亚洲黄页视频免费观看| 在线观看日韩视频| 欧美性猛交xxxx免费看| 91免费高清视频| 第一福利永久视频精品|