国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

數據庫正規化和設計技巧(2)

2024-07-21 02:11:01
字體:
來源:轉載
供稿:網友
菜鳥學堂:
第二級正規化形式

  1.為應用在多條記錄的字段建立獨立的表格

  2.通過一個foreign key來關聯這些表格的值


  我們將url的值放在一個獨立的表格中,這樣我們就可以在以后加入更多的數據,而無需擔心產生重復的值。我們還通過主鍵值來關聯這些字段:

  users

  userid name company company_address

  1 joe abc 1 work lane

  2 jill xyz 1 job street

  urls

  urlid reluserid url

  1 1 abc.com

  2 1 xyz.com

  3 2 abc.com

  4 2 xyz.com

  如上所示,我們創建了獨立的表格,users表中的主鍵userid現在與url表中的foreign key reluserid關聯。現在的情況好象已經得到了明顯的改善。不過,如果我們要為abc公司加入一個員工記錄呢?或者更多,200個?這樣我們就必須重
復使用公司名和地址,這明顯不夠冗余。因此我們將應用第三級正規化方法:

  第三級正規化形式

  1.消除不依賴于該鍵的字段

  公司名及地址與user id都是沒有關系的,因此它們應用擁有自己的公司id:

  users

  userid name relcompid

  1 joe 1

  2 jill 2

  companies

  compid company company_address

  1 abc 1 work lane

  2 xyz 1 job street

  urls

  urlid reluserid url

  1 1 abc.com

  2 1 xyz.com

  3 2 abc.com

  4 2 xyz.com

  這樣我們就將companies表中的主鍵comid和users表中名字為relcompid的foreign key關聯起來,就算為abc公司加入200個員工,在companies中也只有一條記錄。我們的users和urls表可以不斷地擴大,而無需擔心插入不必要的數據。大部
分的開發者都認為經過三步的正規化就足夠了,這個數據庫的設計已經可以很方便地處理整個企業的負擔,此看法在大多數的情況下是正確的。

  我們可以留意一下url的字段--你注意到數據的冗余了嗎?如果給用戶用戶輸入這些url數據的html頁面是一個文本框,可任意輸入的話,這并沒有問題,兩個用戶輸入同樣收藏夾的概率較少,不過,如果是通過一個下拉式的菜單,只讓用戶選擇兩個url輸入,或者更多一點。這種情況下,我們的數據庫還可以進行下一級別的優化--第四步,對于大多數的開發者來說,這一步都是忽略的,因為它要依賴一個很特別的關系--一個多對多的關系,這在我們的應用中是還沒有遇到過的
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 体育| 大洼县| 磴口县| 平南县| 札达县| 保靖县| 彝良县| 广宁县| 天津市| 德化县| 孟州市| 宝兴县| 新兴县| 兴山县| 阳江市| 当雄县| 宁津县| 德州市| 通道| 江安县| 仙桃市| 苍南县| 都兰县| 茂名市| 金门县| 密云县| 彭山县| 云和县| 海晏县| 嫩江县| 璧山县| 大同市| 平度市| 万州区| 读书| 漳浦县| 繁昌县| 罗源县| 开原市| 宝坻区| 云阳县|