数据库设计漫谈之一
第一天:
數據庫設計的時候某數據項能被計算得出,就盡量用計算的方式,而不要增加字段,帶著這種想法設計的數據表如下:
圖1
????如上圖中有“日產量”,“月累產量”,“年累產量”,但是“月累產量”和“年累產量”能通過計算“日產量”得到,所以設計數據表的時候就不要增加“月累產量”和“年累產量”這兩個字段。
簡化后的數據表如下
圖2
????簡化以后再想查詢“月累產量”或者“月累耗電量”就得通過視圖、存儲過程等方式,在減少了工作量的同時又會增加別的工作量。這樣做的優點是數據源單一,一切從基礎字段計算而來,同時缺點是在減少了數據維護工作量的同時又會增加別的工作量(視圖、存儲過程等)。從提高正確性和可擴展性的角度看的話,還是簡化一下好一點。此時問題似乎告一段落。
第二天:
????突然想到要想得到當前的“月累產量”就得知道期初(初始化)的“月累產量”,在期初“月累產量”的基礎之上再加上本月的日產量才能得到當前的“月累產量”。
如此一來就面臨兩種選擇,第一種選擇就是另外維護一張表記錄期初的“月累產量”,這樣做不僅做到簡化的作用,反而又加了一張表。
第二種選擇就是將已經刪除的“月累產量”(當然也包括“年累產量”等等)這些字段都恢復就是回到圖1。在初始化的時候設定初始“月累產量”就可以了。在每新增一條產量數據時,計算公式為當前“月累產量”=期初“月累產量”+Sum(日產量)。
造成這種情形的原因是因為我沒有想清楚“月累產量”其實也是基礎計算公式中的一部分,而非計算結果,做為函數中的自變量當然不能刪除。
如果在此基礎再計算當前“日產量”在當前“月累產量”(日產量/月累產量)中的百分比,就可以直接用計算字段來表示了。
結論是,分清楚那些基礎字段(本例中的“月累產量”是基礎字段,要作為公式中的變量來使用)。對于可以通過計算衍生出來的字段就完全可以被簡化掉了(本例中的日產量/月累產量)。
轉載于:https://www.cnblogs.com/anshangcun/archive/2007/10/10/919849.html
總結
- 上一篇: 关于如何破坏单例我说了好几种方式,面试官
- 下一篇: 性能对比:Count(字段)、Count