首頁 >資料庫 >SQL >MongoDB – 使用模式建構之屬性模式

MongoDB – 使用模式建構之屬性模式

步履不停
步履不停原創
2019-07-01 16:37:042876瀏覽

MongoDB – 使用模式建構之屬性模式

簡單描述:

直接進入了解屬性模式。它特別適合以下的情況:

  1. 有一個大的文檔,但是它其實擁有一些相似的字段,而且這些字段的一個子集具有相同的特徵,最後其實需要對這些子集欄位進行排序或查詢;
  2. 其實也不是所有文件都會出現需要的排序欄位;
  3. 或上述兩個條件都滿足
    事實上考慮到效能方面的原因,為了優化搜尋可能需要許多索引才能照顧到這些子集。但是創建越多的索引也只會導致效能的下降。屬性模式為這種情況提供了一個很好的解決方案。

實例:

一個訂單資料文檔,其實是有很多需要記錄的時間,例如創建時間,支付時間,發貨時間等等。在設計資料結構的時候當然第一時間就會想到如圖:
MongoDB – 使用模式建構之屬性模式

實際上這種設計在時間類型比較少的情況下是沒有太大問題,但是結合了實際業務場景,一張訂單的時間當然不會太少,有時候為了優化排序,不得不建立相應的所以,現在問題就來的,根據這麼多字段逐個建立索引那可能建立很多,這樣反而會降低整體查詢的效能。那麼這時候使用屬性模式就很適合了。如下圖:

MongoDB – 使用模式建構之屬性模式如果訂單資料結構考慮使用了這種模式後,就不需要重複為相似的欄位子集建立索引,大大提高查詢效率。

結論:

屬性模式針對每個文件中許多類似欄位提供了更簡單的文件索引。透過將這個資料子集移到一個鍵值子文件中,我們可以使用不確定的欄位名,為資訊添加額外的限定符,並更清楚地說明原始欄位和值的關係。當我們使用屬性模式時,由於需要的索引更少,查詢變得更簡單更快。

更多SQL相關技術文章,請造訪SQL教學欄位進行學習!

以上是MongoDB – 使用模式建構之屬性模式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
上一篇:having用法下一篇:having用法

相關文章

看更多