मैं एक अटैचमेंट ऑब्जेक्ट मॉडल करने के लिए ईएफ 4 एसटीई का उपयोग कर रहा हूं। अनुलग्नक में एक नाम, विवरण, तिथि, और सबसे महत्वपूर्ण डेटा (byte[]
) शामिल है। लोडिंग को अनुकूलित करने के लिए, मैं डेटा प्रॉपर्टी को तब तक पुनर्प्राप्त नहीं करना चाहता जब तक कि यह बिल्कुल जरूरी न हो, यानी जब उपयोगकर्ता क्लाइंट से Download
पर क्लिक करता है।इकाई फ्रेमवर्क स्प्लिट टेबल हटाएं
इस दृष्टिकोण का पालन करने के प्रयास में, मैंने here वर्णित तालिका-विभाजन तकनीक का उपयोग किया। मैंने अटैचमेंटसंलग्नक (नाम, विवरण, दिनांक) और अटैचमेंटडाटा (डेटा) को विभाजित किया। यह मेरे ईएफ मॉडल में 1 से 1 रिश्ते है। अटैचमेंटडाटा (यानी attachment.AttachmentData == null
) के बिना अटैचमेंट को हटाने का प्रयास करने तक मैं सबकुछ बढ़िया काम करता हूं। मुझे निम्नलिखित अपवाद मिलता है:
अमान्य डेटा का सामना करना पड़ा। एक आवश्यक संबंध गुम है। बाधा उल्लंघन के स्रोत को निर्धारित करने के लिए राज्य एंटर्री की जांच करें।
मैं एक similar post देखा, लेकिन मैं इसे STE की और ApplyChanges
विस्तार विधि के साथ काम करने के लिए नहीं कर पा रहे।
अभी मेरा डेटा एक्सेस कोड सरल है: मैं संदर्भ ApplyChanges()
पर SaveChanges()
पर कॉल करता हूं।
मैंने एसक्यूएल फ़ंक्शन को सरल हटाने की कोशिश की है और इसे दोनों इकाइयों में मैप किया है और वास्तव में काम किया है; हालांकि यह डालने तोड़ दिया। मैं दोनों इकाइयों के लिए सभी गुणों के लिए एक सम्मिलित समारोह मैप करने के लिए प्रतीत नहीं कर सकता।
कुछ अन्य विकल्पों पर कोई विचार मैं कोशिश कर सकता हूं? अनुलग्नक और अनुलग्नक डेटा के बीच संबंध वैकल्पिक हो सकता है? जब मैं इसे 1 से 0+ बना देता हूं, तो मुझे एक मैपिंग त्रुटि मिलती है जो कहती है कि Their primary keys may collide
।
किसी भी सुझाव के लिए खोलें।
धन्यवाद!
धन्यवाद प्रतिक्रिया के लिए एक गुच्छा! बहुत अच्छा काम करता है! –
यह मुझे गहराई से परेशान करता है: क्यों ईएफ इसे समझ नहीं सकता है, क्योंकि इकाइयों को एक ही टेबल में संग्रहीत किया जाता है, उनमें से एक को हटाने से दूसरे को भी हटा दिया जाएगा? आपको इसे लोड करने की आवश्यकता क्यों है? –
@FyodorSoikin: मुझे लगता है क्योंकि किसी ने अभी तक उस सुविधा को लागू नहीं किया है। –