एंटिटी फ्रेमवर्क - नेटिव एसक्यूएल

इकाई ढांचे में आप LINQ का उपयोग करके अपनी इकाई कक्षाओं के साथ क्वेरी कर सकते हैं। आप DbCOntext का उपयोग करके डेटाबेस के खिलाफ सीधे कच्चे SQL का उपयोग करके क्वेरी भी चला सकते हैं। तकनीकों को कोड प्रथम और ईएफ डिजाइनर के साथ बनाए गए मॉडल के समान रूप से लागू किया जा सकता है।

मौजूदा एंटिटी पर SQL क्वेरी

DbSet पर SqlQuery पद्धति एक कच्ची SQL क्वेरी को लिखने के लिए अनुमति देती है जो इकाई उदाहरणों को लौटाएगी। लौटी हुई वस्तुओं को संदर्भ द्वारा ट्रैक किया जाएगा, जैसे वे एक LINQ क्वेरी द्वारा लौटाए गए थे। उदाहरण के लिए -

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         var students = context.Students.SqlQuery("SELECT * FROM dbo.Student").ToList();

         foreach (var student in students) {
            string name = student.FirstMidName + " " + student.LastName;
            Console.WriteLine("ID: {0}, Name: {1}, \tEnrollment Date {2} ",
               student.ID, name, student.EnrollmentDate.ToString());
         }

         Console.ReadKey();
      }
   }
}

उपरोक्त कोड डेटाबेस से सभी छात्रों को पुनः प्राप्त करेगा।

गैर-इकाई प्रकारों के लिए SQL क्वेरी

डेटाबेस वर्ग पर SqlQuery पद्धति का उपयोग करके आदिम प्रकारों सहित किसी भी प्रकार की रिटर्निंग एसक्यूएल क्वेरी बनाई जा सकती है। उदाहरण के लिए -

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         var studentNames = context.Database.SqlQuery
            <string>("SELECT FirstMidName FROM dbo.Student").ToList();

         foreach (var student in studentNames) {
            Console.WriteLine("Name: {0}", student);
         }

         Console.ReadKey();
      }
   }
}

SQL डेटाबेस में शामिल हो जाता है

ExecuteSqlCommnad विधि का उपयोग डेटाबेस में गैर-क्वेरी आदेश भेजने के लिए किया जाता है, जैसे कि इन्सर्ट, अपडेट या डिलीट कमांड। आइए निम्नलिखित कोड पर एक नज़र डालें जिसमें छात्र का पहला नाम आईडी = 1 के रूप में अपडेट किया गया है

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         //Update command

         int noOfRowUpdated = context.Database.ExecuteSqlCommand("Update 
            student set FirstMidName = 'Ali' where ID = 1");

         context.SaveChanges();

         var student = context.Students.SqlQuery("SELECT * FROM
            dbo.Student where ID = 1").Single();

         string name = student.FirstMidName + " " + student.LastName;

         Console.WriteLine("ID: {0}, Name: {1}, \tEnrollment Date {2} ", 
            student.ID, name, student.EnrollmentDate.ToString());

         Console.ReadKey();
      }
   }
}

उपरोक्त कोड डेटाबेस से सभी छात्रों के पहले नाम को पुनः प्राप्त करेगा।