MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

Wählen Sie verschachtelte Felder in mongo db aus

Sie müssen wie folgt aggregieren:

  • Erstellen Sie eine find Objekt, um nur die Datensätze abzugleichen, die die Sprache enthalten($exists).
  • Erstellen Sie eine Projection Objekt, um die Felder zu projizieren.

Code:

var currentLang = "en";
var project = {};
project["title"] = "$"+currentLang+".title";
project["content"] = "$"+currentLang+".content";
project["images"] = 1;

var find = {};
find[currentLang] = {"$exists":true};

db.collection.aggregate([
{$match:find},
{$project:project}
])