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

Jak wybrać dane z podanym warunkiem

edytuj

o takiej strukturze:

{
    "_id" : ObjectId("575e4c8731dcfb59af388e1d"),
    "name" : "Maria",
    "providers" : [ 
        {
            "type" : "facebook",
            "data" : "fb.com",
            "privacy" : true
        }, 
        {
            "type" : "twitter",
            "data" : "twitter.com",
            "privacy" : false
        }, 
        {
            "type" : "google",
            "data" : "google.com",
            "privacy" : true
        }, 
        {
            "type" : "phno",
            "data" : "+1-1289741824124",
            "privacy" : true
        }
    ]
}

z zapytaniem takim:

db.maria.aggregate([{
            $project : {
                _id : 1,
                name : 1,
                "providers" : {
                    $filter : {
                        input : "$providers",
                        as : "p",
                        cond : {
                            $eq : ["$$p.privacy", true]
                        }
                    }
                }
            }
        }
    ])
    ])

uzyskujemy dynamiczne wyniki i nie musimy dbać o nazwę dostawcy, ponieważ jest ona objęta ogólną strukturą

{
    "providers" : [ 
        {
            "type" : "facebook",
            "data" : "fb.com",
            "privacy" : true
        }, 
        {
            "type" : "google",
            "data" : "google.com",
            "privacy" : true
        }, 
        {
            "type" : "phno",
            "data" : "+1-1289741824124",
            "privacy" : true
        }
    ],
    "name" : "Maria"
}

koniec edycji

Sposób, w jaki możesz to uzyskać, to użycie frameworka agregacji. Ponieważ mamy tablicę dla każdego pola, musimy ją najpierw rozwinąć, a następnie możemy użyć $project ustawić wartość pola lub po prostu null. Ponieważ wygląda to na proste zapytanie, może sprawić trochę kłopotów. Sposób, w jaki możemy to poprawić, to zmiana struktury dokumentu, aby mieć tablicę dostawców i proste pole providerType.

Etapy agregacji poniżej:

db.maria.find()
var unwindFb = {
    $unwind : "$facebook"
}
var unwindtw = {
    $unwind : "$twitter"
}
var unwindgo = {
    $unwind : "$google"
}
var unwindph = {
    $unwind : "$phno"
}
var project = {
    $project : {
        _id : 1,
        name : 1, // list other fields here

        facebook : {
            $cond : {
                if  : {
                    $gte : ["$facebook.privacy", true]
                },
            then : [{
                    data : "$facebook.data",
                    privacy : "$facebook.privacy"
                }
            ],
            else  : null
        }
    },
    twitter : {
        $cond : {
            if  : {
                $gte : ["$twitter.privacy", true]
            },
        then : [{
                data : "$twitter.data",
                privacy : "$twitter.privacy"
            }
        ],
        else  : null
    }
},
google : {
    $cond : {
        if  : {
            $gte : ["$google.privacy", true]
        },
    then : [{
            data : "$google.data",
            privacy : "$google.privacy"
        }
    ],
    else  : null
}
},
phno : {
    $cond : {
        if  : {
            $gte : ["$phno.privacy", true]
        },
    then : [{
            data : "$phno.data",
            privacy : "$phno.privacy"
        }
    ],
    else  : null
}
}
}
}

db.maria.aggregate([unwindFb, unwindtw, unwindgo, unwindph, project])

wtedy wynik wygląda tak:

{
    "_id" : ObjectId("575df49d31dcfb59af388e1a"),
    "name" : "Maria",
    "facebook" : [ 
        {
            "data" : "fb.com",
            "privacy" : true
        }
    ],
    "twitter" : null,
    "google" : [ 
        {
            "data" : "google.com",
            "privacy" : true
        }
    ],
    "phno" : [ 
        {
            "data" : "+1-1289741824124",
            "privacy" : true
        }
    ]
}


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Jak za pomocą MongoDB zaktualizować dokument podrzędny tablicy podrzędnej, gdy pozycja elementu jest nieznana?

  2. Problem z zapisywaniem plików MongoDB GridFS za pomocą Node.JS

  3. Dodaj pole o rosnącej wartości w MongoDB Aggregation na podstawie warunku

  4. Rails 4/Devise/MongoDB:Niedozwolone parametry przy użyciu niestandardowych właściwości i silnych parametrów

  5. Najlepsze praktyki dotyczące tworzenia kopii zapasowych baz danych