MongoDB文字搜尋


MongoDB 2.4版開始,MongoDB開始支援文字索引來搜尋字串內容。文字搜尋使用詞法技術通過刪除字串字詞,如aan等等來查詢字串欄位中的指定單詞。目前,MongoDB支援大約15種語言。

啟用文字搜尋

最初,文字搜尋是一個實驗性功能,但從MongoDB 2.4版開始,預設情況下啟用組態。 但是,如果使用2.4之前版本的MongoDB,則必須使用以下程式碼啟用文字搜尋 -

>db.adminCommand({setParameter:true,textSearchEnabled:true})

建立文字索引

請考慮以下文件,其中包含貼文文字及其標籤 -

{
   "post_text": "enjoy the mongodb articles on yiibai tutorials",
   "tags": [
      "mongodb",
      "yiibai tutorials"
   ]
}

我們將在post_text欄位上建立一個文字索引,以便可以在posts的文字中搜尋 -

>db.posts.ensureIndex({post_text:"text"})

使用文字索引

現在我們已經在post_text欄位上建立了文字索引,下面在其文字中搜尋所有帶有「yiibai」一詞的貼文。

>db.posts.find({$text:{$search:"yiibai"}})

上述命令返回以下結果檔案,其文字中包含「yiibai」一詞 -

{ 
   "_id" : ObjectId("595b99e2f6a6243715b3c316"), 
   "post_text" : "enjoy the mongodb articles on yiibai", 
   "tags" : [ "mongodb", "yiibai" ]
}
{
   "_id" : ObjectId("595b99e2f6a6243715b3c317"), 
   "post_text" : "writing yiibai tutorials on mongodb",
   "tags" : [ "mongodb", "tutorial" ] 
}

如果您使用舊版本的MongoDB,則必須使用以下命令 -

>db.posts.runCommand("text",{search:" yiibai "})

與正常搜尋相比,使用文字搜尋極大地提高了搜尋效率。

刪除文字索引

要刪除現有的文字索引,首先使用以下查詢找到索引的名稱 -


>db.posts.getIndexes()

從上面的查詢獲取索引的名稱後,執行以下命令。 這裡,post_text_text是索引的名稱。

>db.posts.dropIndex("post_text_text")