【发布时间】:2016-01-22 19:47:21
【问题描述】:
我正在尝试添加新的或根据现有子文档的存在来更新它。
给出以下架构:
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
});
存储以下文档:
{
"_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
}
我正在尝试使用以下代码更新或添加新的子文档:
User.findOneAndUpdate({email: email},
{
"$push" : {
"provider": {
"provider": "dropbox",
"id": "123441212",
"accessToken": "sdasddad"
}
}
}, function (error, doc) {
....
}});
很遗憾,现有的子文档没有更新,而是创建了新的子文档。
你能帮帮我吗?
提前致谢!
附:是否可以命名子文档?那么例如有一个名为“facebook”的子文档,可以通过名称直接访问?
--- 解决方案---
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 _ = require('underscore');”)
【问题讨论】:
标签: node.js mongodb mongoose nosql