3

可能重复:
mongo 可以插入数据吗?

我的模式定义如下:

var Permission = new Schema({
  _id: String,  // email address
  role: String  // "admin" or "member"
});

var Org = new Schema({
  name: {type: String, index: {unique: true, dropDups: true}, trim: true},
  permissions: [Permission]
});

我正在尝试匹配和更新子文档行(在我的情况下为“权限”,或者如果不匹配(例如 upsert)则插入新的权限行。

这是我写的:

exports.updatePermissions = function(req, res) {
  return Org
    .update(
      {name:"my_org", "permissions.$._id": req.body.email},
      {$set: {"permissions.$.role": req.body.role}})
    .exec(function(err) {
      // stuff
    });
};

MongoDB 似乎接受了这一点(例如没有错误),但数据库没有变化。我也在 mongo shell 中尝试了以下操作:

db.orgs.update({"name":"my_org", "permissions.$._id":"newuser@email.com"}, {$set: {"permissions.$.role": "member"}});

Mongo 再次接受了查询,但没有任何变化。这是我要修改的文档:

{
    "name" : "my_org",
    "permissions" : [
        {
            "_id" : "newuser@email.com",
            "role" : "admin"
        }
    ]
}

有什么建议么?非常感谢

4

1 回答 1

0

这对我有用 $elemMatch,还可以查看$ 运算符的规则

db.orgs.update({"name":"my_org", "permissions": {$elemMatch: {_id:"newuser@email.com"}}},
     {$set: {"permissions.$.role": "member"}});
于 2013-01-10T01:31:15.243 回答