Mon goose обновление значения в Array of Array в NodeJS - PullRequest
0 голосов
/ 24 февраля 2020

моя схема тестирования:

var TestSchema = new Schema({
    testName: String,
    topic: {
        topicTitle: String,
        topicQuestion: [
            {
                questionTitle: String,
                choice: [
                    {
                        name: String
                        age: Number
                    }
                ]
            }
        ]
    }
}, { collection: 'test' });
var Test = mongoose.model('test', TestSchema);

Я хочу обновить одно значение age ($ in c), у которого есть идентификатор выбора.

У меня может быть идентификатор теста , идентификатор topicQuestion и идентификатор выбора .

Как написать этот запрос в пн goose в NodeJS?

Обычно я использую приведенный ниже запрос для обновления значения:

Test.findOneAndUpdate({ _id: testId }, { $inc: { ... } }, function (err, response) {
   ...
});

, но так сложно получить массив и еще один массив. Спасибо

Ответы [ 2 ]

1 голос
/ 24 февраля 2020

Вы можете использовать позиционный оператор $ [] для обновления вложенных массивов.

router.put("/tests/:testId/:topicQuestionId/:choiceId", async (req, res) => {
  const { testId, topicQuestionId, choiceId } = req.params;

  const result = await Test.findByIdAndUpdate(
    testId,
    {
      $inc: {
        "topic.topicQuestion.$[i].choice.$[j].age": 1
      }
    },
    {
      arrayFilters: [{ "i._id": topicQuestionId }, { "j._id": choiceId }],
      new: true
    }
  );
  res.send(result);
});

Допустим, у нас есть этот существующий документ:

{
    "_id" : ObjectId("5e53e7d9bf65ac4f5cbf2116"),
    "testName" : "Test 1",
    "topic" : {
        "topicTitle" : "Title",
        "topicQuestion" : [
            {
                "_id" : ObjectId("5e53e7d9bf65ac4f5cbf211a"),
                "questionTitle" : "Question 1 Title",
                "choice" : [
                    {
                        "_id" : ObjectId("5e53e7d9bf65ac4f5cbf211c"),
                        "name" : "A",
                        "age" : 1
                    },
                    {
                        "_id" : ObjectId("5e53e7d9bf65ac4f5cbf211b"),
                        "name" : "B",
                        "age" : 2
                    }
                ]
            },
            {
                "_id" : ObjectId("5e53e7d9bf65ac4f5cbf2117"),
                "questionTitle" : "Question 2 Title",
                "choice" : [
                    {
                        "_id" : ObjectId("5e53e7d9bf65ac4f5cbf2119"),
                        "name" : "C",
                        "age" : 3
                    },
                    {
                        "_id" : ObjectId("5e53e7d9bf65ac4f5cbf2118"),
                        "name" : "D",
                        "age" : 4
                    }
                ]
            }
        ]
    },
    "__v" : 0
}

Если мы хотим увеличить age значение данного выбора, мы отправляем запрос PUT с использованием конечной точки, подобной этой http://.../tests/5e53e7d9bf65ac4f5cbf2116/5e53e7d9bf65ac4f5cbf211a/5e53e7d9bf65ac4f5cbf211b, где

"testId": "5e53e7d9bf65ac4f5cbf2116"

"topicQuestionId": "5e53e7d9bf65ac4f5cbf211a"

"choiceId": "5e53e7d9bf65ac4f5cbf211b"

0 голосов
/ 24 февраля 2020

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

Пример:

Test.findOneAndUpdate({ _id: testId, topicQuestion.choice._id: choiceId}, { 'topicQuestion.$.choice': {$inc: { age: <numberToIncrement> }}}, {new: true}, function (err, response) {
   ...
});
...