標籤:man print .com 文本搜尋 com tag 文本 刪除 子集
啟用文本搜尋:
最初文本搜尋是一個實驗性功能,但2.6版本開始,配置是預設啟用的。但是,如果使用的是以前 MongoDB 的版本,那麼必須啟用文本搜尋,使用下面的代碼:
>db.adminCommand({setParameter:true,textSearchEnabled:true})
建立文本索引:
考慮下文字後其標籤的文章集合,包含以下檔案:
{ "post_text": "enjoy the mongodb articles on yiibai", "tags": [ "mongodb", "yiibai" ]}
我們將建立post_text欄位的文本索引,以便我們能夠在我們的文章中搜尋文本:
>db.posts.ensureIndex({post_text:"text"})
使用文本索引:
現在,我們已經建立文本post_text欄位的索引,我們將搜尋所有含有 yiibai.com 一詞的文章。
>db.posts.find({$text:{$search:"yiibai.com"}})
上面的命令返回在文本中含有yiibai單詞的文章,如以下結果文檔:
{ "_id" : ObjectId("53493d14d852429c10000002"), "post_text" : "enjoy the mongodb articles on yiibai.com", "tags" : [ "mongodb", "yiibai.com" ]}{ "_id" : ObjectId("53493d1fd852429c10000003"), "post_text" : "writing tutorials on mongodb", "tags" : [ "mongodb", "tutorial" ] }
如果使用的是舊版本的MongoDB,必須使用下面命令:
>db.posts.runCommand("text",{search:" yiibai.com "})
使用文本搜尋比普通搜尋的搜尋效率有極大的提高。
刪除文本索引:
要刪除現有的文本索引,使用下面的查詢首先找到索引的名稱:
>db.posts.getIndexes()
從上面查詢得到索引的名稱後,運行以下命令。這裡,post_text_text是索引的名稱。
>db.posts.dropIndex("post_text_text")
mongodb 文本索引