mongodb 文本索引
2017-05-12 10:34
183 查看
启用文本搜索:
最初文本搜索是一个实验性功能,但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学习之四----文本索引的简单使用
- MongoDB数据模型和索引学习总结
- [置顶] MongoDB研究总结之索引部分
- Jquery 操作下拉列表select的值,文本,索引等
- mongodb 添加删除索引
- MongoDB 学习笔记(四):索引
- 深入理解MongoDB的复合索引
- 五、MongoDB的索引
- [MongoDB] Index 索引
- mongodb通过@Indexes对多列建立索引
- Mongodb源码分析--插入记录及索引B树构建
- Mongodb源码分析--插入记录及索引B树构建
- Mongodb在renameCollection之后,记得千万要立即补建索引.
- MongoDB的索引(三)
- 文本主题模型之潜在语义索引(LSI)
- MongoDB 复合索引
- MongoDB学习04: 索引
- 跟四分卫一起学MongoDB - 索引
- MongoDB---地理索引
- pymongo给mongodb创建索引的简单实现方法