findOneAndUpdate самый последний документ - PullRequest
0 голосов
/ 01 октября 2018

Это моя схема

 var BudgetSchema = mongoose.Schema({
  user_email: { type: String, required: true },
  user_budget: { type: Number, required: true },
  platforms_budget: {
    type: [{
      platform_id: { type: String, required: true },
      platform_name: { type: String, required: true },
      platform_budget_percent: { type: Number, required: true },
      platform_budget: { type: Number, required: true },
    }]
  },
  created: { type: Date, default: Date.now() }
});

var BudgetSchemaExport = module.exports = mongoose.model('Budget', BudgetSchema);

А это функция:

module.exports.updateBudgetPercent = async function (user_email, platform_name, p_budget) {
  var query = {
    "user_email": user_email,
    "platforms_budget": {
      $elemMatch: { "platform_name": platform_name }
    }
  };
  //the location that need to be updated
  var update = { "$set": { "platforms_budget.$[outer].platform_budget_percent": p_budget }  };
  //array's index
  var options = { arrayFilters: [{ "outer.platform_name": platform_name }] };
  var updated = await this.findOneAndUpdate(query, update, options).sort({ created: -1 })
  if (updated) { //if the data was updated
    return true;
  } else {
    return false;
  }
}

Цель этой функции - обновить бюджет для конкретного пользователя.Я хочу обновить самый последний документ, но он обновляет самый ранний / первый.

Я попробовал эту опцию: var updated = await this.findOneAndUpdate(query, update, options, {sort:{ "created": -1 }}), но я получил ошибку:

events.js:167
      throw er; // Unhandled 'error' event
      ^
TypeError: callback.apply is not a function

Есть идеи?Спасибо.

1 Ответ

0 голосов
/ 01 октября 2018

Используйте upsert: true с sort: { created: -1 }.Вот запрос:

var updated = await this.findOneAndUpdate(
  query,
  update,
  {
    upsert: true,
    sort: { created: -1 },
  }
);

Надеюсь, это поможет вам.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...