【问题标题】:Trouble updating a specific subdocument with MongoDB使用 MongoDB 更新特定子文档时遇到问题
【发布时间】:2014-01-31 16:45:08
【问题描述】:

我的文档如下所示:

{
  _id: ObjectId("52d317d7b5c4960000587cd4"),
  txid: "7e621eeb02874ab039a8566fd36f4591e65eca65313875221842c53de6907d6c",
  vin: [
    {
      _id: ObjectId("52d317d7b5c4960000587ce9"),
      meta_address: "321",
      meta_amount: 50,
      sequence: 4294967295,
      txid: "6749762ae220c10705556799dcec9bb6a54a7b881eb4b961323a3363b00db518",
      vout: 0
    },
    {
      _id: ObjectId("52d317d7b5c4960000587ce8"),
      sequence: 4294967295,
      txid: "c04c413576307737f3ad48efe5d509ebc883e1d04822b3a2eccf6a80a4482932",
      vout: 0
    },
    {
      txid: "72d4fc43ac576a4b2f1f35e1b310a2d83a1012a36fdc7813ec237646950233cf",
      vout: 0,
      sequence: 4294967295,
      _id: ObjectId("52d317d7b5c4960000587ce7")
    }
  ]
}

我的查询是: { txid: '7e621eeb02874ab039a8566fd36f4591e65eca65313875221842c53de6907d6c', 'vin.txid': 'c04c413576307737f3ad48efe5d509ebc883e1d04822b3a2eccf6a80a4482932', 'vin.vout': 0 }

更新是:

{ 'vin.$.meta_address': '321',
  'vin.$.meta_amount': 50 }

但是当我运行它时,它会更新vin 数组中的第一项而不是第二项。现在,奇怪的是,如果我将查询更改为: { txid: '7e621eeb02874ab039a8566fd36f4591e65eca65313875221842c53de6907d6c', 'vin.txid': 'c04c413576307737f3ad48efe5d509ebc883e1d04822b3a2eccf6a80a4482932'}

然后它工作正常。我认为问题在于我的查询在 vin 中查找 2 个元素,但我需要同时搜索这两个元素。我做错了什么?

【问题讨论】:

    标签: mongodb subdocument


    【解决方案1】:

    要在更新中获取 $ 以识别与查询中的两个属性匹配的元素,您需要在查询对象中使用 $elemMatch

    { txid: '7e621eeb02874ab039a8566fd36f4591e65eca65313875221842c53de6907d6c', 
      vin: {$elemMatch: {
          txid: 'c04c413576307737f3ad48efe5d509ebc883e1d04822b3a2eccf6a80a4482932', 
          vout: 0 
      }}}
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2017-10-13
      • 1970-01-01
      • 2018-08-08
      • 1970-01-01
      • 2017-01-29
      • 1970-01-01
      • 2018-02-08
      • 2022-08-02
      相关资源
      最近更新 更多