我的情况是,如果person1接受person2交易方式。.person1_id将保存在person2特定deal字段accepted中,我已经尝试了如果接受的用户(person2 )有一笔交易,但是如果有一笔以上的交易,它会更新但删除其他交易(即,假设person2具有3笔交易,这意味着如果person1接受第三笔交易,则接受的用户ID正在第三笔交易中更新,并且第一笔交易和第二笔交易已删除)。任何人都可以帮助我如何仅保存更新后的交易数组

var incomingUser = req.user;//accepting user accesstoken in header(person1)
if(req.params.id){
var id = req.params.id;//deal id
console.log("DealId:"+id + "Acceptinguser:"+incomingUser.name);
User.findOne(
{
    "deals": {
      $elemMatch: {
        _id: id
      }
    }
  },
function(err, data){
  console.log("Dealer:" +data.name);
  console.log("deal:"+ data.deals);
  if(err){
    console.log("User not found");
    res.send(new restify.ResourceNotFoundError('failed','Deal not found'));
    return next();
  }
    var dealObj = _.filter(data.deals, { id: id })[0];
    console.log("Deal Obj" + dealObj);
     var acceptingUser = incomingUser;
     console.log("accepting user:" +acceptingUser._id);
     dealObj.accepted = acceptingUser._id;
     console.log("accept id: "+ dealObj.accepted);
     data.deals = dealObj;
     console.log("data:"+ data.deals);
  data.save(function (err, result){
    console.log("Result:" + result);
    if(err){
      console.log("Internal error");
      res.send(new restifyc.InternalError('failed','Error accepting'));
      return next();
    }
    console.log("saved");
    res.send(200,{user: result});
    return next();
  });
});
}
}


我的模式是

var dealSchema = new mongoose.Schema({
shopName: {type: String,required: true},
deal: {type: String,required: true},
price:{type: Number,required: true},
start:{type: Date,default: Date.now},
end:{type: Date},
expiry:{type: Date},
comments:{type: String},
accepted: {type:mongoose.Schema.Types.ObjectId, ref:'user'},//person1 _id
rejected: {type:mongoose.Schema.Types.ObjectId, ref: 'user'}
});
var userSchema = new mongoose.Schema({
  name: { type: String,required: true},
  phone: { type: Number, required: true,unique: true},
  email:{type: String},
  password: {type: String},
  deals:[dealSchema]
  }, {collection: 'user'});
  mongoose.model('Deal', dealSchema);
  mongoose.model('user', userSchema);

最佳答案

是的,为了专门更新您需要的内容,可以将<array>.$用于元素的指定位置:

User.update(
  "deals": {
    $elemMatch: {
      _id: id
    }
  }, {
    "$set": {
      "deals.$" : {/*your deal data*/}
    }
  }, function(err, doc) {

  });


有关如何使用$通配符https://docs.mongodb.org/manual/reference/operator/update/positional/的更多详细信息

10-07 21:05