20個資料庫設計的最佳實踐
資料庫設計是整個程式的重點之一,為了支援相關程式執行,最佳的資料庫設計往往不可能一蹴而就,只能反覆探尋並逐步求精,這是一個複雜的過程,也是規劃和結構化資料庫中的資料物件以及這些資料物件之間關係的過程。下面給出了20個資料庫設計最佳實踐,當然,所謂最佳,還是要看它是否適合你的程式。一起來了解了解吧。
- 使用明確、統一的標明和列名,例如 School, SchoolCourse, CourceID。
- 資料表名使用單數而不是複數,例如 StudentCourse,而不是StudentCourses。
- 資料表名不要使用空格。
- 資料表名不要使用不必要的字首或者字尾,例如使用School,而不是TblSchool,或者SchoolTable等等。
- 資料庫中的密碼要加密,到應用中再解密。 (其實就是雜湊儲存、單向加密)
- 使用整數作為ID欄位,也許現在沒有這個必要,但是將來需要,例如關聯表,索引等等。
- 使用整數字段做索引,否則會帶來很大的效能問題 。
- 使用 bit 作為布林欄位,使用整數或者varcha是浪費。同時,這類欄位應該以“Is”開頭。
- 要經過認證才能訪問資料庫,不要給每一個使用者管理員許可權。
- 儘量避免使用“select *”,而使用“select [required_column_list]”以獲得更好的效能。
- 假如程式程式碼比較複雜,使用ORM框架,例如hibernate,iBatis。ORM框架的效能問題可以通過詳細的配置去解決。
- 分割不常使用的資料表到不同的物理儲存以獲得更好的效能。
- 對於關鍵資料庫,使用安全備份系統,例如叢集,同步等等。
- 使用外來鍵,非空等限制來保證資料的完整性,不要把所有的東西都扔給程式。
- 缺乏資料庫文件是致命的。你應該為你的資料庫設計寫文件,包括觸發器、儲存過程和其他指令碼。
- 對於經常使用的查詢和大型資料表,要使用索引。資料分析工具可以幫助你決定如何建立索引。
- 資料庫伺服器和網頁伺服器應該放在不同的機器上。這回提高安全性,並減輕CPU壓力。
- Image和blob欄位不應該定義在常用的資料表中,否則會影響效能。
- 正規化(Normalization)要按照要求使用以提高效能。Normalization做的不夠會導致資料冗餘,而過度Normalization 會導致太多的join和資料表,這兩種情況都會影響效能。
- 多花點時間在資料庫設計上,否則你將來會付出加倍的時間來償還。(oschina.net蟲蟲譯)
英文原址:javacodegeeks.com
相關文章
- 資料庫設計的十個最佳實踐資料庫
- 資料庫設計中的6個最佳實踐步驟資料庫
- 資料庫優化的最佳實踐資料庫優化
- TypeScript 資料模型層程式設計的最佳實踐TypeScript模型程式設計
- PHP最佳實踐之資料庫PHP資料庫
- 13 個設計 REST API 的最佳實踐RESTAPI
- 微服務的【資料庫管理】最佳實踐微服務資料庫
- MySQL資料庫優化的最佳實踐MySql資料庫優化
- 資料庫安全最佳實踐:基本指南資料庫
- Java程式設計師的八個最佳實踐Java程式設計師
- 企業級雲資料庫最佳實踐資料庫
- 設計微服務的最佳實踐微服務
- jQuery程式設計的最佳實踐jQuery程式設計
- 有效資料湖攝取的5個最佳實踐
- Oracle 12c資料庫最佳化器統計資訊收集的最佳實踐(二)Oracle資料庫
- 資料庫伺服器運維最佳實踐資料庫伺服器運維
- 資料庫安全的5個基本實踐資料庫
- Android 中的升級資料庫最佳方法實踐Android資料庫
- 雲時代的資料庫客戶端 —— CloudQuery最佳實踐資料庫客戶端Cloud
- 收集最佳化統計資料(Optimizer Statistics)的最佳實踐方法
- 20 個 OpenSSH 最佳安全實踐
- go 程式設計師的最佳實踐Go程式設計師
- SACC2017:資料庫架構設計與實踐的後半生資料庫架構
- Spring Boot中五個設計模式最佳實踐Spring Boot設計模式
- Java程式設計細節之十個最佳實踐Java程式設計
- 【資料庫設計】資料庫的設計資料庫
- 我拒絕接受的幾個最佳程式設計實踐方法程式設計
- Oracle 12c資料庫優化器統計資訊收集的最佳實踐Oracle資料庫優化
- TiDB 異構資料庫複製最佳實踐TiDB資料庫
- 【BEST】Oracle 資料庫19c配置最佳實踐Oracle資料庫
- 沈劍:58同城資料庫架構最佳實踐資料庫架構
- MySQL資料庫最佳化實踐--硬體方面MySql資料庫
- Oracle收集優化統計資料的最佳實踐方法Oracle優化
- 資料庫設計---即資料庫架構設計的幾個步驟資料庫架構
- react 設計模式與最佳實踐React設計模式
- MaxCompute表設計最佳實踐
- RESTful API 設計指南——最佳實踐RESTAPI
- Android 路由設計最佳實踐Android路由