我试图创建数据,如果数据库中存在facebook id,否则创建新数据,但是第一个条件工作正常但是当它的创建数据没有任何反应时,即使我硬编码提供者值,也得到connot read property 'provider' of null
。
db.collection('accounts', function(err, collection){
collection.findOne({'email': fbEmail}, function(err, item){
var providerId = item.provider.facebook.id;
console.log("facebook id should be: "+providerId);
if(providerId == ""){
collection.update({email:fbEmail, 'provider.facebook.id':""}, {$set: {"provider.facebook.id": fbId}}, {safe:true}, function(err){
if(err){
console.log(err);
}else{
console.log("id updated!");
};
});
}else{ //creates a new user
console.log("creating a new account...");
collection.update({'email': fbEmail}, {
'email': fbEmail,
'provider':
{
'facebook': {'id': fbId},
'twitter': {'id': ""}
}
}, {upsert:true}, function(err, doc){
if(err){
console.log("Error finding email "+err);
}
});
}
});
});
答案 0 :(得分:1)
accounts
个收集文档中的一个(第一个)有provider=null
。您可以通过以下方式修改findOne
条件以避免它:
collection.findOne({'email': fbEmail, 'provider': {$exists: true}}, ...
请注意,此修改只会跳过未设置provider
字段的所有帐户(或设置为null
)。