কম্পিউটার

MongoDB সামগ্রিক বাস্তবায়ন - unwind, গ্রুপ এবং প্রকল্প?


MongoDB-তে $unwind প্রতিটি উপাদানের জন্য একটি নথি আউটপুট করতে ইনপুট নথি থেকে একটি অ্যারে ক্ষেত্রকে বিনির্মাণ করে।

$group নির্দিষ্ট _id এক্সপ্রেশন দ্বারা ইনপুট নথিগুলিকে গ্রুপ করতে ব্যবহৃত হয় এবং প্রতিটি স্বতন্ত্র গ্রুপিংয়ের জন্য একটি নথি আউটপুট করে৷

অনুরোধ করা ক্ষেত্রগুলির সাথে নথিগুলিকে পাইপলাইনের পরবর্তী পর্যায়ে যাওয়ার জন্য $project ব্যবহার করা হয়৷

আসুন আমরা নথি-

সহ একটি সংগ্রহ তৈরি করি
> db.demo238.insertOne(
...   {
...
...      "EmailId" : "John@gmail.com",
...      "details" : [
...         {
...            "Name" : "Bob",
...            "isActive" : true
...         }
...      ]
...   }
...);
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e4418e3f4cebbeaebec5152")
}
>
> db.demo238.insertOne(
...   {
...
...      "EmailId" : "Chris@gmail.com",
...      "details" : [
...         {
...            "Name" : "David"
...         }
...      ]
...   }
...);
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e4418e3f4cebbeaebec5153")
}
>
>
> db.demo238.insertOne(
...   {
...
...      "EmailId" : "Mike@gmail.com",
...      "details" : [
...         {
...            "Name" : "Carol",
...            "isActive" : true
...         }
...      ]
...   }
...);
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e4418e4f4cebbeaebec5154")
}

Find() পদ্ধতির সাহায্যে একটি সংগ্রহ থেকে সমস্ত নথি প্রদর্শন করুন:

> db.demo238.find().pretty();

এটি নিম্নলিখিত আউটপুট −

তৈরি করবে
{
   "_id" : ObjectId("5e4418e3f4cebbeaebec5152"),
   "EmailId" : "John@gmail.com",
   "details" : [
      {
         "Name" : "Bob",
         "isActive" : true
      }
   ]
}
{
   "_id" : ObjectId("5e4418e3f4cebbeaebec5153"),
   "EmailId" : "Chris@gmail.com",
   "details" : [
      {
         "Name" : "David"
      }
   ]
}
{
   "_id" : ObjectId("5e4418e4f4cebbeaebec5154"),
   "EmailId" : "Mike@gmail.com",
   "details" : [
      {
         "Name" : "Carol",
         "isActive" : true
      }
   ]
}

MongoDB এগ্রিগেট বাস্তবায়নের জন্য নিম্নোক্ত ক্যোয়ারী - unwind, group and project −

> db.demo238.aggregate(
...   [
...      { "$match": { "details.isActive": true } },
...      { "$unwind": "$details" },
...      { "$match": { "details.isActive": true } },
...      { "$group": {
...         "_id": "$details.Name",
...         "active": { "$first": "$_id" }
...      }}
...   ],
...   function(err,result) {
...
...   }
...);

এটি নিম্নলিখিত আউটপুট −

তৈরি করবে
{ "_id" : "Carol", "active" : ObjectId("5e4418e4f4cebbeaebec5154") }
{ "_id" : "Bob", "active" : ObjectId("5e4418e3f4cebbeaebec5152") }

  1. MongoDB এগ্রিগেটে $match এবং $project বাস্তবায়ন করুন

  2. MongoDB-তে ঘন্টা এবং $avg দ্বারা একত্রিত করতে হবে

  3. ডকুমেন্ট এবং অ্যারে উপাদান থেকে গড় পেতে MongoDB সমষ্টি?

  4. MongoDB সমষ্টি গ্রুপ একাধিক ফলাফল?