首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MongoDB:如何在Mongoose中添加或更新SubDocument?

MongoDB:如何在Mongoose中添加或更新SubDocument?
EN

Stack Overflow用户
提问于 2015-10-23 17:54:27
回答 3查看 2.3K关注 0票数 3

我正在尝试添加一个新的或更新一个现有的SubDocument基于它的存在。

给定的是以下架构:

代码语言:javascript
复制
var providerSchema = new Schema({
  provider: String,
  id: String,
  accessToken: Object
})

var userSchema = new Schema({
  email: { type: String },
  provider: [providerSchema],
  created_at: Date,
  updated_at: Date
});

存储以下文档:

代码语言:javascript
复制
    {
    "_id": {
        "$oid": "5629f57b13bc066c17b88a0d"
    },
    "created_at": {
        "$date": "2015-10-23T08:53:15.684Z"
    },
    "updated_at": {
        "$date": "2015-10-23T08:53:15.684Z"
    },
    "email": "123123123@gmail.com",
    "provider": [
        {
            "provider": "facebook",
            "id": "123123",
            "accessToken": {
                "expires_in": 123123,
                "token_type": "bearer",
                "access_token": "123123123"
            },
            "_id": {
                "$oid": "5629f57b13bc066c17b88a0e"
            }
        },
        {
            "accessToken": {
                "access_token": "123123",
                "token_type": "bearer",
                "uid": "123123"
            },
            "id": "123123",
            "provider": "dropbox",
            "_id": {
                "$oid": "5629f58813bc066c17b88a12"
            }
        }
    ],
    "__v": 0
}

我正在尝试使用以下代码更新或添加新的SubDocument:

代码语言:javascript
复制
User.findOneAndUpdate({email: email},
    {
      "$push" : {
        "provider": {
          "provider": "dropbox",
          "id": "123441212",
          "accessToken": "sdasddad"
        }
      }
    },  function (error, doc) { 
         .... 
}});

不幸的是,现有的SubDocuments没有更新,但创建了新的SubDocuments。

你能帮帮我吗?

提前感谢!

附注:可以命名为SubDocuments吗?那么,例如,有一个名为"facebook“的SubDocument,可以通过name直接访问?

-解决方案--

代码语言:javascript
复制
User.findOne(
    {"email": email})
    .populate("provider")
    .exec(function (err, data) {
        if(data === null && typeof data === "object"){
          // Create User
          user.save(function (error) {
            if(error) return callback(new Error(error), null);
            return callback(null, user);
          })
        } else {
          //
          if(err) return callback(new Error(err), null);

          var prov = _.findWhere(data.provider, { "provider": provider });

          if(typeof variable_here === 'undefined'){
              data.provider.push(update);
          } else {
            _.extend(prov, update);
          }

          data.save(function (error) {
            if(error) {
              return callback(error, null);
            } else {
              return callback(null, data);
            }
          });
        }
      }
    );

谢谢,侯赛因·杰拉米!仍然有很多退路。

(我一开始很纠结于"_.findWhere";它是下划线;只需通过"npm install underscore -save“安装,并在文件中放入以下行"var _=_.findWhere(‘下划线’);”)

EN

回答 3

Stack Overflow用户

发布于 2015-10-23 20:00:02

考虑学生集合中的以下文档,该文档的成绩元素值是嵌入文档的数组:

代码语言:javascript
复制
    {
      _id: 4,
      grades: [
         { grade: 80, mean: 75, std: 8 },
         { grade: 85, mean: 90, std: 5 },
         { grade: 90, mean: 85, std: 3 }
      ]
    }

使用位置$运算符将嵌入文档中的std字段的值更新为等级85:

代码语言:javascript
复制
    db.students.update(
       { _id: 4, "grades.grade": 85 },
       { $set: { "grades.$.std" : 6 } }
    )

下面的代码是update的完整语法,如果你定义upsert为true,它将插入新的记录,否则它将被更新。默认值: false

代码语言:javascript
复制
            db.collection.update(
               <query>,
               <update>,
               {
                 upsert: <boolean>,
                 multi: <boolean>,
                 writeConcern: <document>
               }
            )
票数 1
EN

Stack Overflow用户

发布于 2015-10-23 19:00:27

你可以试试这个。我想这可能行得通。

代码语言:javascript
复制
 User.update({email: email,provider.provider:'dropbox'},{$set:{"provider.$": {"provider": {
              "provider": "dropbox",
              "id": "123441212",
              "accessToken": "sdasddad"
            }}}},function(error, doc){
    ...
    }});
票数 0
EN

Stack Overflow用户

发布于 2015-10-24 00:43:01

-解决方案--

代码语言:javascript
复制
User.findOne(
    {"email": email})
    .populate("provider")
    .exec(function (err, data) {
        if(data === null && typeof data === "object"){
          // Create User
          user.save(function (error) {
            if(error) return callback(new Error(error), null);
            return callback(null, user);
          })
        } else {
          //
          if(err) return callback(new Error(err), null);

          var prov = _.findWhere(data.provider, { "provider": provider });

          if(typeof variable_here === 'undefined'){
              data.provider.push(update);
          } else {
            _.extend(prov, update);
          }

          data.save(function (error) {
            if(error) {
              return callback(error, null);
            } else {
              return callback(null, data);
            }
          });
        }
      }
    );

谢谢,侯赛因·杰拉米!仍然有很多退路。

(我一开始很纠结于"_.findWhere";它是下划线;只需通过"npm install underscore -save“安装,并在文件中放入以下行"var _=_.findWhere(‘下划线’);”)

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33299536

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档