इकाई ढांचा - लेन-देन
एंटिटी फ्रेमवर्क के सभी संस्करणों में, जब भी आप निष्पादित करते हैं SaveChanges()डेटाबेस को सम्मिलित करने, अपडेट करने या हटाने के लिए, फ्रेमवर्क उस ऑपरेशन को लेनदेन में लपेट देगा। जब आप SaveChanges का आह्वान करते हैं, तो संदर्भ स्वचालित रूप से एक लेन-देन शुरू करता है और दृढ़ता या सफल होने के आधार पर इसे वापस करता है या रोल करता है।
यह सब आपके लिए पारदर्शी है, और आपको इससे निपटने की कभी आवश्यकता नहीं होगी।
यह लेन-देन ऑपरेशन को निष्पादित करने के लिए केवल लंबे समय तक रहता है और फिर पूरा होता है।
जब आप ऐसे किसी अन्य ऑपरेशन को निष्पादित करते हैं, तो एक नया लेनदेन शुरू होता है।
इकाई ढांचा 6 निम्नलिखित प्रदान करता है -
Database.BeginTransaction ()
यह उपयोगकर्ताओं के लिए लेनदेन शुरू करने और पूरा करने के लिए मौजूदा DbContext के भीतर एक सरल और आसान तरीका है।
यह एक ही लेन-देन के भीतर कई ऑपरेशनों को संयोजित करने की अनुमति देता है और इसलिए या तो सभी प्रतिबद्ध हैं या सभी को एक के रूप में वापस रोल किया गया है।
यह उपयोगकर्ता को लेनदेन के लिए अलगाव स्तर को अधिक आसानी से निर्दिष्ट करने की अनुमति देता है।
Database.UseTransaction ()
यह DbContext को एक लेनदेन का उपयोग करने की अनुमति देता है, जिसे इकाई ढांचे के बाहर शुरू किया गया था।
आइए निम्नलिखित उदाहरण पर एक नज़र डालें जहां एक ही लेनदेन में कई ऑपरेशन किए जाते हैं। कोड इस प्रकार है -
class Program {
static void Main(string[] args) {
using (var context = new UniContextEntities()) {
using (var dbContextTransaction = context.Database.BeginTransaction()) {
try {
Student student = new Student() {
ID = 200,
FirstMidName = "Ali",
LastName = "Khan",
EnrollmentDate = DateTime.Parse("2015-12-1")
};
context.Students.Add(student);
context.Database.ExecuteSqlCommand(@"UPDATE Course SET Title =
'Calculus'" + "WHERE CourseID = 1045");
var query = context.Courses.Where(c ⇒ c.CourseID == 1045);
foreach (var item in query) {
Console.WriteLine(item.CourseID.ToString()
+ " " + item.Title + " " + item.Credits);
}
context.SaveChanges();
var query1 = context.Students.Where(s ⇒ s.ID == 200);
foreach (var item in query1) {
Console.WriteLine(item.ID.ToString()
+ " " + item.FirstMidName + " " + item.LastName);
}
dbContextTransaction.Commit();
} catch (Exception) {
dbContextTransaction.Rollback();
}
}
}
}
}
लेनदेन की शुरुआत के लिए आवश्यक है कि अंतर्निहित स्टोर कनेक्शन खुला हो।
इसलिए Database.BeginTransaction () कॉल करने पर कनेक्शन खुल जाएगा, अगर यह पहले से ही नहीं खुला है।
यदि DbContextTransaction ने कनेक्शन खोला है, तो यह डिस्पोज़ () कहे जाने पर इसे बंद कर देगा।