2011-12-28 9 views
5

मान लीजिए मैं एक ही समय में निम्नलिखित टेबल्स में रिकॉर्ड डालने हूँ
तालिका 1
तालिका 2
तालिका 3
सारणी 4
टेबल 5कैसे

अब entites के लिए LINQ में लेन-देन maintan करने के लिए क्या मैं करना चाहते हैं, किसी भी अपवाद या त्रुटि के मामले में तालिका 3 में सम्मिलन के दौरान होता है, उसके बाद रिकॉर्ड करें जो कि पहले से सम्मिलित है (उदाहरण के लिए तालिका 1 और तालिका 2 में) रोल रोल होना चाहिए ...

कैसे कर सकते हैं मैं इस तरह के लेनदेन का प्रबंधन?

उत्तर

3

डिफ़ॉल्ट रूप से, SaveChanges लेन-देन (डॉक्स में Remarks part देखें)

में निष्पादित करेंगे आप लेन-देन पर अधिक नियंत्रण चाहते हैं, तो आप लपेट कर सकते हैं अपने SaveChanges एक TransactionScope में ब्लॉक। SaveChanges तब आपके परिवेश लेनदेन को उठाएंगे और उस का उपयोग करेंगे।

यह तब उपयोगी हो सकता है जब आप एक वितरित लेनदेन चाहते हैं (उदाहरण के लिए एकाधिक संदर्भों के साथ या यदि आप डब्ल्यूसीएफ का उपयोग करते हैं)।

आप उल्लेख किया है कि आप विभिन्न मॉडलों का उपयोग करें, आप एक TransactionScope के भीतर दोनों ObjectContexts का उपयोग करें (और AcceptAllChanges साथ some logic का उपयोग करें) होगा

आपका कोड तो ऐसा दिखाई देगा:

using (TransactionScope scope = new TransactionScope()) 
{ 
    //Do something with context1 
    //Do something with context2 


    //Save Changes but don't discard yet 
    context1.SaveChanges(false); 

    //Save Changes but don't discard yet 
    context2.SaveChanges(false); 


    //if we get here things are looking good. 
    scope.Complete(); 

    //If we get here it is save to accept all changes. 
    context1.AcceptAllChanges(); 
    context2.AcceptAllChanges(); 
} 
+0

यूप मेरा जवाब मिला, धन्यवाद :) –

4

इस इकाई की रूपरेखा 4

के डिफ़ॉल्ट व्यवहार को लेन-देन निहित है जैसे ही आप SaveChanges फोन किसी भी त्रुटि एक रोलबैक को गति प्रदान करेगा है ..।

+0

मैं इसे स्वयं संभाल कर सकते हैं ? वास्तव में तालिका 1 की प्राथमिक कुंजी तालिका 2 के लिए विदेशीकी होगी और तालिका 2 का पीके तालिका 3 के लिए एफके होगा और इसी तरह ... तो यह कैसे काम करेगा? –

+0

@DotNetIsMyPower आपको उन्हें जोड़ने की ज़रूरत है। इस संगठन को निर्दिष्ट करें जैसे फ़ील्ड पहले से ही उपलब्ध हैं। Table2.Prop = Table1.Prop; आदि – scartag

+0

लेकिन वे अलग मॉडल में हैं। हालांकि मुझे कोशिश करने दो। @scartag त्वरित उत्तर के लिए धन्यवाद दोस्त –