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

MongoDB में डेटा वर्जनिंग को लागू करने के तरीके

इसमें गोता लगाते समय पहला बड़ा सवाल यह है कि "आप परिवर्तन कैसे संग्रहीत करना चाहते हैं" ?

  1. मुश्किल?
  2. संपूर्ण रिकॉर्ड प्रतियां?

मेरा व्यक्तिगत दृष्टिकोण अंतर को स्टोर करना होगा। क्योंकि इन अंतरों का प्रदर्शन वास्तव में एक विशेष क्रिया है, मैं अंतर को एक अलग "इतिहास" संग्रह में रखूंगा।

मैं मेमोरी स्पेस को बचाने के लिए विभिन्न संग्रह का उपयोग करूंगा। आप आम तौर पर एक साधारण प्रश्न के लिए पूर्ण इतिहास नहीं चाहते हैं। तो इतिहास को ऑब्जेक्ट से बाहर रखकर आप उस डेटा को पूछे जाने पर सामान्य रूप से एक्सेस की जाने वाली मेमोरी से भी बाहर रख सकते हैं।

अपने जीवन को आसान बनाने के लिए, मैं एक इतिहास दस्तावेज बनाऊंगा जिसमें समय-मुद्रित अंतर का एक शब्दकोश होगा। कुछ इस तरह:

{
    _id : "id of address book record",
    changes : { 
                1234567 : { "city" : "Omaha", "state" : "Nebraska" },
                1234568 : { "city" : "Kansas City", "state" : "Missouri" }
               }
}

अपने जीवन को वास्तव में आसान बनाने के लिए, मैं अपने डेटाऑब्जेक्ट्स (EntityWrapper, जो भी हो) का यह हिस्सा बनाऊंगा जिसका उपयोग मैं अपने डेटा तक पहुंचने के लिए करता हूं। आम तौर पर इन वस्तुओं का इतिहास का कोई न कोई रूप होता है, जिससे आप आसानी से save() . को ओवरराइड कर सकते हैं एक ही समय में यह परिवर्तन करने का तरीका।

अद्यतन करें:2015-10

ऐसा लगता है कि अब JSON अंतर को संभालने के लिए एक युक्ति है। यह अंतर / परिवर्तनों को संग्रहीत करने का एक अधिक मजबूत तरीका लगता है।



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. पाइपलाइन एकत्रीकरण के साथ स्प्रिंग डेटा MongoDB लुकअप

  2. MongoDB क्वेरी सहायता - उप-वस्तु में किसी भी कुंजी के मूल्यों पर क्वेरी

  3. MongoDB:$geoWithin ऑपरेटर का उपयोग करके सही परिणाम नहीं मिल रहा है

  4. मोंगोडीबी सी # ऑब्जेक्ट्स की क्वेरी ऐरे जिसमें संपत्ति मान होता है

  5. रेल में मोंगोइड के साथ मोंगोडीबी - भू-स्थानिक अनुक्रमण