MongoDB 全文索引

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_18948359/article/details/88690853

说明:本篇文章介绍 MongoDB 中的全文索引的使用,如何创建以及使用全文索引进行常规搜索,其次介绍全文检索的打分搜索, "$text", "$search", "$meta" 的用法。

MongoDB 全文索引

全文检索对每一个词建立一个索引,指明该词在文章中出现的次数和位置,当用户查询时,检索程序就根据事先建立的索引进行查找,并将查找的结果反馈给用户的检索方式。

这个过程类似于通过字典中的检索字表查字的过程。

建立全文索引

// 单个字段建立 全文索引 
db.collection.createIndex({filed: "text"}); 

// 多个字段建立 全文索引 
db.collection.createIndex({filed: "text", filed1: "text", ...});

如果想要表示出全文检索,需要使用 "$text" 判断符;要进行数据的查询,需要使用 "$search" 运算符:

  • 查询指定关键字:{ "$search" : "查询关键字" }
  • 查询多个关键字(或关系):{ "$search" : "查询关键字 查询关键字 ..." } (使用空格分开)
  • 查询多个关键字(与关系):{ "$search" : "\"查询关键字\" \"查询关键字\" ..." } (使用转义字符分开)
  • 查询多个关键字(排查某一个):{ "$search" : "查询关键字 查询关键字 ... -排除关键字" } (使用 "-")

实战

先插入数据

db.news.insertOne({name: "name1", content: "name test java mongodb"});
db.news.insertOne({name: "name2", content: "name java mongodb"});
db.news.insertOne({name: "name3", content: "name mongodb"});
db.news.insertOne({name: "name4", content: "name java mongodb"});
db.news.insertOne({name: "name5", content: "name test mongodb"});

创建索引

// 创建索引
db.news.createIndex({"content": "text"});

示例:查询单个字符

// 查询单个字符
db.news.find({"$text": {"$search": "java"} } )

db.news.find({"$text": {"$search": "name"} } )

示例:查询多个字符

// 查询多个字符
db.news.find({"$text": {"$search": "name test"} } )

示例:查询同时包含 test 与 mongodb 

// 查询同时包含 test 与 mongodb 
db.news.find({"$text": {"$search": "\"name\" \"test\" "} } )

示例:查询同时包含 test 与 mongodb 但是不包含 java 的文档数据

// 查询同时包含 test 与 mongodb 但是不包含 java 的文档数据 
db.news.find({"$text": {"$search": "\"name\" \"test\" -java"} } )

特殊使用方式

给所有的字段创建全文索引。这种方式不推荐使用,因为给所有的字段添加索引,是一个很漫长的过程。

db.collection.createIndex({"$**": "text"});

使用打分来判断检索结果(分数越高,表示相似度越近)

// 示例
db.news.find({"$text": {"$search": "name test"} }, {"score" : {"$meta": "textScore"}} );

猜你喜欢

转载自blog.csdn.net/qq_18948359/article/details/88690853