



下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、數(shù)據(jù)庫設(shè)計(jì)核心原則羅代均一、3NF第三范式通常認(rèn)為,第三范式在性能,擴(kuò)展性和數(shù)據(jù)完整性方面達(dá)到了最好平衡. 通常認(rèn)為,第三范式在性能,擴(kuò)展性和數(shù)據(jù)完整性方面達(dá)到了最好平衡.有以下幾個要點(diǎn)。有以下幾個要點(diǎn)。1.一個表只描述一個單一的事物(實(shí)體。一個表只描述一個單一的事物2.表內(nèi)的每一個值在整個數(shù)據(jù)庫只出現(xiàn)一次(外鍵除外2.表內(nèi)的每一個值在整個數(shù)據(jù)庫只出現(xiàn)一次(外鍵除外。表內(nèi)的每一個值在整個數(shù)據(jù)庫只出現(xiàn)一次3.表內(nèi)的每一行都應(yīng)該被唯一的標(biāo)識(有唯一主鍵。3.表內(nèi)的每一行都應(yīng)該被唯一的標(biāo)識(有唯一主鍵。表內(nèi)的每一行都應(yīng)該被唯一的標(biāo)識4.表內(nèi)不存儲與主鍵無關(guān)的信息。表內(nèi)不存儲與主鍵無關(guān)的信息二、字段設(shè)
2、計(jì)技巧1.確保表中沒有計(jì)算字段計(jì)算字段的值,是由其他字段的值計(jì)算而來,當(dāng)你更新其他字段的時(shí)候,很容易忽略同時(shí)更新這個計(jì)算字段,造成數(shù)據(jù)的錯誤。2.確保這個字段的值只有一個例如下表Users:用戶ID 用戶名稱電話號碼001 robin 1358888888/028-*/電話號碼的值就不只一個,因此電話字段不能放在users表中,解決辦法是增加一個表Phone 電話號碼ID 用戶ID 電話號碼001 001 13588888 002 001 028-888888這個表就是Users的從表,用戶ID是外鍵. 還有地址address,和電話的情況類似。3.盡可能地細(xì)分字段如下雇員表(employee
3、雇員ID 雇員名稱地址emp_id emp_name emp_address 001 Robin四川省成都市高新區(qū)天泰路1號這里的emp_address就可以細(xì)分,改進(jìn)的表如下雇員ID 雇員名稱國家省/直轄市地/市001 羅代均china 四川成都區(qū)/縣高新區(qū)街道天泰路1號這樣更方便我們編輯和統(tǒng)計(jì),有利于保證數(shù)據(jù)的完整性。三數(shù)據(jù)表設(shè)計(jì)技巧1.為表內(nèi)的每一個字段添加表名縮寫例如客戶表customer cust_id cust_name cust_type cust_city .這樣書寫SQL語句時(shí),很容易就知道這個字段屬于哪個表,代表什么含義。例如cust_city ,就不會和employee表
4、的emp_city混淆了。2.為每一個表添加如下字段last_update_by 最后修改人last_update_date 最后修改時(shí)間這樣方便以后數(shù)據(jù)錯誤時(shí),查找相關(guān)責(zé)任人,以及錯誤發(fā)生時(shí)間。3.添加刪除標(biāo)記字段在關(guān)系數(shù)據(jù)庫中,表之間的關(guān)系錯綜復(fù)雜,刪除一條記錄,往往會影響很多其他的表,建議添加刪除標(biāo)記字段,刪除數(shù)據(jù)時(shí),只是將這行標(biāo)志為刪除即可。例如,客戶表(customercust_id cust_name status001 羅代均A A:Active,活動的,有效的002 羅曾英I I:Inactive ,無效的其他的表,比如送貨單,里面有cust_id,如果我們將002客戶刪除,那
5、么這張送貨單也就不能查看了.刪除002客戶時(shí),只需要將其狀態(tài)更改為I即可. 我們還可以編寫單獨(dú)的數(shù)據(jù)清除程序,將這些標(biāo)記為刪除的數(shù)據(jù)刪除,或者移入歷史數(shù)據(jù)庫中等。4.使用無業(yè)務(wù)含義的數(shù)字作為主鍵首先,關(guān)系數(shù)據(jù)庫中,一個表的主鍵往往會被其它表引用(外鍵.因此, 任何情況下,都不能允許主鍵字段被修改.否則,相關(guān)表的記錄都要相應(yīng)的修改,這真是噩夢.而且,任何有業(yè)務(wù)含義的字段,都有被修改的可能,因此不能作為主鍵, 當(dāng)然,為了保證數(shù)據(jù)的完整性,我們可以為必須唯一的字段(可能是一個,或者多個,添加唯一索引.最后,從性能考慮,還有什么比數(shù)字查詢效率更高呢?這點(diǎn)對于多表連接查詢非常重要。例如,以前有些系統(tǒng)使用身份證號碼作為主鍵,但是后來身份證由15 位升為18位,這些系統(tǒng)就面臨噩夢了!因此,建議為表添加無業(yè)務(wù)含義的數(shù)字作為主鍵,SQL Server,MySQL 可以用自增字段, Oracle可以用序列sequence.5.別忘記為外鍵添加索引大家都知道,系統(tǒng)會自動為主鍵添加唯一索引。但是外鍵,需要我們手動添加索引。6.將表的公共部分,導(dǎo)出成一張表,作為其他模塊交互的接口。如果表的結(jié)構(gòu)經(jīng)常變化,那么將這個表中公共的部分抽取出來,單獨(dú)作為一張表,這樣,對表結(jié)構(gòu)的修改,就不會影響到其它關(guān)聯(lián)的模塊。例如:將客戶表customer表拆分customer_basic和customer_oth
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 安全管理體系建設(shè)試題及答案
- 小學(xué)教師教學(xué)反思與問題解決的考核
- 注冊土木工程師考試知識整合試題及答案
- 客服邏輯思維試題及答案
- 幼兒園數(shù)學(xué)重點(diǎn)考查題及答案分享
- 深入研究2025年樂理考試的試卷結(jié)構(gòu)試題及答案
- 深入分析新能源汽車的技術(shù)試題及答案
- 測試測試題及答案
- 管理工具試題及答案
- 姜堰語文面試題及答案
- 七下生物考試試卷及答案
- 財(cái)產(chǎn)險(xiǎn)試題庫及答案
- 湖南新高考教學(xué)教研聯(lián)盟暨長郡二十校聯(lián)盟2025屆高三年級第二次聯(lián)考物理試題及答案
- 商品出庫管理規(guī)范
- 2025山東煙臺市蓬萊區(qū)城市建設(shè)投資集團(tuán)有限公司招聘22人筆試參考題庫附帶答案詳解
- 建筑勞務(wù)公司人事管理制度
- 應(yīng)聘人員登記表
- 2024年山東省公共衛(wèi)生臨床中心招聘筆試真題
- 2025年全國二模日語試題及答案
- 眼科學(xué)考試試題題庫
- 傷殘鑒定 委托書
評論
0/150
提交評論