范式

范式(數(shù)據(jù)庫(kù)設(shè)計(jì)范式,數(shù)據(jù)庫(kù)的設(shè)計(jì)范式)是符合某一種級(jí)別的關(guān)系模式的集合。構(gòu)造數(shù)據(jù)庫(kù)必須遵循一定的規(guī)則紧唱。在關(guān)系數(shù)據(jù)庫(kù)中评甜,這種規(guī)則就是范式灰粮。關(guān)系數(shù)據(jù)庫(kù)中的關(guān)系必須滿(mǎn)足一定的要求,即滿(mǎn)足不同的范式蜕着。

目前關(guān)系數(shù)據(jù)庫(kù)有六種范式:第一范式(1NF)谋竖、第二范式(2NF)、第三范式(3NF)承匣、Boyce-Codd范式(BCNF)蓖乘、第四范式(4NF)和第五范式(5NF)。

滿(mǎn)足最低要求的范式是第一范式(1NF)韧骗。在第一范式的基礎(chǔ)上進(jìn)一步滿(mǎn)足更多要求的稱(chēng)為第二范式(2NF)嘉抒,其余范式以次類(lèi)推。一般說(shuō)來(lái)袍暴,數(shù)據(jù)庫(kù)只需滿(mǎn)足第三范式(3NF)就行了些侍。

第一范式

每一列不可分割。是對(duì)關(guān)系模式的最基本要求政模。不滿(mǎn)足1NF的數(shù)據(jù)庫(kù)就不是關(guān)系數(shù)據(jù)庫(kù)岗宣。

第二范式

非主屬性完全依賴(lài)于主屬性,不能存在只依賴(lài)主屬性一部分的屬性淋样。
假定選課關(guān)系表為SelectCourse(學(xué)號(hào)耗式,姓名,年齡趁猴,課程名稱(chēng)刊咳,成績(jī),學(xué)分)儡司,關(guān)鍵字為組合關(guān)鍵字(學(xué)號(hào)娱挨,課程名稱(chēng)),因?yàn)榇嬖谌缦聸Q定關(guān)系:
(學(xué)號(hào)捕犬,課程名稱(chēng)) → (姓名跷坝,年齡酵镜,成績(jī),學(xué)分)
這個(gè)數(shù)據(jù)庫(kù)表不滿(mǎn)足第二范式探孝,因?yàn)榇嬖谌缦聸Q定關(guān)系:
(課程名稱(chēng)) → (學(xué)分)
(學(xué)號(hào)) → (姓名笋婿,年齡)
即存在組合關(guān)鍵字中的字段決定非關(guān)鍵字的情況。
由于不符合2NF顿颅,這個(gè)選課關(guān)系表會(huì)存在如下問(wèn)題:

  1. 數(shù)據(jù)冗余:
    同一門(mén)課程由n個(gè)學(xué)生選修缸濒,"學(xué)分"就重復(fù)n-1次;同一個(gè)學(xué)生選修了m門(mén)課程粱腻,姓名和年齡就重復(fù)了m-1次庇配。
  2. 更新異常:
    若調(diào)整了某門(mén)課程的學(xué)分,數(shù)據(jù)表中所有行的"學(xué)分"值都要更新绍些,否則會(huì)出現(xiàn)同一門(mén)課程學(xué)分不同的情況捞慌。
  3. 插入異常:
    假設(shè)要開(kāi)設(shè)一門(mén)新的課程,暫時(shí)還沒(méi)有人選修柬批。這樣啸澡,由于還沒(méi)有"學(xué)號(hào)"關(guān)鍵字,課程名稱(chēng)和學(xué)分也無(wú)法記錄入數(shù)據(jù)庫(kù)氮帐。
  4. 刪除異常:
    假設(shè)一批學(xué)生已經(jīng)完成課程的選修嗅虏,這些選修記錄就應(yīng)該從數(shù)據(jù)庫(kù)表中刪除。但是上沐,與此同時(shí)皮服,課程名稱(chēng)和學(xué)分信息也被刪除了。很顯然参咙,這也會(huì)導(dǎo)致插入異常龄广。
    把選課關(guān)系表SelectCourse改為如下三個(gè)表:
    學(xué)生:Student(學(xué)號(hào),姓名,年齡)蕴侧;
    課程:Course(課程名稱(chēng)择同,學(xué)分);
    選課關(guān)系:SelectCourse(學(xué)號(hào)净宵,課程名稱(chēng)奠衔,成績(jī))。
    這樣的數(shù)據(jù)庫(kù)表是符合第二范式的塘娶, 消除了數(shù)據(jù)冗余、更新異常痊夭、插入異常和刪除異常刁岸。
    另外,所有單關(guān)鍵字的數(shù)據(jù)庫(kù)表都符合第二范式她我,因?yàn)椴豢赡艽嬖诮M合關(guān)鍵字虹曙。

第三范式

每列數(shù)據(jù)都和主鍵直接相關(guān)迫横,不能傳遞依賴(lài)于主鍵。
假定學(xué)生關(guān)系表為Student(學(xué)號(hào)酝碳,姓名矾踱,年齡,所在學(xué)院疏哗,學(xué)院地點(diǎn)呛讲,學(xué)院電話(huà)),關(guān)鍵字為單一關(guān)鍵字"學(xué)號(hào)"返奉,因?yàn)榇嬖谌缦聸Q定關(guān)系:
(學(xué)號(hào)) → (姓名贝搁,年齡,所在學(xué)院芽偏,學(xué)院地點(diǎn)雷逆,學(xué)院電話(huà))
這個(gè)數(shù)據(jù)庫(kù)是符合2NF的,但是不符合3NF污尉,因?yàn)榇嬖谌缦聸Q定關(guān)系:
(學(xué)號(hào)) → (所在學(xué)院) → (學(xué)院地點(diǎn)膀哲,學(xué)院電話(huà))
即存在非關(guān)鍵字段"學(xué)院地點(diǎn)"、"學(xué)院電話(huà)"對(duì)關(guān)鍵字段"學(xué)號(hào)"的傳遞函數(shù)依賴(lài)被碗。
它也會(huì)存在數(shù)據(jù)冗余某宪、更新異常、插入異常和刪除異常的情況蛮放。

把學(xué)生關(guān)系表分為如下兩個(gè)表:
學(xué)生:(學(xué)號(hào)缩抡,姓名,年齡,所在學(xué)院)包颁;
學(xué)院:(學(xué)院瞻想,地點(diǎn),電話(huà))娩嚼。
這樣的數(shù)據(jù)庫(kù)表是符合第三范式的蘑险,消除了數(shù)據(jù)冗余、更新異常岳悟、插入異常和刪除異常佃迄。

BCNF

在3NF基礎(chǔ)上消除主屬性對(duì)于碼的部分與傳遞函數(shù)依賴(lài)。

假設(shè)倉(cāng)庫(kù)管理關(guān)系表為StorehouseManage(倉(cāng)庫(kù)ID,存儲(chǔ)物品ID,管理員ID,數(shù)量)贵少,且有一個(gè)管理員只在一個(gè)倉(cāng)庫(kù)工作呵俏,一個(gè)倉(cāng)庫(kù)可以存儲(chǔ)多種物品。這個(gè)數(shù)據(jù)庫(kù)表中存在如下決定關(guān)系:
(倉(cāng)庫(kù)ID,存儲(chǔ)物品ID) →(管理員ID,數(shù)量)
(管理員ID,存儲(chǔ)物品ID) → (倉(cāng)庫(kù)ID,數(shù)量)
所以(倉(cāng)庫(kù)ID,存儲(chǔ)物品ID)和(管理員ID,存儲(chǔ)物品ID)都是StorehouseManage的候選關(guān)鍵字滔灶,表中的唯一非關(guān)鍵字段為數(shù)量普碎,它是符合第三范式的。但是录平,由于存在如下決定關(guān)系:
(倉(cāng)庫(kù)ID) → (管理員ID)
(管理員ID) → (倉(cāng)庫(kù)ID)
即存在關(guān)鍵字段決定關(guān)鍵字段的情況麻车,所以其不符合BCNF范式缀皱。它會(huì)出現(xiàn)如下異常情況:

  1. 刪除異常:
    當(dāng)倉(cāng)庫(kù)被清空后,所有"存儲(chǔ)物品ID"和"數(shù)量"信息被刪除的同時(shí)动猬,"倉(cāng)庫(kù)ID"和"管理員ID"信息也被刪除了啤斗。
  2. 插入異常:
    當(dāng)倉(cāng)庫(kù)沒(méi)有存儲(chǔ)任何物品時(shí),無(wú)法給倉(cāng)庫(kù)分配管理員赁咙。
  3. 更新異常:
    如果倉(cāng)庫(kù)換了管理員钮莲,則表中所有行的管理員ID都要修改。

把倉(cāng)庫(kù)管理關(guān)系表分解為二個(gè)關(guān)系表:
倉(cāng)庫(kù)管理:StorehouseManage(倉(cāng)庫(kù)ID,管理員ID)序目;
倉(cāng)庫(kù):Storehouse(倉(cāng)庫(kù)ID,存儲(chǔ)物品ID,數(shù)量)臂痕。
這樣的數(shù)據(jù)庫(kù)表是符合BCNF范式的,消除了刪除異常猿涨、插入異常和更新異常握童。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市叛赚,隨后出現(xiàn)的幾起案子澡绩,更是在濱河造成了極大的恐慌,老刑警劉巖俺附,帶你破解...
    沈念sama閱讀 217,657評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件肥卡,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡事镣,警方通過(guò)查閱死者的電腦和手機(jī)步鉴,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)璃哟,“玉大人氛琢,你說(shuō)我怎么就攤上這事∷嫔粒” “怎么了阳似?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,057評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)铐伴。 經(jīng)常有香客問(wèn)我撮奏,道長(zhǎng),這世上最難降的妖魔是什么当宴? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,509評(píng)論 1 293
  • 正文 為了忘掉前任畜吊,我火速辦了婚禮,結(jié)果婚禮上户矢,老公的妹妹穿的比我還像新娘玲献。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,562評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布青自。 她就那樣靜靜地躺著,像睡著了一般驱证。 火紅的嫁衣襯著肌膚如雪延窜。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,443評(píng)論 1 302
  • 那天抹锄,我揣著相機(jī)與錄音逆瑞,去河邊找鬼。 笑死伙单,一個(gè)胖子當(dāng)著我的面吹牛获高,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播吻育,決...
    沈念sama閱讀 40,251評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼念秧,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了布疼?” 一聲冷哼從身側(cè)響起摊趾,我...
    開(kāi)封第一講書(shū)人閱讀 39,129評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎游两,沒(méi)想到半個(gè)月后砾层,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,561評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡贱案,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,779評(píng)論 3 335
  • 正文 我和宋清朗相戀三年肛炮,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片宝踪。...
    茶點(diǎn)故事閱讀 39,902評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡侨糟,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出肴沫,到底是詐尸還是另有隱情粟害,我是刑警寧澤,帶...
    沈念sama閱讀 35,621評(píng)論 5 345
  • 正文 年R本政府宣布颤芬,位于F島的核電站悲幅,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏站蝠。R本人自食惡果不足惜汰具,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,220評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望菱魔。 院中可真熱鬧留荔,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,838評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至碘勉,卻和暖如春巷挥,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背验靡。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,971評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工倍宾, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人胜嗓。 一個(gè)月前我還...
    沈念sama閱讀 48,025評(píng)論 2 370
  • 正文 我出身青樓高职,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親辞州。 傳聞我的和親對(duì)象是個(gè)殘疾皇子怔锌,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,843評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 第一范式(1NF) 強(qiáng)調(diào)的是列的原子性,即列不能夠再分成其他幾列孙技。 考慮這樣一個(gè)表:【聯(lián)系人】(姓名产禾,性別,電話(huà))...
    noonbiteun閱讀 634評(píng)論 0 0
  • 第一范式(1NF): 數(shù)據(jù)表的每一列是基本列牵啦,不可再拆分(下面的表1的結(jié)構(gòu)則不符合第一范式亚情,當(dāng)然,目前在用的各種數(shù)...
    清風(fēng)明月兮丶閱讀 607評(píng)論 0 0
  • 李木頭從九里彎村來(lái)到了這個(gè)城市蹬黃包車(chē)已經(jīng)有半年了哈雏。說(shuō)起黃包車(chē)楞件,當(dāng)然已經(jīng)不是駱駝祥子拉的兩輪人力車(chē)了。時(shí)代在前進(jìn)裳瘪,...
    雷永青閱讀 1,896評(píng)論 2 7
  • 一句雞湯:今天對(duì)生活的種種不滿(mǎn)土浸,都源于曾經(jīng)的不努力。 大概意思如此彭羹,具體的表述實(shí)在記不清了黄伊。 自研究生入學(xué)以來(lái),一...
    日月之約閱讀 385評(píng)論 0 0
  • 文/才下眉頭 我小墨墨就一周歲啦,好嗨皮呀毡惜!回想新手媽咪這一年拓轻,心潮澎湃,不知不覺(jué)就混了一年資歷~~慶幸的是经伙,忙亂...
    132db6d301e0閱讀 847評(píng)論 0 3