MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Jak zastosować warunek na wynik $lookup w mongoDB?

Nie możesz użyć „$match” z metodą obiektu po „$lookup”, ponieważ wartości zwracane przez „$lookup” są wartościami tablicowymi. Lepiej dodaj funkcję "$unwind" po wyszukaniu, a następnie zgrupuj ją.

Przykładowe zapytanie

 db
.album
.aggregate([
    {
        $lookup:{
            from:"photo",
            localField:"_id",
            foreignField:"album_id",
            as:"photo"
        }
     },
    {
        preserveNullAndEmptyArrays : true,
        path : "$photo"
    },
    {
        $match:{
            "photo.flag": 1
        }
     },
     {
        $group : {
            _id : {
                id : "$_id",
                album_name: "$album_name",
                album_description: "$album_description",
                emoji_id: "$emoji_id"
            },
            photo: {
                $push : "$photo"
            }
        }
     }
    {
         $lookup:{
            from:"emoji",
            localField:"_id.album_emoji",
            foreignField:"_id",
            as:"emoji"
         }
    },
    {
         $project:{
            album_name:"$album_name",
            album_description:"$album_description",
            emoji:"$emoji",
            photo:"$photo",
            total_photos: {$size: "$photo"}
         }
    }
])

Lub użyj „$filter”.

db
.album
.aggregate([
    {
        $lookup:{
            from:"photo",
            localField:"_id",
            foreignField:"album_id",
            as:"photo"
        }
     },
    {
        $project: {
            id : "$_id",
            album_name: "$album_name",
            album_description: "$album_description",
            emoji_id: "$emoji_id",
            photo: {
                $filter : {
                    input: "$photo",
                    as : "photo_field",
                    cond : {
                        $eq: ["$$photo_field.flag",1]
                    }
                }
            }
        }
    },
    {
         $lookup:{
            from:"emoji",
            localField:"album_emoji",
            foreignField:"_id",
            as:"emoji"
         }
    },
    {
         $project:{
            album_name:"$album_name",
            album_description:"$album_description",
            emoji:"$emoji",
            photo:"$photo",
            total_photos: {$size: "$photo"}
         }
    }
])


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Wyszukiwanie geoprzestrzenne Mongoose:odległość nie działa

  2. Wykonaj skrypt powłoki mongodb za pomocą sterownika C#

  3. Jak zezwolić na puste pole podczas aktualizacji w Mongoose?

  4. Zapytanie o inny model w metodzie instancji innego modelu

  5. Jak mogę użyć wyrażenia regularnego w mongodb przez mongolab?