Ошибка Connect 500 в MongooseError.CastError

0

Здесь сделка: у меня есть форма в AngularJS/Node.JS, которая извлекает вопросы из MongoDB и присваивает значения каждому из ответов. Прошлой ночью я убил мою базу данных MongoDB. К счастью, у меня остались файлы JSON. Создал две новые коллекции (то же имя, что и предыдущая база данных) с файлами JSON, но теперь я получаю эту ошибку при попытке заполнить форму и отправить данные обратно в объект базы данных с массивом, называемым ответами:

Error
     at MongooseError.CastError ((HIDDEN)/node_modules/mongoose/lib/error/cast.js:18:16)
     at ObjectId.cast ((HIDDEN)/node_modules/mongoose/lib/schema/objectid.js:134:13)
     at Array.MongooseArray.mixin._cast ((HIDDEN)/node_modules/mongoose/lib/types/array.js:117:32)
     at Array.MongooseArray.mixin._mapCast ((HIDDEN)/node_modules/mongoose/lib/types/array.js:278:17)
     at Object.map (native)
     at Array.MongooseArray.mixin.push ((HIDDEN)/node_modules/mongoose/lib/types/array.js:291:25)
     at (HIDDEN)/controllers/user.js:236:22
     at (HIDDEN)/node_modules/async/lib/async.js:187:20
     at (HIDDEN)/node_modules/async/lib/async.js:239:13
     at _arrayEach ((HIDDEN)/node_modules/async/lib/async.js:91:13)
     at _each ((HIDDEN)/node_modules/async/lib/async.js:82:13)
     at Object.async.forEachOf.async.eachOf ((HIDDEN)/node_modules/async/lib/async.js:238:9)
     at Object.async.forEach.async.each ((HIDDEN)/node_modules/async/lib/async.js:215:22)
     at exports.postWizard ((HIDDEN)/controllers/user.js:233:11)
     at Layer.handle [as handle_request] ((HIDDEN)/node_modules/express/lib/router/layer.js:95:5)
     at next ((HIDDEN)/node_modules/express/lib/router/route.js:131:13)
POST /wizard 500 234.552 ms - -
  • 0
    Я думаю, что я должен создать _id для каждого из моих вложенных документов. Есть ли способ автоматизировать это?
Теги:
mongoose

1 ответ

0
Лучший ответ

Эта проблема была решена путем создания идентификаторов для вложенных объектов. Мне пришлось db вставить каждый документ. MongoDB автоматически не генерирует идентификатор для вложенных объектов; таким образом, мне пришлось использовать ObjectId():

 db.questions.insert({ 
    "question": "q1",
    "order": 1,
    "type": "assessment",
    "answers": [{
        "_id" : ObjectId(),
        "answer": "Yes",
        "value": 1
    }, {
        "_id" : ObjectId(),
        "answer": "No",
        "value": 0
 }]})

Ещё вопросы

Сообщество Overcoder
Наверх
Меню