



下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、數(shù)據(jù)庫設(shè)計核心原則羅代均一、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、計技巧1.確保表中沒有計算字段計算字段的值,是由其他字段的值計算而來,當(dāng)你更新其他字段的時候,很容易忽略同時更新這個計算字段,造成數(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)計,有利于保證數(shù)據(jù)的完整性。三數(shù)據(jù)表設(shè)計技巧1.為表內(nèi)的每一個字段添加表名縮寫例如客戶表customer cust_id cust_name cust_type cust_city .這樣書寫SQL語句時,很容易就知道這個字段屬于哪個表,代表什么含義。例如cust_city ,就不會和employee表
4、的emp_city混淆了。2.為每一個表添加如下字段last_update_by 最后修改人last_update_date 最后修改時間這樣方便以后數(shù)據(jù)錯誤時,查找相關(guān)責(zé)任人,以及錯誤發(fā)生時間。3.添加刪除標(biāo)記字段在關(guān)系數(shù)據(jù)庫中,表之間的關(guān)系錯綜復(fù)雜,刪除一條記錄,往往會影響很多其他的表,建議添加刪除標(biāo)記字段,刪除數(shù)據(jù)時,只是將這行標(biāo)志為刪除即可。例如,客戶表(customercust_id cust_name status001 羅代均A A:Active,活動的,有效的002 羅曾英I I:Inactive ,無效的其他的表,比如送貨單,里面有cust_id,如果我們將002客戶刪除,那
5、么這張送貨單也就不能查看了.刪除002客戶時,只需要將其狀態(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)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 金融投資公司股權(quán)合并與風(fēng)險控制協(xié)議
- 智能停車場車位管理系統(tǒng)功能增強(qiáng)與系統(tǒng)升級補(bǔ)充協(xié)議
- 子女撫養(yǎng)權(quán)變更及監(jiān)護(hù)責(zé)任調(diào)整補(bǔ)充協(xié)議
- 外籍教師職業(yè)發(fā)展規(guī)劃與培訓(xùn)合同
- 高科技工業(yè)廠房土地年限續(xù)期與設(shè)備更新及租賃合同
- 生物醫(yī)學(xué)影像技術(shù)實(shí)驗(yàn)室共建與臨床轉(zhuǎn)化協(xié)議
- 第二學(xué)期幼兒園數(shù)學(xué)活動計劃
- 四年級音樂教學(xué)資源整合計劃
- 城市公共設(shè)施資金投入計劃
- 2025年半自動精密印刷機(jī)項(xiàng)目申請報告
- 2025團(tuán)員考試試題及答案
- 2025年全國防災(zāi)減災(zāi)日專題培訓(xùn)課件
- 2025-2030中國氯氧化鉍行業(yè)市場發(fā)展趨勢與前景展望戰(zhàn)略研究報告
- 視頻監(jiān)控介紹課件
- 2025年軟件測試工程師考試題及答案
- 血管內(nèi)導(dǎo)管相關(guān)性血流感染預(yù)防與診治指南(2025)解讀課件
- 2025年高考數(shù)學(xué)考前最后一課
- 茶葉加工考試題及答案
- 跨學(xué)科實(shí)踐制作微型密度計人教版物理八年級下學(xué)期
- 2025屆高考語文作文備考之審題立意30道選擇題訓(xùn)練(附答案)
- 21. 三黑和土地 課件
評論
0/150
提交評論