ошибка поиска и обновления и дублирования 11000

#mongodb #mongoose #mongoose-schema

#mongodb #mongoose #mongoose-схема

Вопрос:

здравствуйте, у меня проблема с запуском моего кода, потому что в нем указано, что E11000 ошибка с дубликатом ключа collection

 router.put('/:city/edit',isAdminCheck, async function(req,res){
var query = req.params.city;
var update = {region:req.body.region,country:req.body.country,image:req.body.image,flag:req.body.flag,languages:req.body.languages,currencies:req.body.currencies,city:req.body.city};
CityList.findOneAndUpdate(query,update,{upsert:true}, function(error){
    if(error){
        if(error.code === 11000){
            CityList.findOneAndUpdate(query,update,{upsert:true}, function(error){
                if(error){
                    console.log(error);
                }else{
                    res.redirect("/"   req.params.cty);
                }
            })
        }
    }else{
        res.redirect("/"   req.params.city);
    }
})

});
  

Ответ №1:

Ваш запрос неверен. Это должно быть так

 var query = {city: req.params.city};
  

И вы дважды выполняете одно и то же обновление. Вы должны вызвать ее только один раз.

 CityList.findOneAndUpdate(query,update,{upsert:true}, function(error){
    if(error){
        // handle error
        }
    }else{
        res.redirect("/"   req.params.city);
    }
})