0

我在这个主题上搜索了很多,但我完全迷路了。这是我的问题(我将 node.js 与 mongojs 一起使用):

我想要这样的文件:

{ 
    "_id" : ObjectId("50ce2f7f98fa09b20d000001"), 
    "beginTime" : 1355689855016, 
    "tags" : {
        "primary": [ 29, 12, 16], 
        "secondary": [6, 8, 9]
    },
    "user" : "50bdddc601de4681d666835f"
}

但是,如果我尝试在“主要”下推送新标签(请注意,此字段来自变量),就像这样

tags = {};
tags[request.body.relevance] = request.body.tag;
return db.activities.update({
  '_id': db.ObjectId(request.body.activity),
  'user': request.session.user.id
}, {
  $push: {
    tags: tags
  }
});

然后我得到

{ "_id" : ObjectId("50ce2f7f98fa09b20d000001"), "beginTime" : 1355689855016, "tags" : [ { "primary" : 29 }, { "primary" : "24" }, { "primary" : "1" } ], "user" : "50bdddc601de4681d666835f" }

我尝试了许多其他变体,包括嵌套 $push(女巫将其转换为字段 oo)。无论如何,我总是失败。也是在这一点上我真的很饿T_T

请帮我。谢谢。

4

1 回答 1

1

运算符的值$push需要是要推送到的数组字段,而不是父字段。

试试这个:

...
return db.activities.update({
  '_id': db.ObjectId(request.body.activity),
  'user': request.session.user.id
}, {
  $push: {
    'tags.primary': tags.primary,
    'tags.secondary': tags.secondary
  }
});

更新

要动态执行此操作,您需要执行以下操作:

...
var push = {};
push['tags.' + request.body.relevance] = request.body.tag;
return db.activities.update({
  '_id': db.ObjectId(request.body.activity),
  'user': request.session.user.id
}, {
  $push: push
});
于 2012-12-16T21:22:58.470 回答