এর জন্য $group এর সাথে aggregate() এবং group ব্যবহার করুন। আসুন নথি-
সহ একটি সংগ্রহ তৈরি করি> db.demo354.insertOne({"Name1":"Chris","Name2":"David"});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e5685a6f8647eb59e5620c0")
}
> db.demo354.insertOne({"Name1":"Chris","Name2":"David"});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e5685a9f8647eb59e5620c1")
}
> db.demo354.insertOne({"Name1":"Chris","Name2":"Bob"});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e5685aff8647eb59e5620c2")
}
> db.demo354.insertOne({"Name1":"Carol","Name2":"John"});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e5685c4f8647eb59e5620c3")
}
> db.demo354.insertOne({"Name1":"Carol","Name2":"John"});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e5685c5f8647eb59e5620c4")
} Find() পদ্ধতি -
এর সাহায্যে একটি সংগ্রহ থেকে সমস্ত নথি প্রদর্শন করুন> db.demo354.find();
এটি নিম্নলিখিত আউটপুট −
তৈরি করবে{ "_id" : ObjectId("5e5685a6f8647eb59e5620c0"), "Name1" : "Chris", "Name2" : "David" }
{ "_id" : ObjectId("5e5685a9f8647eb59e5620c1"), "Name1" : "Chris", "Name2" : "David" }
{ "_id" : ObjectId("5e5685aff8647eb59e5620c2"), "Name1" : "Chris", "Name2" : "Bob" }
{ "_id" : ObjectId("5e5685c4f8647eb59e5620c3"), "Name1" : "Carol", "Name2" : "John" }
{ "_id" : ObjectId("5e5685c5f8647eb59e5620c4"), "Name1" : "Carol", "Name2" : "John" } অন্য ক্ষেত্র দ্বারা গোষ্ঠীবদ্ধ অনন্য ক্ষেত্রগুলির সংখ্যা গণনা করার জন্য নিম্নলিখিত প্রশ্ন রয়েছে −
> db.demo354.aggregate([
... {
... $group: {
... _id: {
... "Name1": "$Name1",
... "Name2": "$Name2"
... },
... }
... },
... {
... $group: {
... _id: "$_id.Name1",
... "Name2": { $sum: 1 }
... }
... },
... {
... $project: {
... _id: 0,
... Name1: "$_id",
... Name2: 1
... }
... }
... ]) এটি নিম্নলিখিত আউটপুট −
তৈরি করবে{ "Name2" : 2, "Name1" : "Chris" }
{ "Name2" : 1, "Name1" : "Carol" }