我试图在两个模型之间使用多对多关联,我必须两次调用.add()或.remove()才能使其正常工作:
// User.js Model
module.exports = {
attributes: {
connections: {
collection: 'connection',
via: 'users'
}
}
}
// Connection.js Model
module.exports = {
attributes: {
users: {
collection: 'user',
via: 'connections'
}
}
}
这是我在UsersController.js中的代码:
User.findById(req.params.user)
.populate('connections')
.exec(function(err, users) {
if (err) return res.status(404).end(); // Not really a 404 but good for now
var user = users[0];
user.connections.add(req.body.connection_id);
user.save(function(err) {
// In my tests err is null/undefined
return res.status(204).end();
}
});
我得到204回来,日志中没有错误或没有其他失败。当我签入MongoDB数据库时,用户的连接字段只是一个空数组。如果我再次发送相同的请求,那么我会收到一条错误消息,指出该用户已经存在connection_id。我查看了数据库,现在连接出现在用户的连接字段中。当我删除连接时它做同样的事情,我必须发送两次才能使它生效。有人有什么想法吗?
以下是我使用的模块版本:
答案 0 :(得分:3)
听起来像是与同步方法和异步方法相关的东西......这意味着您在某个请求完成之前退出该方法。但不确定发生的地方。看看这是否有帮助:
var connectionId = req.param('connection_id');
var userId = req.param('user');
User.find(userId)
.populate('connections')
.exec(function(err, users) {
if (err) return res.status(404).end(); // Not really a 404 but good for now
//BTW might be good to double check doing console.log("users: "+JSON.stringify(users));
var user = users[0];
user.connections.push(connectionId);
//Is it really there? console.log("user: "+JSON.stringify(user));
user.save(function(err) {
// In my tests err is null/undefined
return res.status(204).end();
}
});