mongodb数据库教程-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") 

  

从零到一,创造未来!跨零综合IT问题解决服务站,欢迎你的到来。Oracle数据库教程 mongodb数据库教程/a> 只为你绽放。

本文固定链接: http://kua0.com/2019/03/29/mongodb数据库教程-mongodb文本搜索/

为您推荐

发表评论

电子邮件地址不会被公开。 必填项已用*标注