इकाई फ्रेमवर्क - संगामिति
किसी भी डेटा ऐक्सेस डेवलपर को डेटा कंसीडर से संबंधित प्रश्न का उत्तर देते समय कठिनाई का सामना करना पड़ता है, "एक ही समय में एक से अधिक व्यक्ति एक ही डेटा को एडिट करने से क्या होता है?"
हमारे बीच और अधिक भाग्यशाली व्यापारिक नियमों से निपटते हैं जो कहते हैं कि "कोई समस्या नहीं है, जीत में आखिरी है।"
इस मामले में, संगामिति एक मुद्दा नहीं है। अधिक संभावना है, यह उतना सरल नहीं है, और एक बार में प्रत्येक परिदृश्य को हल करने के लिए चांदी की गोली नहीं है।
डिफ़ॉल्ट रूप से, एंटिटी फ्रेमवर्क "जीत में अंतिम एक" का अर्थ लेगा, जिसका अर्थ है कि नवीनतम अपडेट लागू किया जाता है, भले ही किसी और ने समय डेटा को पुनर्प्राप्त करने के बीच डेटा अपडेट किया हो और समय डेटा सहेजा गया हो।
आइए इसे बेहतर ढंग से समझने के लिए एक उदाहरण लेते हैं। निम्न उदाहरण पाठ्यक्रम तालिका में एक नया कॉलम वर्जननो जोड़ता है।
डिजाइनर पर जाएं और डिजाइनर विंडो पर राइट-क्लिक करें और डेटाबेस से अपडेट मॉडल का चयन करें ...
आप देखेंगे कि कोर्स एंटिटी में एक और कॉलम जोड़ा गया है।
नए बनाए गए संस्करण VersionNo पर राइट-क्लिक करें और गुण का चयन करें और निम्नलिखित छवि में दिखाए गए अनुसार ConcurrencyMode को फिक्स्ड में बदलें।
किसी भी समय एक पाठ्यक्रम अद्यतन किया जाता है, किसी भी समय एक पाठ्यक्रम को अद्यतन किया जाता है, के लिए पाठ्यक्रम के। के साथ सेट करें, अद्यतन कमांड अपने EntityKey और उसके VersionNo संपत्ति का उपयोग कर पाठ्यक्रम के लिए दिखेगा।
आइए एक साधारण परिदृश्य पर नज़र डालें। दो उपयोगकर्ता एक ही समय में एक ही कोर्स को प्राप्त करते हैं और उपयोगकर्ता 1 मैथ्स के लिए उस पाठ्यक्रम का शीर्षक बदल देता है और उपयोगकर्ता से पहले परिवर्तन बचाता है। बाद में जब उपयोगकर्ता 2 उस पाठ्यक्रम का शीर्षक बदलता है जिसे उपयोगकर्ता 1 से पहले पुनर्प्राप्त किया गया था, तो अपने परिवर्तनों को सहेजें, इसमें केस उपयोगकर्ता 2 को समवर्ती अपवाद मिलेगा"User2: Optimistic Concurrency exception occured"।
using System;
using System.Data.Entity;
using System.Data.Entity.Infrastructure;
using System.Linq;
namespace DatabaseFirstDemo {
class Program {
static void Main(string[] args) {
Course c1 = null;
Course c2 = null;
//User 1 gets Course
using (var context = new UniContextEntities()) {
context.Configuration.ProxyCreationEnabled = false;
c1 = context.Courses.Where(s ⇒ s.CourseID == 1).Single();
}
//User 2 also get the same Course
using (var context = new UniContextEntities()) {
context.Configuration.ProxyCreationEnabled = false;
c2 = context.Courses.Where(s ⇒ s.CourseID == 1).Single();
}
//User 1 updates Course Title
c1.Title = "Edited from user1";
//User 2 updates Course Title
c2.Title = "Edited from user2";
//User 1 saves changes first
using (var context = new UniContextEntities()) {
try {
context.Entry(c1).State = EntityState.Modified;
context.SaveChanges();
} catch (DbUpdateConcurrencyException ex) {
Console.WriteLine("User1: Optimistic Concurrency exception occurred");
}
}
//User 2 saves changes after User 1.
//User 2 will get concurrency exection
//because CreateOrModifiedDate is different in the database
using (var context = new UniContextEntities()) {
try {
context.Entry(c2).State = EntityState.Modified;
context.SaveChanges();
} catch (DbUpdateConcurrencyException ex) {
Console.WriteLine("User2: Optimistic Concurrency exception occurred");
}
}
}
}
}