gpt4 book ai didi

MongoDB 文本搜索不返回任何内容

转载 作者:行者123 更新时间:2023-12-03 15:59:59 25 4
gpt4 key购买 nike

我的收藏之一不再针对某些搜索值返回任何内容。这是一个控制台转储来说明问题:

meteor:PRIMARY> db['test'].insert({ sku: 'Barrière' });
WriteResult({ "nInserted" : 1 })
meteor:PRIMARY> db['test'].insert({ sku: 'Bannière' });
WriteResult({ "nInserted" : 1 })
meteor:PRIMARY> db['test'].createIndex({ sku: 'text' });
{
"createdCollectionAutomatically" : false,
"numIndexesBefore" : 1,
"numIndexesAfter" : 2,
"ok" : 1
}
meteor:PRIMARY> db['test'].find({ sku: /ba/i });
{ "_id" : ObjectId("57bbb447fc77800b1e63ba64"), "sku" : "Barrière" }
{ "_id" : ObjectId("57bbb455fc77800b1e63ba65"), "sku" : "Bannière" }
meteor:PRIMARY> db['test'].find({ $text: { $search: 'ba' } });
meteor:PRIMARY> db['test'].find({ $text: { $search: 'Ba' } });
meteor:PRIMARY>

即使我明确添加了两个应该匹配的文档,搜索也没有返回任何结果。这是怎么回事?我缺少什么选项/配置?

** 编辑 **

我尝试了这个查询

meteor:PRIMARY> db['test'].find({ $or: [ { $text: { $search: 'ba' } }, { sku: { $regex: 'ba', $options: 'i' } } ] });
Error: error: {
"waitedMS" : NumberLong(0),
"ok" : 0,
"errmsg" : "error processing query: ns=meteor.testTree: $or\n sku regex /ba/\n TEXT : query=ba, language=english, caseSensitive=0, diacriticSensitive=0, tag=NULL\nSort:
{}\nProj: {}\n planner returned error: Failed to produce a solution for TEXT under OR - other non-TEXT clauses under OR have to be indexed as well.",
"code" : 2
}

但我不确定如何创建索引来搜索部分值(即使用 $regex 或其他运算符)。使用第三方索引器对我来说似乎有点大材小用...肯定有一种方法可以立即执行全文搜索以及模式匹配吗?

这是我执行两个查询并手动合并结果的唯一解决方案吗?

最佳答案

试试这个:

db['test'].insert({ sku: 'ba ba' });
db['test'].find({ $text: { $search: 'ba' } });

另请参阅mongodb文档:

如果搜索字符串是空格分隔的字符串,则 $text 运算符会对每个术语执行逻辑 OR 搜索,并返回包含任何术语的文档。

我认为 mongodb $text $search 只是按空格分割字符串并匹配整个单词。如果您需要搜索单词的一部分,您可能需要使用其他一些框架来寻求帮助。也许您也可以使用 $regex 来执行此操作。

如果唯一的要求是按前缀查询单词,可以使用$regex,如果只按前缀查询,可以使用索引。否则,如果将扫描整个集合。

关于MongoDB 文本搜索不返回任何内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39091440/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com