前年做一个日志分析的项目,,用到了MongoDB数据库。有个功能是对数据进行二次查询,所以就用到了MongoDB自带的全文索引,虽然这个方案最后无法满足要求,但是还是想记录下。
目前MongoDB驱动使用的是2.4版本,项目框架是.Net Framework4.5(原来项目使用的是1.7版本的,但是发现没有支持text search的接口)。
1、需求说明
在二次筛选框中输入关键字,支持多个关键字输入,支持and、or连接词。
例如:
或-or:上位机 or 客户端 ,上位机 客户端【关键词之间以空格隔开】
且-and:上位机 and 客户端
2、查询语法
首先,先整理下text search 相关查询语法。
2.1. 创建全文索引
指定text索引名称为“IndexList”
2.2. 使用$text对添加索引字段的内容执行文本搜索。
2.3. $search字段
3. 所遇问题
因为要求要支持A and B or C格式的查询,但是text seatch 好像不支持。
按照以下格式进行查询,但是只能显示 【客户端 and 局放】的数据。
后来查询官方文档才知道,在MongoDB的全文检索中,使用and连接词查询,就相当于短语查询,如果查询字符串中有短语和单个术语,那么文本搜索将仅匹配包含短语的文档。
-
文章推荐:
-
https://blog.youkuaiyun.com/sinat_32366329/article/details/82535170
-
https://docs.mongodb.com/manual/reference/operator/query/text/index.html#text-query-operator-behavior