[英]Removing Objects in one-to-many relationships using Node.js REST API, Mongoose, Express, Angular,
[英]Storing a one to many relationship in Node.js using Mongoose
我有一个非常简单的一对多关系,其中User
有一个Alerts
列表。 为此,我定义了以下架构:
var userSchema = new Schema({
email: String,
alerts: [{type: Schema.Types.ObjectId, ref: 'Alert'}]
});
var User = mongoose.model('User', userSchema);
var alertSchema = new Schema({
_creator: {type: Schema.Types.ObjectId, ref: 'User'},
value: String,
});
var Alert = mongoose.model('Alert', alertSchema);
现在,我正在尝试创建一个函数,该函数创建一个新的Alert
并将其从数据库添加到现有的User
。 我有以下代码(删除错误处理,因此代码更短):
function createAlertForUser(userId, value) {
User.findOne({_id: userId}, function (error, user) {
var alert = new Alert({
_creator: userId,
value: value
});
alert.save(function (error, alert) {
// push it to the user
user.alerts.push(alert);
user.save(function(error) {
console.log("saved");
});
});
});
}
但是,当我检查数据库时,似乎将空值保存到用户的警报列表中。 有什么想法我想念的吗?
您尝试将整个Alert
对象推送到ObjectId
数组。
尝试以下方法:
user.alerts.push(alert.id);
要么
user.alerts.push(alert._id);
两者都是正确的。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.