如何将两个键组合成Mongodb中的一个新对象?

时间:2014-11-21 21:51:57

标签: mongodb

以下是我的文档示例。

{
    _id: '1',
    card: [
        {
            'expiration_month': '10',
            'expiration_year': '2017'
        },
        {
            'expiration_month': '01',
            'expiration_year': '2015'
        },
    ]
}

我希望将月份和年份合并到日期对象中,并将其存储在这些键已存储在同一对象中。

所以它看起来像expires实际上是一个日期对象。

{
    _id: '1',
    card: [
        {
            'expiration_month': '10',
            'expiration_year': '2017',
            expires: {                
            }
        },
        {
            'expiration_month': '01',
            'expiration_year': '2015',
            expires: {                
            }
        }
    ]
}

我试过这个,但我知道这是错的。

db.collection.update({'card.expires': {$exists: false}}, { $set: moment(new Date(card.expiration_year + '-' + card.expiration_month)) })

3 个答案:

答案 0 :(得分:0)

遗憾的是,mongodb不允许基于文档中的字段进行更新。 https://jira.mongodb.org/browse/SERVER-458

您需要将此操作作为两个单独的操作,一个用于查找要修改的文档,另一个用正确的新日期更新这些文档。

答案 1 :(得分:0)

我会这样做:

db.yourcollection.find().snapshot().forEach(
  function (e) {
    var saveChanges = false;

    if(e.cards && e.cards.length > 0){
        for(var i=0; i < e.cards.length; i++){
            if(e.cards[i].expiration_month && e.cards[i].expiration_year){
                e.cards[i].expires = new Date(e.cards[i].expiration_year, e.cards[i].expiration_month, 1);

                saveChanges = true;
            }
        }
    }
    if(saveChanges) db.yourcollection.save(e);
  }
)

答案 2 :(得分:0)

更新card数组元素的一种方法是:

db.collection.find({"card.expires":{$exists:false}}).forEach(function(doc){
var cards = doc.card.map(function(card){
var date = new ISODate(card.expiration_year+card.expiration_month+"01");
if(!card.hasOwnProperty("expires")){card["expires"]=date;}
return card;
})
db.collection.update({"_id":doc._id},{"card":cards});
});