douliang1900 2018-08-06 15:38
浏览 240

使用mgo查询子元素mongodb时不支持的投影选项

I am working on a query to a mongodb with mgo using golang but it throws Unsupported projection option error while querying a sub document.

I am working on below document

{
    "_id" : ObjectId("5b64a0d3931653c36bcaf0b5"),
    "quantity" : 2,
    "product" : "ABC",   
    "children" : [ 
        {           
            "isBlocked" : true,
            "blockedMessage" : "Error occurred: TRACEID",
            "serialNo" : "abc123",
            "token" : "foo456",            
        }
    ]
}

The query I am using is

bson.M{"_id": 0, "children": bson.M{"serialNo": "abc123"}}

May I know where the mistake is?

  • 写回答

1条回答 默认 最新

  • duai4512 2018-08-06 15:42
    关注

    Matching array element should be done with $elemMatch

    Raw mongodb query looks like:

    db.collection.find({_id: ObjectId('...'), children: {$elemMatch: {serialNo: 'abc123'}}});
    
    评论

报告相同问题?

悬赏问题

  • ¥20 模型在y分布之外的数据上预测能力不好如何解决
  • ¥15 processing提取音乐节奏
  • ¥15 gg加速器加速游戏时,提示不是x86架构
  • ¥15 python按要求编写程序
  • ¥15 Python输入字符串转化为列表排序具体见图,严格按照输入
  • ¥20 XP系统在重新启动后进不去桌面,一直黑屏。
  • ¥15 opencv图像处理,需要四个处理结果图
  • ¥15 无线移动边缘计算系统中的系统模型
  • ¥15 深度学习中的画图问题
  • ¥15 java报错:使用mybatis plus查询一个只返回一条数据的sql,却报错返回了1000多条