MongoDB
 sql >> डेटाबेस >  >> NoSQL >> MongoDB

तिथि के अनुसार MongoDb एकत्रीकरण समूह

db.foos.aggregate(
    [   
        {   $project : { day : {$substr: ["$TimeStamp", 0, 10] }}},        
        {   $group   : { _id : "$day",  number : { $sum : 1 }}},
        {   $sort    : { _id : 1 }}        
    ]
)

तिथि के अनुसार समूह को एकत्रीकरण ढांचे में दो चरणों में किया जा सकता है, यदि छँटाई वांछित है, तो परिणाम को छाँटने के लिए एक अतिरिक्त तीसरे चरण की आवश्यकता है:

  1. $project $substr . के संयोजन में प्रत्येक दस्तावेज़ से ISODate ऑब्जेक्ट के पहले 10 वर्ण (YYYY:MM:DD) लेता है (परिणाम "_id" और "दिन" फ़ील्ड वाले दस्तावेज़ों का एक संग्रह है);
  2. $group दिन के हिसाब से समूह, प्रत्येक मिलान दस्तावेज़ के लिए संख्या 1 जोड़ना (संक्षेप करना);
  3. $sort "_id" से आरोही, जो पिछले एकत्रीकरण चरण से एक दिन है - यदि क्रमबद्ध परिणाम वांछित है तो यह वैकल्पिक है।

यह समाधान db.twitter.ensureIndex( { TimeStamp: 1 } ) जैसी अनुक्रमणिकाओं का लाभ नहीं उठा सकता , क्योंकि यह ISODate ऑब्जेक्ट को फ़्लाई पर एक स्ट्रिंग ऑब्जेक्ट में बदल देता है। बड़े संग्रह (लाखों दस्तावेज़) के लिए यह एक प्रदर्शन बाधा हो सकती है और अधिक परिष्कृत तरीकों का उपयोग किया जाना चाहिए।



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. कैसे प्रतिक्रिया में बेस 64 छवि दिखाने के लिए?

  2. खोज विधि में AND - ऑपरेटर का उपयोग करें

  3. दस्तावेज़ के बाहर निहित विशेषताओं के आधार पर MapReduce एकत्रीकरण

  4. MongoDB नमूना ऑपरेटर

  5. मोंगोडीबी सेवा फेडोरा में नहीं चल रही है