कृपया डोमेन संचालित डिज़ाइन में इकाइयों और कुल जड़ों के बीच मुख्य अंतर क्या है। उदाहरण के लिए इकाई ढांचे में, अगर मैं डेटा अखंडता इकाइयों को सुनिश्चित कर सकता हूं तो कुल योग का उपयोग क्या होता है?डोमेन संचालित डिजाइन में एक इकाई और कुल के बीच अंतर
उत्तर
परिभाषा काफी सीधे आगे है:
- कुल योग: मूल रूप से वस्तुओं, कि जड़ कुल के लिए एक स्पष्ट संदर्भ बनाने का एक समूह है, इसलिए जब आप रूट का संदर्भ है, तो आप समुच्चय की अखंडता को सुनिश्चित कर सकते हैं करने के लिए पूरा का पूरा।
कुल डोमेन-संचालित डिज़ाइन में एक पैटर्न है। एक डीडीडी कुल डोमेन ऑब्जेक्ट्स क्लस्टर है जिसे एक इकाई के रूप में माना जा सकता है। एक उदाहरण एक ऑर्डर और इसकी लाइन-आइटम हो सकता है, ये अलग-अलग ऑब्जेक्ट्स अलग होंगे, लेकिन ऑर्डर का इलाज करने के लिए उपयोगी है (इसकी लाइन आइटम के साथ) एक समग्र के रूप में।
कुल मिलाकर इसकी घटक वस्तुओं में से एक को रूट होना चाहिए। कुल के बाहर से कोई भी संदर्भ केवल कुल रूट पर जाना चाहिए। इस प्रकार रूट पूरी तरह से की अखंडता सुनिश्चित कर सकता है।
समेकन डेटा संग्रहण के हस्तांतरण का मूल तत्व हैं - आप पूरे योग को लोड या सहेजने का अनुरोध करते हैं। लेनदेन पार सीमाओं को पार नहीं करना चाहिए।
डीडीडी समेकित कभी-कभी संग्रह कक्षाओं (सूचियों, मानचित्र आदि) के साथ भ्रमित होते हैं। डीडीडी समेकन डोमेन अवधारणाएं हैं (ऑर्डर, क्लिनिक विज़िट, प्लेलिस्ट), जबकि संग्रह सामान्य हैं। एक कुल योग अक्सर में सरल फ़ील्ड के साथ मल्टीप्लेयर संग्रह होते हैं। शब्द "समेकित" एक आम है, और (उदा। यूएमएल) के विभिन्न संदर्भों में प्रयोग किया जाता है, इस स्थिति में यह डीडीडी कुल के रूप में एक ही अवधारणा को संदर्भित नहीं करता है।
- निकाय: एक डाटा मॉडल संदर्भ में, डेटा की संरचना संग्रहीत प्रपत्र की परवाह किए बिना वर्णन करता है।
ईडीएम चुनौतियों कि कई रूपों में संग्रहीत डेटा होने से उत्पन्न होती हैं संबोधित करते हैं। उदाहरण के लिए, ऐसे व्यवसाय पर विचार करें जो संबंधपरक डेटाबेस, टेक्स्ट फ़ाइलें, एक्सएमएल फाइल, स्प्रेडशीट्स और रिपोर्ट में डेटा संग्रहीत करता है। यह डेटा मॉडलिंग, एप्लिकेशन डिज़ाइन और डेटा एक्सेस में महत्वपूर्ण चुनौतियों को प्रस्तुत करता है। डेटा-ओरिएंटेड एप्लिकेशन को डिज़ाइन करते समय, चुनौती कुशल डेटा पहुंच, संग्रहण और स्केलेबिलिटी बलि किए बिना कुशल और रखरखाव कोड लिखना है। जब डेटा में एक रिलेशनल स्ट्रक्चर, डेटा एक्सेस, स्टोरेज, और स्केलेबिलिटी बहुत प्रभावी होती है, लेकिन कुशल और रखरखाव कोड लिखना अधिक कठिन हो जाता है। जब डेटा में ऑब्जेक्ट स्ट्रक्चर होता है, तो ट्रेड-ऑफ़ को उलट दिया जाता है: कुशल डेटा एक्सेस, स्टोरेज और स्केलेबिलिटी की लागत पर कुशल और रखरखाव कोड लिखना आता है।यहां तक कि यदि इन ट्रेड-ऑफ के बीच सही संतुलन पाया जा सकता है, तो नई चुनौतियां उत्पन्न होती हैं जब डेटा एक रूप से दूसरे रूप में स्थानांतरित होता है। एंटिटी डेटा मॉडल किसी भी स्टोरेज स्कीमा से स्वतंत्र इकाइयों और रिश्तों के संदर्भ में डेटा की संरचना का वर्णन करके इन चुनौतियों का समाधान करता है। यह डेटा के संग्रहीत रूप को एप्लिकेशन डिज़ाइन और विकास के लिए अप्रासंगिक बनाता है। और, क्योंकि इकाइयां और रिश्ते डेटा की संरचना का वर्णन करते हैं क्योंकि यह किसी एप्लिकेशन में उपयोग नहीं किया जाता है (इसके संग्रहीत रूप में नहीं), वे एप्लिकेशन विकसित हो सकते हैं।
परिभाषा भिन्न हो सकती है, जिन्हें मार्टिन फाउलर और माइक्रोसॉफ्ट द्वारा परिभाषित किया गया है। उम्मीद है कि हालांकि अंतर को स्पष्ट करता है।
डोमेन संचालित डिजाइन परिप्रेक्ष्य से DbContext
यूनिटऑफवर्क का कार्यान्वयन है और DbSet<T>
एक भंडार का कार्यान्वयन है।
यह वह बिंदु है जहां डीडीडी और एंटिटीफ्रेमवर्क विपरीत है। डीडीडी का सुझाव है कि कुल रूट प्रति रिपोजिटरी है लेकिन EntityFramework प्रति इकाई एक बनाता है।
तो, कुल रूट क्या है?
मान लें कि हमारे पास सोशल नेटवर्क है और इकाइयां पोस्ट, पसंद, टिप्पणी, टैग जैसी हैं। (मुझे विश्वास है कि आप इन इकाइयों के बीच संबंधों की कल्पना कर सकते हैं) कुछ इकाइयां "कुल रूट"
कुल रूट खोजने के लिए मैं यह पता लगाने की कोशिश करता हूं कि कौन सी संस्थाएं बिना किसी अन्य के रह सकती हैं। उदाहरण के लिए, एक पोस्ट के बिना पसंद या टिप्पणी नहीं रह सकती है। फिर पोस्ट एक समग्र जड़ है और हमें पोस्ट रिपोजिटरी की आवश्यकता है या पोस्ट इकाई को एक रिपोजिटरी (इंटरफ़ेस चीज़ जैसे प्रसिद्ध संग्रह) में बदल दें। टिप्पणी और पसंद (साथ ही पोस्ट) के लिए सीआरयूडी परिचालन इस भंडार पर बने रहना चाहिए।
अच्छा उत्तर और परिभाषा, मेरी सिद्धांत परिभाषा के बजाय एक और अधिक कार्यात्मक परिभाषा। – Greg
'डीडीडी का सुझाव है कि कुल मिलाकर एक रिपोजिटरी ...' एक उत्कृष्ट, और कम उपयोग वाली अवधारणा, आईएमएचओ। –
@Mehmet अच्छा वर्णन। बिल्कुल मेरी तस्वीरों की कुल जड़ें थीं। मैंने सोचा कि विदेशी कुंजी और प्राथमिक कुंजी के संबंध में, इकाई ढांचे का उपयोग करके उत्पन्न डेटाबेस तालिका इकाइयों के साथ यह संभव है। क्या एक डोमेन संचालित डिजाइन प्रोजेक्ट के लिए इकाई फ्रेमवर्क इकाइयों को उत्पन्न करना बुद्धिमान होगा? या मैन्युअल रूप से एक बनाओ? ..... अंत में मैं डेटाबेस को कुल जड़ों को कैसे बना सकता हूं? –
- 1. डोमेन संचालित डिजाइन - कुल रूट
- 2. डोमेन संचालित डिजाइन, एसओसी, और इकाई पहचान
- 3. डोमेन संचालित डिजाइन, .NET और इकाई फ्रेमवर्क
- 4. डोमेन संचालित डिजाइन कार्यान्वित
- 5. डोमेन संचालित डिजाइन: कुल रूट कब बनाना है?
- 6. डोमेन संचालित डिजाइन
- 7. डोमेन-संचालित डिजाइन
- 8. डोमेन संचालित डिजाइन बनाम मॉडल संचालित वास्तुकला
- 9. डोमेन-संचालित-डिजाइन
- 10. डोमेन संचालित डिजाइन
- 11. डोमेन संचालित डिजाइन?
- 12. डोमेन संचालित डिजाइन और इकाई फ्रेमवर्क 4.1 (कोड-प्रथम)
- 13. कार्यात्मक प्रोग्रामिंग + डोमेन-संचालित डिजाइन
- 14. आईओसी कंटेनर और डोमेन संचालित डिजाइन
- 15. राज्य पैटर्न और डोमेन संचालित डिजाइन
- 16. डीडीडी (डोमेन-संचालित-डिजाइन) - बड़े समेकित
- 17. डोमेन संचालित डिजाइन, डोमेन ऑब्जेक्ट्स, सेटर्स के बारे में रवैया
- 18. गतिशील भाषाओं में डोमेन संचालित डिजाइन प्रयास?
- 19. डोमेन संचालित डिजाइन Node.js में अनुप्रयोग
- 20. Node.js के लिए डोमेन संचालित डिजाइन
- 21. एनीमिक डोमेन मॉडल बनाम डोमेन मॉडल एक साधारण डोमेन संचालित डिजाइन
- 22. एक एमवीसी वेब अनुप्रयोग के लिए डोमेन संचालित डिजाइन बनाम डाटाबेस संचालित डिजाइन
- 23. डीडीडी: डोमेन संचालित डिजाइन। डोमेन डीडीडी में क्या मतलब है?
- 24. एक आवेदन डिजाइन करने के लिए DDD (डोमेन संचालित डिजाइन) डीसीआई गठबंधन करने के लिए कैसे
- 25. डोमेन-संचालित डिजाइन में एक इंटरफेस को एक समग्र रूट लागू करना चाहिए
- 26. डोमेन संचालित डिजाइन (एसक्यूएल से लिंक) - आप कुल के हिस्सों को कैसे हटाते हैं?
- 27. बुनियादी सुविधाओं और आवेदन कोड डोमेन संचालित डिजाइन
- 28. डोमेन संचालित डिजाइन: वर्कफ़्लो तर्क कहां स्थित है?
- 29. क्या डोमेन-संचालित डिज़ाइन रिपॉजिटरीज़ और स्प्रिंग डेटा वाले लोगों के बीच कोई मेल नहीं है?
- 30. डोमेन संचालित डिजाइन में उपयोगकर्ता सत्रों को कैसे संभालें
हाँ थोड़ा प्रतिक्रिया करता है ... आपकी प्रतिक्रिया के लिए धन्यवाद @ ग्रेग। –
दोनों के लिए परिभाषा दुखद रूप से एक दूसरे के लिए उपयोग की जाती है, जो भ्रमित हो सकती है लेकिन वास्तव में इसका मतलब है। – Greg