2016-08-25 6 views
1
var CarSchema = new Schema({ 
    name: {type: String}, 
    partIds: [{type: Schema.Types.ObjectId, ref: 'Part'}], 
}); 

var PartSchema = new Schema({ 
    name: {type: String}, 
    props: [ 
     { colour: {type: String}, shape: {type:String} } 
    ], 
}); 

Zum BeispielMongoose: Bestücken verschachtelte Array Objekt mit Projektion

Car = { 
     name: "BMW", 
     partIds:[ObjectId("57baa43e152654f80aac36a6")]} 

Part = { 
     _id: ObjectId("57baa43e152654f80aac36a6"), 
     name: "Piston", 
     props: [{colour:"red", shape: "Cubical"},{colour:"green", shape: "cylindrical"}] 

Also, wenn ich mir Abfrage ein Dokument wie diese erhalten soll:

Car = { 
     name: "BMW", 
     partIds: [{ 
_id:ObjectId("57baa43e152654f80aac36a6"), name:"Piston", props: [{colour:"red", shape:"cubical"}] 
    } 

Die Array Requisiten nur mit Element haben sollte Farbe rot

Ich möchte Auto mit Part Array so besetzen, dass seine Prop-Array nur das Objekt mit Colo haben Dein Rot. Gibt es sowieso, um es zu tun, oder würde ich altmodische Art und Weise durch Requisiten-Array durchlaufen müssen, die seiner Farbe mit rot entsprechen.

+0

Haben Sie bereits die 'part' Kollektion? Oder erstellen Sie es und speichern Sie seine ID in 'Car' Collection? –

+0

Die Teile-Sammlung ist anders und ihre IDs sind in Auto-Sammlungen 'partIds –

+0

gespeichert, so dass Sie 'Teil'-Dokument erstellen und seine ID in' Auto'-Sammlung speichern möchten, wenn die Farbe rot ist? –

Antwort

1

Sie können dies tun, indem Sie die select Option in Ihrem populate Anruf bereitstellt:

Car.findOne() 
    .populate({ 
     path: 'partIds', 
     select: { props: { $elemMatch: { colour: 'red' } }, name: 1 } 
    }) 
    .exec(callback); 

Ergebnis:

{ _id: 57c085451cd8dfcdf814f640, 
    name: 'BMW', 
    partIds: 
    [ { _id: 57baa43e152654f80aac36a6, 
     name: 'Piston', 
     props: [ { colour: 'red', shape: 'Cubical' } ] } ] } 

Die select verwendet den $elemMatch Projektionsoperator nur die rote props auswählen Element.

0

können Sie dies versuchen, es sollte Sie bekommen, was Sie wollen.

car.find({"partIds.props.colour" : "red"}) 
    .populate('partIds') 
    .exec(function(err,result){...}); 
Verwandte Themen