आप मैप रिड्यूस की अवधारणा का उपयोग कर सकते हैं। आइए पहले दस्तावेजों के साथ एक संग्रह बनाएं -
> db.getAllFieldNamesDemo.insertOne({"StudentFirstName":"David","StudentAge":23}); { "acknowledged" : true, "insertedId" : ObjectId("5cd998e9b50a6c6dd317ad90") }
खोज () विधि की मदद से संग्रह से सभी दस्तावेजों को प्रदर्शित करने के लिए क्वेरी निम्नलिखित है -
> db.getAllFieldNamesDemo.find();
यह निम्नलिखित आउटपुट देगा -
{ "_id" : ObjectId("5cd998e9b50a6c6dd317ad90"), "StudentFirstName" : "David", "StudentAge" : 23 }
MongoDB संग्रह में सभी फ़ील्ड नाम प्राप्त करने की क्वेरी निम्नलिखित है -
> myMapReduce = db.runCommand({ "mapreduce" : "getAllFieldNamesDemo", "map" : function() { for (var myKey in this) { emit(myKey, null); } }, "reduce" : function(myKey, s) { return null; }, "out": "getAllFieldNamesDemo" + "_k" }) { "result" : "getAllFieldNamesDemo_k", "timeMillis" : 1375, "counts" : { "input" : 1, "emit" : 3, "reduce" : 0, "output" : 3 }, "ok" : 1 } > db[myMapReduce.result].distinct("_id");
यह दर्ज किए गए नामों को प्रदर्शित करते हुए निम्नलिखित आउटपुट उत्पन्न करेगा -
[ "StudentAge", "StudentFirstName", "_id" ]