इकाई ढांचा - मान्यता

इस अध्याय में आइए हम उन मान्य तकनीकों के बारे में जानें, जिनका उपयोग ADO.NET इकाई ढांचे में मॉडल डेटा को मान्य करने के लिए किया जा सकता है। एंटिटी फ्रेमवर्क सत्यापन सुविधाओं की एक शानदार विविधता प्रदान करता है जिसे क्लाइंट-साइड सत्यापन के लिए उपयोगकर्ता इंटरफ़ेस पर लागू किया जा सकता है या सर्वर-साइड सत्यापन के लिए उपयोग किया जा सकता है।

  • इकाई ढांचे में, डेटा सत्यापन किसी एप्लिकेशन में खराब डेटा को पकड़ने के लिए समाधान का हिस्सा है।

  • डेटा फ्रेमवर्क विधियों की एक विस्तृत श्रृंखला का उपयोग करके डेटाबेस द्वारा डिफ़ॉल्ट रूप से लिखे जाने से पहले, एंटिटी फ्रेमवर्क सभी डेटा को मान्य करता है।

  • हालाँकि, उपयोगकर्ता-इंटरफ़ेस डेटा सत्यापन के बाद Entity फ्रेमवर्क आता है। तो उस मामले में ईएफ फेंकता है और एक सामान्य संदेश दिखाने के लिए किसी भी अपवाद को संभालने के लिए इकाई सत्यापन की आवश्यकता है।

  • आपकी त्रुटि जाँच और उपयोगकर्ता को त्रुटि संदेश पास करने का तरीका सुधारने के लिए डेटा सत्यापन की कुछ तकनीकें हैं।

DbContext में ValidateEntity नाम का एक ओवरराइडेबल तरीका है। जब आप SaveChanges को कॉल करते हैं, तो Entity Framework अपने कैश में प्रत्येक इकाई के लिए इस पद्धति को कॉल करेगा, जिसकी स्थिति अपरिवर्तित नहीं है। स्टूडेंट एंटिटी के लिए आप निम्न तर्क को सीधे यहाँ रख सकते हैं जैसा कि निम्नलिखित उदाहरण में दिखाया गया है।

public partial class UniContextEntities : DbContext {

   protected override System.Data.Entity.Validation
      .DbEntityValidationResult ValidateEntity(DbEntityEntry entityEntry, 
      System.Collections.Generic.IDictionary<object, object> items) {

         if (entityEntry.Entity is Student) {

            if (entityEntry.CurrentValues.GetValue<string>("FirstMidName") == "") {

               var list = new List<System.Data.Entity
                  .Validation.DbValidationError>();

               list.Add(new System.Data.Entity.Validation
                  .DbValidationError("FirstMidName", "FirstMidName is required"));

               return new System.Data.Entity.Validation
                  .DbEntityValidationResult(entityEntry, list);
            }
         }

         if (entityEntry.CurrentValues.GetValue<string>("LastName") == "") {

            var list = new List<System.Data.Entity
               .Validation.DbValidationError>();

            list.Add(new System.Data.Entity.Validation
               .DbValidationError("LastName", "LastName is required"));

            return new System.Data.Entity.Validation
               .DbEntityValidationResult(entityEntry, list);
         }

         return base.ValidateEntity(entityEntry, items);
   }
}

उपरोक्त मान्य विधि, छात्र इकाई FirstMidName और LastName गुणों की जाँच की जाती है यदि इनमें से किसी भी संपत्ति में एक खाली स्ट्रिंग है, तो यह एक त्रुटि संदेश लौटाएगा।

आइए एक सरल उदाहरण देखें जिसमें एक नया छात्र बनाया गया है, लेकिन छात्र का फर्स्टमीडनाम खाली स्ट्रिंग है जैसा कि निम्नलिखित कोड में दिखाया गया है।

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         Console.WriteLine("Adding new Student to the database");
         Console.WriteLine();

         try {

            context.Students.Add(new Student() {
               FirstMidName = "",
               LastName = "Upston"
            });

            context.SaveChanges();
         } catch (DbEntityValidationException dbValidationEx) {

            foreach (DbEntityValidationResult entityErr in 
               dbValidationEx.EntityValidationErrors) {

               foreach (DbValidationError error in entityErr.ValidationErrors) {
                  Console.WriteLine("Error: {0}",error.ErrorMessage);
               }
            }
         }

         Console.ReadKey();
      }
   }
}

जब उपरोक्त उदाहरण संकलित और निष्पादित किया जाता है, तो आपको कंसोल विंडो पर निम्न त्रुटि संदेश प्राप्त होगा।

Adding new Student to the database  
Error: FirstMidName is required

हम आपको बेहतर समझ के लिए चरण-दर-चरण तरीके से उपरोक्त उदाहरण को निष्पादित करने की सलाह देते हैं।