從MongoDB 2.4版開始,MongoDB開始支持文本索引來搜索字符串內(nèi)容。文本搜索使用詞法技術(shù)通過刪除字符串字詞,如a
,an
等等來查找字符串字段中的指定單詞。目前,MongoDB支持大約15種語言。
最初,文本搜索是一個(gè)實(shí)驗(yàn)性功能,但從MongoDB 2.4版開始,默認(rèn)情況下啟用配置。 但是,如果使用2.4之前版本的MongoDB,則必須使用以下代碼啟用文本搜索 -
>db.adminCommand({setParameter:true,textSearchEnabled:true})
請(qǐng)考慮以下文檔,其中包含帖子文字及其標(biāo)簽 -
{
"post_text": "enjoy the mongodb articles on yiibai tutorials",
"tags": [
"mongodb",
"yiibai tutorials"
]
}
我們將在post_text
字段上創(chuàng)建一個(gè)文本索引,以便可以在posts
的文本中搜索 -
>db.posts.ensureIndex({post_text:"text"})
現(xiàn)在我們已經(jīng)在post_text
字段上創(chuàng)建了文本索引,下面在其文本中搜索所有帶有“yiibai
”一詞的帖子。
>db.posts.find({$text:{$search:"yiibai"}})
上述命令返回以下結(jié)果文件,其文本中包含“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 "})
與正常搜索相比,使用文本搜索極大地提高了搜索效率。
要?jiǎng)h除現(xiàn)有的文本索引,首先使用以下查詢找到索引的名稱 -
>db.posts.getIndexes()
從上面的查詢獲取索引的名稱后,運(yùn)行以下命令。 這里,post_text_text
是索引的名稱。
>db.posts.dropIndex("post_text_text")