2013-02-21 3 views
8

utilizzando Mongoose.js con node.js.mongoose.js CastError: Cast su numero non riuscito per il valore "[oggetto oggetto]" sul percorso "indefinito"

ho questo schema:

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] 
}); 

e questo codice errori fuori (gruppo va bene, compito che IDX va bene, le risposte è un array vuoto, l'utente è valido, foto è valido):

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


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

a quel punto ricevo il seguente errore:

/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) 

Tutte le idee su come risolvere questo o quello che potrebbe essere c aiutandolo?

PS Non so se è importante ma nella chiamata per ottenere gruppo sto popolando tasks.responses.user e tasks.responses.photo e tasks.created_by.

+0

Era il valore nel database che non riusciva alla conversione del tipo. Il valore che si sta salvando andava bene. È strano che l'errore si verifichi sul salvataggio e non sul ritrovamento. –

risposta

20

La parola chiave "tipo" viene utilizzata da mangusta per determinare il tipo di campo. Mongoose probabilmente pensa che le risposte siano di tipo Numero anziché di matrice.

Prova:

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

Un'altra alternativa sarebbe quella di avvolgere il vostro oggetto risposta in uno schema di allora:

responses: [Response] 
+0

ah, certo! Grazie! ... ora è che ho capito che non va in crash non è popolato, ma hai risolto l'incidente quindi grazie ancora! –

+0

Hai provato semplicemente "default: Date.now' senza le parentesi()? –

2

Vi metto quello fissato la mia casting per objectId. È la storia della chiave aggiornata del mio documento di caratteristiche. Ho aggiunto alcuni commenti per mostrare che l'area problematica corrisponde al problema del casting.

importazione mangusta;

var mongoose = require('mongoose'); 

definire objectId;

var ObjectId = mongoose.Schema.Types.ObjectId; 

definire il tipo nel proprio schema;

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 } 
}); 

e quindi inserire il documento tramite metodo 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 }); 
    }); 

e infine questa è la stringa JSON. puoi attivarlo da google chrome javascript console o uno simile;

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); 
    });