MongoDB 覆蓋索引查詢
官方的MongoDB的文檔中說明,覆蓋查詢是以下的查詢:
所有的查詢欄位是索引的一部分
所有的查詢返回欄位在同一個索引中
由於所有出現在查詢中的欄位是索引的一部分, MongoDB 無需在整個資料文件中檢索符合查詢條件和傳回使用相同索引的查詢結果。
因為索引存在於RAM中,從索引中取得資料比透過掃描文件讀取資料快得多。
使用覆蓋索引查詢
為了測試蓋索引查詢,使用以下users 集合:
{ "_id": ObjectId("53402597d852426020000002"), "contact": "987654321", "dob": "01-01-1991", "gender": "M", "name": "Tom Benzamin", "user_name": "tombenzamin" }
我們在users 集合中建立聯合索引,欄位為 gender 和user_name :
>db.users.ensureIndex({gender:1,user_name:1})
現在,索引會覆寫以下查詢:
>db.users.find({gender:"M"},{user_name:1,_id:0})
也就是說,對於上述查詢,MongoDB的不會去資料庫檔案中尋找。相反,它會從索引中提取數據,這是非常快速的數據查詢。
由於我們的索引中不包括 _id 字段,_id在查詢中會預設返回,我們可以在MongoDB的查詢結果集中排除它。
下面的實例沒有排除_id,查詢就不會被覆寫:
>db.users.find({gender:"M"},{user_name:1})
最後,如果是以下的查詢,不能使用覆蓋索引查詢:
-
#所有索引欄位是一個陣列
所有索引欄位是一個子文件