【问题标题】:MongoDB text search does not return anythingMongoDB 文本搜索不返回任何内容
【发布时间】:2016-08-23 20:01:50
【问题描述】:

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

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 或其他运算符)。使用第三方索引器对我来说似乎有点过头了...肯定有一种方法可以同时执行全文搜索和模式匹配?

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

【问题讨论】:

    标签: mongodb


    【解决方案1】:

    试试这个:

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

    另请参考mongodb文档:

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

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

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

    【讨论】:

    • 好吧,当然,但是您正在调整 data 以匹配查询,而我需要一个 query 来获取数据。
    • 对不起,我的错,我认为 mongodb 没有得到你的语言,你使用的是法语还是什么语言?我认为这是 è 使 mongodb 出现错误。我尝试过使用 Bannièr 或 Bannière 将返回您的文件。但如果它比 Banniè 短,它就不会返回。我也尝试过纯英文单词,比如 "hello" ,它只在我使用 $text 搜索时使用 "hello" 时返回。您可以尝试使用 $language 操作来指定您正在使用的语言。
    • 如果你确实需要通过 "ba" 甚至 "an" 查询 "Bannière" ,你可能需要自己建立一个索引,映射 "b" ,"B" , "ba" , "Ba" , "an" blah blah all to "Bannière" 。您还可以使用第三方框架进行索引,例如 sphinx。这就是我所知道的。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2012-07-08
    • 1970-01-01
    • 1970-01-01
    • 2021-11-20
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多