日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java学习笔记:数据库中的范式和反范式

發(fā)布時間:2024/9/30 java 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java学习笔记:数据库中的范式和反范式 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

范式是關系數(shù)據(jù)庫理論的基礎,也是我們在設計數(shù)據(jù)庫結(jié)構(gòu)過程中所要遵循的規(guī)則和指導方法。數(shù)據(jù)庫的設計范式是數(shù)據(jù)庫設計所需要滿足的規(guī)范。只有理解數(shù)據(jù)庫的設計范式,才能設計出率、優(yōu)雅的數(shù)據(jù)庫,否則可能會設計出錯誤的數(shù)據(jù)庫。

反范式,不滿足范式的模型,就是反范式模型。反范式跟范式所要求的正好相反,在反范式的設計模式,我們可以允許適當?shù)臄?shù)據(jù)的冗余,用這個冗余去取操作數(shù)據(jù)時間的縮短。本質(zhì)上就是用空間來換取時間,把數(shù)據(jù)冗余在多個表中,當查詢時可以減少或者是避免表之間的關聯(lián)。

RDBMS模型設計過程中,常常使用范式約束我們的模型,但在NOSQL模型中則大量采用反范式。

數(shù)據(jù)庫中范式和反范式的的主要區(qū)別在于:

在范式化的數(shù)據(jù)庫中,每個事實數(shù)據(jù)會出現(xiàn)并且只出現(xiàn)一次;相反,在反范式化的數(shù)據(jù)庫中,信息是冗余的,可能會存儲在多個地方。

范式化的優(yōu)點:

1)范式化的新操作通常比反范式化要快。

2)當數(shù)據(jù)較好地范式化時,就只有很少或者沒有重復數(shù)據(jù),所以只需要修改少的數(shù)據(jù)。

3)范式化的表通常小,可以好地放在內(nèi)存里,所以執(zhí)行操作會快。

4)很少有多余的數(shù)據(jù)意味著檢索列表數(shù)據(jù)時少需要DISTINCT或者GROUP BY語句。

范式化設計的schema的缺點是通常需要關聯(lián),較多的關聯(lián)可能使得一些索引策略無效,例如,范式化可能將列存放在不同的表中,而這些列如果在一個表中本可以屬于同一個索引。

反范式的schema因為所有數(shù)據(jù)都在一張表中,可以很好地避免關聯(lián)。缺點是update操作的代價高,需要新多個表,至于這會不會是一個問題,需要考慮新的頻率以及新的時長,并和執(zhí)行select查詢的頻率進行比較。

從另一個父表冗余一些數(shù)據(jù)到子表的理由通常是排序的需要。

緩存衍生值也是有用的。如果需要顯示每個用戶發(fā)了多少消息(像很多論壇做的),可以每次執(zhí)行一個昂貴的子查詢來計算并顯示它;也可以在user表中建一個num_messages列,每當用戶發(fā)新消息時新這個值。

本文來自千鋒教育,轉(zhuǎn)載請注明出處。

與50位技術專家面對面20年技術見證,附贈技術全景圖

總結(jié)

以上是生活随笔為你收集整理的Java学习笔记:数据库中的范式和反范式的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。