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") }