sql >> Database teknologi >  >> NoSQL >> MongoDB

Betinget projektion i mongodb ved hjælp af c# driver

Sådan ville jeg gå til det. For at du kan fjerne gruppe-id'et "artefakt", skal du projicere gruppeoutputtet og ikke inkludere id'et.

db.getCollection('MyClass').aggregate( [
{$unwind: '$Class'}, 
{ $project : {  Name : 1 , 
                Occupation : 1, 
                Class : {
                    ClassType:1, 
                    Professors:{
                        $cond: {
                            if: { $eq: ["$Class.ClassType", "English"] },
                            then: [],
                            else: "$Class.Professors"
                                }
                    }
                }
            } 
    },
{$group: {
    _id: '$_id',
    Name: {$first: '$Name'},
    Occupation: {$first: '$Occupation'},
    Class: {$push: '$Class'}
}},

] )




  1. Sender yderligere krukker til Spark via spark-submit

  2. Mongodb Sharding - ingen sådan kommando:'addShard'

  3. Gør Meteor reaktiv over for specifikke underelementer af Meteor.user()

  4. Hvad er forskellen mellem HSET og HMSET metode i redis database