數(shù) 據(jù)庫設(shè)計是整個程序的重點之一,為了支持相關(guān)程序運行,最佳的數(shù)據(jù)庫設(shè)計往往不可能一蹴而就,只能反復(fù)探尋并逐步求精,這是一個復(fù)雜的過程,也是規(guī)劃和結(jié) 構(gòu)化數(shù)據(jù)庫中的數(shù)據(jù)對象以及這些數(shù)據(jù)對象之間關(guān)系的過程。下面給出了20個數(shù)據(jù)庫設(shè)計最佳實踐,當(dāng)然,所謂最佳,還是要看它是否適合你的程序。一起來了解 了解吧。
?
- 使用明確、統(tǒng)一的標明和列名,例如 School, SchoolCourse, CourceID。
- 數(shù)據(jù)表名使用單數(shù)而不是復(fù)數(shù),例如 StudentCourse,而不是StudentCourses。
- 數(shù)據(jù)表名不要使用空格。
- 數(shù)據(jù)表名不要使用不必要的前綴或者后綴,例如使用School,而不是TblSchool,或者SchoolTable等等。
- 數(shù)據(jù)庫中的密碼要加密,到應(yīng)用中再解密。 (其實就是散列存儲、單向加密)
- 使用整數(shù)作為ID字段,也許現(xiàn)在沒有這個必要,但是將來需要,例如關(guān)聯(lián)表,索引等等。
- 使用整數(shù)字段做索引,否則會帶來很大的性能問題 。
- 使用 bit 作為布爾字段,使用整數(shù)或者varcha是浪費。同時,這類字段應(yīng)該以“Is”開頭。
- 要經(jīng)過認證才能訪問數(shù)據(jù)庫,不要給每一個用戶管理員權(quán)限。
- 盡量避免使用“select *”,而使用“select [required_column_list]”以獲得更好的性能。
- 假如程序代碼比較復(fù)雜,使用ORM框架,例如hibernate,iBatis。ORM框架的性能問題可以通過詳細的配置去解決。
- 分割不常使用的數(shù)據(jù)表到不同的物理存儲以獲得更好的性能。
- 對于關(guān)鍵數(shù)據(jù)庫,使用安全備份系統(tǒng),例如集群,同步等等。
- 使用外鍵,非空等限制來保證數(shù)據(jù)的完整性,不要把所有的東西都扔給程序。
- 缺乏數(shù)據(jù)庫文檔是致命的。你應(yīng)該為你的數(shù)據(jù)庫設(shè)計寫文檔,包括觸發(fā)器、存儲過程和其他腳本。
- 對于經(jīng)常使用的查詢和大型數(shù)據(jù)表,要使用索引。數(shù)據(jù)分析工具可以幫助你決定如何建立索引。
- 數(shù)據(jù)庫服務(wù)器和網(wǎng)頁服務(wù)器應(yīng)該放在不同的機器上。這回提高安全性,并減輕CPU壓力。
- Image和blob字段不應(yīng)該定義在常用的數(shù)據(jù)表中,否則會影響性能。
- 范式(Normalization)要按照要求使用以提高性能。Normalization做的不夠會導(dǎo)致數(shù)據(jù)冗余,而過度Normalization 會導(dǎo)致太多的join和數(shù)據(jù)表,這兩種情況都會影響性能。
- 多花點時間在數(shù)據(jù)庫設(shè)計上,否則你將來會付出加倍的時間來償還。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
