সাব-ডকুমেন্ট ক্ষেত্রের মানগুলির স্বতন্ত্র তালিকা পেতে, আপনি ডট(.) ব্যবহার করতে পারেন। সিনট্যাক্স নিম্নরূপ -
db.yourCollectionName.distinct("yourOuterFieldName.yourInnerFieldName");
ধারণাটি বুঝতে, আসুন ডকুমেন্টের সাথে একটি সংগ্রহ তৈরি করি। একটি নথির সাথে একটি সংগ্রহ তৈরি করার প্রশ্নটি নিম্নরূপ -
> db.getDistinctListOfSubDocumentFieldDemo.insertOne( ... { ... "StudentId": 101, ... "StudentPersonalDetails": [ ... { ... "StudentName": "John", ... "StudentAge":24 ... }, ... { ... "StudentName": "Carol", ... "StudentAge":21 ... } ... ] ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5c90a9abb74d7cfe6392d7d8") } > db.getDistinctListOfSubDocumentFieldDemo.insertOne( ... ... { ... "StudentId": 102, ... "StudentPersonalDetails": [ ... { ... "StudentName": "Carol", ... "StudentAge":26 ... }, ... { ... "StudentName": "Bob", ... "StudentAge":21 ... } ... ] ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5c90a9ceb74d7cfe6392d7d9") } > db.getDistinctListOfSubDocumentFieldDemo.insertOne( ... { ... "StudentId": 103, ... "StudentPersonalDetails": [ ... { ... "StudentName": "Bob", ... "StudentAge":25 ... }, ... { ... "StudentName": "David", ... "StudentAge":24 ... } ... ] ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5c90a9e6b74d7cfe6392d7da") }
Find() পদ্ধতির সাহায্যে একটি সংগ্রহ থেকে সমস্ত নথি প্রদর্শন করুন। প্রশ্নটি নিম্নরূপ -
> db.getDistinctListOfSubDocumentFieldDemo.find().pretty();
নিচের আউটপুট −
{ "_id" : ObjectId("5c90a9abb74d7cfe6392d7d8"), "StudentId" : 101, "StudentPersonalDetails" : [ { "StudentName" : "John", "StudentAge" : 24 }, { "StudentName" : "Carol", "StudentAge" : 21 } ] } { "_id" : ObjectId("5c90a9ceb74d7cfe6392d7d9"), "StudentId" : 102, "StudentPersonalDetails" : [ { "StudentName" : "Carol", "StudentAge" : 26 }, { "StudentName" : "Bob", "StudentAge" : 21 } ] } { "_id" : ObjectId("5c90a9e6b74d7cfe6392d7da"), "StudentId" : 103, "StudentPersonalDetails" : [ { "StudentName" : "Bob", "StudentAge" : 25 }, { "StudentName" : "David", "StudentAge" : 24 } ] }
সাব-ডকুমেন্ট ফিল্ডের মানগুলির স্বতন্ত্র তালিকা পাওয়ার জন্য এখানে ক্যোয়ারী রয়েছে −
> db.getDistinctListOfSubDocumentFieldDemo.distinct("StudentPersonalDetails.StudentName");
নিচের আউটপুট −
[ "Carol", "John", "Bob", "David" ]