我有一个“用户”集合,包含一些字段(名称,名字,登录名,密码......)
我想存储用户&密码在一个名为“local”的“子文档”中(对于本地连接,将来我可以有一个名为“facebook”或“google”的子文档...)
所以,这是mongo中文档的结构:
db.User.find(){
"__v": 0,
"_id": ObjectId("5342b25940bcab2d1d71e04a"),
"active": true,
"address": "juddegaass, 2A",
"api_key": "3cead67add74395ce4d1dfcdd3ea4979",
"city": "Kehlen",
"country": "LU",
"create_date": ISODate("2014-04-07T14:12:41.104Z"),
"credit": 0,
"email": "admin@company.com",
"firstname": "Admin",
"lastname": "Istrator",
"local": {
"email": "admin@company.com",
"password": "$2a$08$Y7GorE3UhceNhPzvAdv7X.wDNxp80snHdng0hq9r1AePqRW1iHU5i"
},
"role": "su",
"uptade_date": ISODate("2014-04-07T14:12:41.104Z"),
"zip": "8281"
}
我有一个表单来更新用户,我的问题是我提交此表单时。我收到了一个错误:
TypeError: Cannot set property 'email' of undefined
这是我的Node User Mapper中的更新功能:
var toUpdate = {};
if (data.firstname) toUpdate.firstname = data.firstname;
if (data.lastname) toUpdate.lastname = data.lastname;
if (data.email) {
toUpdate.email = data.email;
toUpdate.local.email = data.email;
}
if (data.password !== '') toUpdate.local.password = user.generateHash(data.password);
if (data.role) toUpdate.role = data.role;
...
if (data.apiKey) toUpdate.api_key = data.apiKey;
if (data.active) toUpdate.active = data.active;
dbUser.update({'_id' : data.id}, toUpdate, {upsert : true}, function (err) {
if (err) return callback(new Error(err));
callback(null, data.id);
});
当然,我可以声明“本地”子对象,但如果我声明它,密码值将被删除。
答案 0 :(得分:1)
您的评论清楚地表明您可能已在数据库中为此项目添加了条目。当您使用mongoose时,更新的正确方法是先将其从数据库中取出,然后保存。
dbUser.findbyId(data.id, function(err, user){
if(err){
return callback(err);
}
if(!user){
user = new dbUser();
}
if (data.firstname) user.firstname = data.firstname;
//...//
if(data.email){
user.local = user.local || {};
user.local.email = data.email;
}
if(data.password !== '') {
user.local = user.local || {};
user.local.password = dbUser.generateHash(data.password);
}
user.save(callback);
});