首页 > 解决方案 > 对 ObjectId 字段的 Atlas 搜索不起作用

问题描述

我试图在 ObjectId 字段上实现 Atlas 搜索查询,但没有匹配到任何内容。这是索引定义。

{
  "mappings": {
    "dynamic": false,
    "fields": {
      "hscode": {
        "foldDiacritics": true,
        "maxGrams": 4,
        "minGrams": 1,
        "tokenization": "edgeGram",
        "type": "autocomplete"
      },
      "title": {
        "foldDiacritics": true,
        "maxGrams": 10,
        "minGrams": 2,
        "tokenization": "edgeGram",
        "type": "autocomplete"
      },
      "type._id": {
        "type": "objectId"
      }
    }
  }
}

查询详情如下

db.categories.aggregate([
    {
        $search:{
            index:"categorySearch",
            equals:{
                path:"type._id",
                value:ObjectId("61711b4275e9397ec79bdfed")
            }
        }
    }
])

注意:自动完成查询工作没有问题。提前谢谢你。

标签: mongodbsearchmongodb-queryatlasmongodb-atlas-search

解决方案


对于那些寻求修复的人,请尝试将索引更改为如下所示。应添加文档类型以使其正常工作。

type:{
  _id:{
    type:"objectId"
  }
  type:"document"
}

推荐阅读