<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    理解數(shù)據(jù)庫范式
    系統(tǒng)是短暫的
    數(shù)據(jù)是永恒的
    數(shù) 據(jù)庫范式是數(shù)據(jù)庫設(shè)計(jì)中必不可少的知識,沒有對范式的理解,就無法設(shè)計(jì)出高效率、優(yōu)雅的數(shù)據(jù)庫。甚至設(shè)計(jì)出錯誤的數(shù)據(jù)庫。而想要理解并掌握范式卻并不是那 么容易。教科書中一般以關(guān)系代數(shù)的方法來解釋數(shù)據(jù)庫范式。這樣做雖然能夠十分準(zhǔn)確的表達(dá)數(shù)據(jù)庫范式,但比較抽象,不太直觀,不便于理解,更難以記憶。

    本 文用較為直白的語言介紹范式,旨在便于理解和記憶,這樣做可能會出現(xiàn)一些不精確的表述。但對于初學(xué)者應(yīng)該是個不錯的入門。我寫下這些的目的主要是為了加強(qiáng) 記憶,其實(shí)我也比較菜,我希望當(dāng)我對一些概念生疏的時(shí)候,回過頭來看看自己寫的筆記,可以快速地進(jìn)入狀態(tài)。如果你發(fā)現(xiàn)其中用錯誤,請指正。

           下面開始進(jìn)入正題:

    一、基礎(chǔ)概念

    要理解范式,首先必須對知道什么是關(guān)系數(shù)據(jù)庫,如果你不知道,我可以簡單的不能再簡單的說一下:關(guān)系數(shù)據(jù)庫就是用二維表來保存數(shù)據(jù)。表和表之間可以……(省略10W字)。

    然后你應(yīng)該理解以下概念:

    實(shí)體:現(xiàn)實(shí)世界中客觀存在并可以被區(qū)別的事物。比如“一個學(xué)生”、“一本書”、“一門課”等等。值得強(qiáng)調(diào)的是這里所說的“事物”不僅僅是看得見摸得著的“東西”,它也可以是虛擬的,不如說“老師與學(xué)校的關(guān)系”。

     
    屬性:教科書上解釋為:“實(shí)體所具有的某一特性”,由此可見,屬性一開始是個邏輯概念,比如說,“性別”是“人”的一個屬性。在關(guān)系數(shù)據(jù)庫中,屬性又是個物理概念,屬性可以看作是“表的一列”。

     
    元組:表中的一行就是一個元組。

     
    分量:元組的某個屬性值。在一個關(guān)系數(shù)據(jù)庫中,它是一個操作原子,即關(guān)系數(shù)據(jù)庫在做任何操作的時(shí)候,屬性是“不可分的”。否則就不是關(guān)系數(shù)據(jù)庫了。

     
    碼:表中可以唯一確定一個元組的某個屬性(或者屬性組),如果這樣的碼有不止一個,那么大家都叫候選碼,我們從候選碼中挑一個出來做老大,它就叫主碼。
     
    全碼:如果一個碼包含了所有的屬性,這個碼就是全碼。

     
    主屬性:一個屬性只要在任何一個候選碼中出現(xiàn)過,這個屬性就是主屬性。

     
    非主屬性:與上面相反,沒有在任何候選碼中出現(xiàn)過,這個屬性就是非主屬性。

     
    外碼:一個屬性(或?qū)傩越M),它不是碼,但是它別的表的碼,它就是外碼。

     
    二、6個范式

    好了,上面已經(jīng)介紹了我們掌握范式所需要的全部基礎(chǔ)概念,下面我們就來講范式。首先要明白,范式的包含關(guān)系。一個數(shù)據(jù)庫設(shè)計(jì)如果符合第二范式,一定也符合第一范式。如果符合第三范式,一定也符合第二范式…

     
     
     
    第一范式(1NF):屬性不可分。
    在前面我們已經(jīng)介紹了屬性值的概念,我們說,它是“不可分的”。而第一范式要求屬性也不可分。那么它和屬性值不可分有什么區(qū)別呢?給一個例子:

    name
     tel
     age
     
    大寶
     13612345678
     22
     
    小明
     13988776655
     010-1234567
     21
     
           

    Ps:這個表中,屬性值“分”了。

    name
     tel
     age
     
    手機(jī)
     座機(jī)
     
    大寶
     13612345678
     021-9876543
     22
     
    小明
     13988776655
     010-1234567
     21
     

    Ps:這個表中,屬性 “分”了。

    這兩種情況都不滿足第一范式。不滿足第一范式的數(shù)據(jù)庫,不是關(guān)系數(shù)據(jù)庫!所以,我們在任何關(guān)系數(shù)據(jù)庫管理系統(tǒng)中,做不出這樣的“表”來。

     
     
     
    第二范式(2NF):符合1NF,并且,非主屬性完全依賴于碼。
    聽起來好像很神秘,其實(shí)真的沒什么。

    一 個候選碼中的主屬性也可能是好幾個。如果一個主屬性,它不能單獨(dú)做為一個候選碼,那么它也不能確定任何一個非主屬性。給一個反例:我們考慮一個小學(xué)的教務(wù) 管理系統(tǒng),學(xué)生上課指定一個老師,一本教材,一個教室,一個時(shí)間,大家都上課去吧,沒有問題。那么數(shù)據(jù)庫怎么設(shè)計(jì)?(學(xué)生上課表)

    學(xué)生
     課程
     老師
     老師職稱
     教材
     教室
     上課時(shí)間
     
    小明
     一年級語文(上)
     大寶
     副教授
     《小學(xué)語文1》
     101
     14:30
     

    一個學(xué)生上一門課,一定在特定某個教室。所以有(學(xué)生,課程)->教室

    一個學(xué)生上一門課,一定是特定某個老師教。所以有(學(xué)生,課程)->老師

    一個學(xué)生上一門課,他老師的職稱可以確定。所以有(學(xué)生,課程)->老師職稱

    一個學(xué)生上一門課,一定是特定某個教材。所以有(學(xué)生,課程)->教材

    一個學(xué)生上一門課,一定在特定時(shí)間。所以有(學(xué)生,課程)->上課時(shí)間

    因此(學(xué)生,課程)是一個碼。

    然而,一個課程,一定指定了某個教材,一年級語文肯定用的是《小學(xué)語文1》,那么就有課程->教材。(學(xué)生,課程)是個碼,課程卻決定了教材,這就叫做不完全依賴,或者說部分依賴。出現(xiàn)這樣的情況,就不滿足第二范式!

    有什么不好嗎?你可以想想:

    1、             校長要新增加一門課程叫“微積分”,教材是《大學(xué)數(shù)學(xué)》,怎么辦?學(xué)生還沒選課,而學(xué)生又是主屬性,主屬性不能空,課程怎么記錄呢,教材記到哪呢? ……郁悶了吧?(插入異常)

    2、             下學(xué)期沒學(xué)生學(xué)一年級語文(上)了,學(xué)一年級語文(下)去了,那么表中將不存在一年級語文(上),也就沒了《小學(xué)語文1》。這時(shí)候,校長問:一年級語文(上)用的什么教材啊?……郁悶了吧?(刪除異常)

    3、             校長說:一年級語文(上)換教材,換成《大學(xué)語文》。有10000個學(xué)生選了這么課,改動好大啊!改累死了……郁悶了吧?(修改異常)

    那應(yīng)該怎么解決呢?投影分解,將一個表分解成兩個或若干個表

    學(xué)生
     課程
     老師
     老師職稱
     教室
     上課時(shí)間
     
    小明
     一年級語文(上)
     大寶
     副教授
     101
     14:30
     

    學(xué)生上課表新

    課程
     教材
     
    一年級語文(上)
     《小學(xué)語文1》
     

    課程的表

     
     
    第三范式(3NF):符合2NF,并且,消除傳遞依賴
    上面的“學(xué)生上課表新”符合2NF,可以這樣驗(yàn)證:兩個主屬性單獨(dú)使用,不用確定其它四個非主屬性的任何一個。但是它有傳遞依賴!

    在哪呢?問題就出在“老師”和“老師職稱”這里。一個老師一定能確定一個老師職稱。

    有什么問題嗎?想想:

    1、  老師升級了,變教授了,要改數(shù)據(jù)庫,表中有N條,改了N次……(修改異常)

    2、  沒人選這個老師的課了,老師的職稱也沒了記錄……(刪除異常)
    3、  新來一個老師,還沒分配教什么課,他的職稱記到哪?……(插入異常)
    那應(yīng)該怎么解決呢?和上面一樣,投影分解:

    學(xué)生
     課程
     老師
     教室
     上課時(shí)間
     
    小明
     一年級語文(上)
     大寶
     101
     14:30
     

     
    老師
     老師職稱
     
    大寶
     副教授
     

     
    BC范式(BCNF):符合3NF,并且,主屬性不依賴于主屬性
    若關(guān)系模式屬于第一范式,且每個屬性都不傳遞依賴于鍵碼,則R屬于BC范式。

    通常BC范式的條件有多種等價(jià)的表述:每個非平凡依賴的左邊必須包含鍵碼;每個決定因素必須包含鍵碼。

    BC范式既檢查非主屬性,又檢查主屬性。當(dāng)只檢查非主屬性時(shí),就成了第三范式。滿足BC范式的關(guān)系都必然滿足第三范式。

    還可以這么說:若一個關(guān)系達(dá)到了第三范式,并且它只有一個候選碼,或者它的每個候選碼都是單屬性,則該關(guān)系自然達(dá)到BC范式。

     
    一般,一個數(shù)據(jù)庫設(shè)計(jì)符合3NF或BCNF就可以了。在BC范式以上還有第四范式、第五范式。

    第四范式:要求把同一表內(nèi)的多對多關(guān)系刪除。

    第五范式:從最終結(jié)構(gòu)重新建立原始結(jié)構(gòu)。
    但在絕大多數(shù)應(yīng)用中不需要設(shè)計(jì)到這種程度。并且,某些情況下,過于范式化甚至?xí)?shù)據(jù)庫的邏輯可讀性和使用效率起到阻礙。數(shù)據(jù)庫中一定程度的冗余并不一定是壞事情。如果你對第四范式、第五范式感興趣可以看一看專業(yè)教材,從頭學(xué)起,并且忘記我說的一切,以免對你產(chǎn)生誤導(dǎo)。

     

    posted on 2011-03-04 17:23 sanmao 閱讀(752) 評論(2)  編輯  收藏

    FeedBack:
    # re: 數(shù)據(jù)庫范式|數(shù)據(jù)庫第一范式|數(shù)據(jù)庫第二范式
    2012-01-07 12:52 | user88
    小兄弟,你連1NF都沒搞明白,就胡亂的說話,不怕貽笑大方?  回復(fù)  更多評論
      
    # re: 數(shù)據(jù)庫范式|數(shù)據(jù)庫第一范式|數(shù)據(jù)庫第二范式
    2012-01-07 12:58 | user88
    " 我們在任何關(guān)系數(shù)據(jù)庫管理系統(tǒng)中,做不出這樣的“表”來。" --你對1NF的理解,我告訴你:
    name tel age
    大寶 13612345678 22
    小明 13988776655 , 010-1234567 21

    你想想看,你難道不能在TEL字段里,沒輸入 13988776655 , 010-1234567 嗎?二者中間可以加個空格,逗號或者分號都可以的。但是你必須從 語言的角度來理解這個1NF的定義(上例就是你所說的不屬性值分了),它是不滿足1NF的。
    所以,你千萬別再說什么“我們在任何關(guān)系數(shù)據(jù)庫管理系統(tǒng)中,做不出這樣的“表”來。" ”這樣可笑的話了!

      回復(fù)  更多評論
      

    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導(dǎo)航:
     

    常用鏈接

    留言簿(5)

    隨筆分類

    隨筆檔案

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 91热成人精品国产免费| 亚洲中文字幕久久精品蜜桃| 亚洲色大成网站WWW久久九九| 国产美女精品久久久久久久免费| 国产成人福利免费视频| 1000部无遮挡拍拍拍免费视频观看| 在线观看免费黄色网址| 两个人日本免费完整版在线观看1| 一级日本高清视频免费观看| 野花视频在线官网免费1| 亚洲欧美在线x视频| 欧美亚洲国产SUV| 综合偷自拍亚洲乱中文字幕 | 1000部夫妻午夜免费| 最近2019免费中文字幕6| 8x8×在线永久免费视频| 亚洲一级免费毛片| 国产成人无码免费看视频软件| 国产麻豆视频免费观看| 性一交一乱一视频免费看| 国产青草视频免费观看97| 亚洲成a人片在线观看老师| 国产L精品国产亚洲区久久| 77777亚洲午夜久久多人| 国产成人亚洲综合无码精品| 亚洲av无码专区在线播放| 亚洲一卡2卡三卡4卡有限公司| 亚洲系列中文字幕| 国产精品亚洲一区二区麻豆| 亚洲精品乱码久久久久久蜜桃图片| 成人亚洲国产精品久久| jizz在线免费观看| 久久久精品免费视频| 麻豆视频免费播放| 日韩毛片免费在线观看| 亚洲精品国产高清嫩草影院| 亚洲AV无码成人精品区天堂| 亚洲国产成+人+综合| 久久精品国产亚洲av品善| 国产精品青草视频免费播放| 亚洲免费在线视频|