无涯教程-MongoDB - 文本搜索
阿里云国内75折 回扣 微信号:monov8 |
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6 |
从2.4版开始,MongoDB开始支持文本索引来搜索字符串内容, 文本搜索使用词干搜索技术通过删除词干停止词(例如 a,an,the,等)来在字符串字段中查找指定的词。目前,MongoDB支持大约15种语言。
启用文本搜索
最初,"Text Search"是一项实验性函数,但从2.6版开始,默认情况下启用此配置。但是如果您使用的是早期版本,则必须使用以下代码启用文本搜索-
>db.adminCommand({setParameter:true,textSearchEnabled:true})
创建文本索引
考虑 posts 集合下的以下文档,其中包含帖子文本及其标签-
{ "post_text": "enjoy the mongodb articles on learnfk", "tags": [ "mongodb", "learnfk" ] }
无涯教程将在post_text字段上创建文本索引,以便无涯教程可以在帖子的文本中进行搜索-
>db.posts.ensureIndex({post_text:"text"})
使用文字索引
现在无涯教程已经在post_text字段上创建了文本索引,无涯教程将搜索其文本中所有带有 learnfk 单词的帖子。
>db.posts.find({$text:{$search:"learnfk"}})
上面的命令返回了以下输出文档,其后文中带有单词 learnfk -
{ "_id" : ObjectId("53493d14d852429c10000002"), "post_text" : "enjoy the mongodb articles on learnfk", "tags" : [ "mongodb", "learnfk" ] } { "_id" : ObjectId("53493d1fd852429c10000003"), "post_text" : "writing Learnfk on mongodb", "tags" : [ "mongodb", "tutorial" ] }
如果您使用的是旧版本的MongoDB,则必须使用以下命令-
>db.posts.runCommand("text",{search:" learnfk "})
与普通搜索相比,使用文本搜索可以大大提高搜索效率。
删除文字索引
要删除现有的文本索引,请首先使用以下查询找到索引的名称-
>db.posts.getIndexes()
从上面的查询中获取索引名称后,运行以下命令,在这里, post_text_text 是索引的名称。
>db.posts.dropIndex("post_text_text")
参考链接
阿里云国内75折 回扣 微信号:monov8 |
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6 |