2013-02-21 13 views
8

Używanie Mongoose.js z node.js.mongoose.js CastError: Przesyłanie do numeru nie powiodło się dla wartości "[object Object]" w ścieżce "undefined"

mam ten schemat:

var Photo = new Schema({ 
    URL:String 
    ,description:String 
    ,created_by:{type:ObjectId, ref:'User'} 
    ,created_at:{type:Date, default:Date.now()} 
}); 

var User = new Schema({ 
    name:{type:String,index:true} 
    ,email:{type:String,index:true, unique:true} 
}); 

//Task model                                              
var Task = new Schema({ 
    title:String 
    ,created_by:{type:ObjectId, ref: 'User'} 
    ,created:{type:Date, default:Date.now()} 
    ,responses:[{ 
     type:Number 
     ,user:{type:ObjectId, ref: 'User'} 
     ,comment:String 
     ,avatarURL:String 
     ,photo:{type:ObjectId, ref: 'Photo'} 
     ,created:{type:Date, default:Date.now()} 
    }] 
}); 

//Group model                                              
var Group = new Schema({ 
    name:String 
    ,tasks:[Task] 
}); 

i ten kod błędów out (grupa jest w porządku, zadaniem w tej idx jest w porządku, odpowiedzi jest pustą tablicą, użytkownik jest ważny, zdjęcie jest ważny):

var typePhoto = 6; 
var resp = { 
     type: typePhoto//photo                                     
     ,user: user._id 
     ,photo: photo._id 
}; 


group.tasks[taskIdx].responses.push(resp); //errors out here 

w tym momencie pojawia się następujący błąd:

/home/admin/notitws/node_modules/mongoose/lib/utils.js:434 
     throw err; 
      ^
CastError: Cast to number failed for value "[object Object]" at path "undefined" 
    at SchemaNumber.cast (/home/admin/notitws/node_modules/mongoose/lib/schema/number.js:127:9) 
    at Array.MongooseArray._cast (/home/admin/notitws/node_modules/mongoose/lib/types/array.js:78:15) 
    at Object.map (native) 
    at Array.MongooseArray.push (/home/admin/notitws/node_modules/mongoose/lib/types/array.js:187:23) 
    at exports.taskAddPhoto (/home/admin/notitws/routes/group.js:1097:35) 
    at Promise.exports.createPhoto (/home/admin/notitws/routes/photos.js:106:4) 
    at Promise.addBack (/home/admin/notitws/node_modules/mongoose/lib/promise.js:128:8) 
    at Promise.EventEmitter.emit (events.js:96:17) 
    at Promise.emit (/home/admin/notitws/node_modules/mongoose/lib/promise.js:66:38) 
    at Promise.complete (/home/admin/notitws/node_modules/mongoose/lib/promise.js:77:20) 

Wszelkie pomysły jak to naprawić lub co może być c ausing to?

PS Nie wiem, czy to ma znaczenie, ale w wywołaniu, aby uzyskać grupę, zapełniam tasks.responses.user i tasks.responses.photo i tasks.created_by.

+0

To była wartość w bazie danych, która nie przeszła konwersji typu. Zapisywana wartość była w porządku. To dziwne, że błąd występuje przy zapisie, a nie w znalezisku. –

Odpowiedz

20

Słowo kluczowe "typ" używane jest przez mangustę do określenia typu pola. Mongoose prawdopodobnie myśli, że odpowiedzi są typu Number zamiast array.

Spróbuj:

responses:[{ 
    type: {type: Number} 
    ,user:{type:ObjectId, ref: 'User'} 
    ,comment:String 
    ,avatarURL:String 
    ,photo:{type:ObjectId, ref: 'Photo'} 
    ,created:{type:Date, default:Date.now()} 
}] 

Inną alternatywą byłoby owinąć obiekt odpowiedzi do schematu następnie:

responses: [Response] 
+0

ah, oczywiście! Dziękuję Ci! ... teraz jest to, że nie mogę go rozbić, nie jest zaludniony, ale rozwiązałeś awarię, więc dziękuję ci jeszcze raz! –

+0

Czy próbowałeś po prostu 'default: Date.now' bez nawiasów()? –

2

jestem delegowania co stały mój rzucania do objectID. Jest to historia zaktualizowanego klucza mojego dokumentu funkcji. Dodałem komentarze, aby pokazać, że problematyczny obszar odpowiada problemowi z castowaniem.

importowanie mangusty;

var mongoose = require('mongoose'); 

define objectId;

var ObjectId = mongoose.Schema.Types.ObjectId; 

zdefiniować typ w swoim schemacie;

var featureSchema = new Schema({ 
     name: String, 
     isSystem: { type: Number, min: 0, max: 1 }, 
     updatedBy: {type:ObjectId, ref:'users'}, //here I defined the field! 
     updatedAt: { type: Date, default: Date.now } 
}); 

a następnie włóż dokument za pomocą metody post;

app.post('/features', function (req, res){ 
      var feature; 
      console.log("POST: "); 
      console.log(req.body); 
      feature = new Feature({ 
        name: req.body.name, 
        isSystem: req.body.isSystem, 
        updatedBy: req.body.updatedBy, //here I insert the objectId field 
        updatedAt: new Date() 
      }); 
      feature.save(function (err) { 
        if (!err) { 
          return console.log("created"); 
        } else { 
         return console.log(err); 
        } 
      }); 
     return res.json({ features: feature }); 
    }); 

i wreszcie to jest twój ciąg json. możesz wystrzelić z google chrome javascript console lub podobnej;

jQuery.post("/features", { 
       "name": "Receipt", 
       "isSystem": 0, 
       "updatedBy": "528f3d44afcb60d90a000001" 
    },function (data, textStatus, jqXHR) { 
       console.log("Post resposne:"); console.dir(data);     
       console.log(textStatus);        
       console.dir(jqXHR); 
    }); 
Powiązane problemy