Entity Framework - Native SQL

ใน Entity Framework คุณสามารถสอบถามกับคลาสเอนทิตีของคุณโดยใช้ LINQ คุณยังสามารถเรียกใช้แบบสอบถามโดยใช้ SQL ดิบโดยตรงกับฐานข้อมูลโดยใช้ DbCOntext เทคนิคนี้สามารถนำไปใช้กับโมเดลที่สร้างด้วย Code First และ EF Designer ได้อย่างเท่าเทียมกัน

แบบสอบถาม SQL ในเอนทิตีที่มีอยู่

วิธี SqlQuery บน DbSet อนุญาตให้เขียนแบบสอบถาม 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 สำหรับประเภทที่ไม่ใช่เอนทิตี

แบบสอบถาม 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 ใช้ในการส่งคำสั่งที่ไม่ใช่คิวรีไปยังฐานข้อมูลเช่นคำสั่ง Insert, Update หรือ Delete มาดูรหัสต่อไปนี้ซึ่งมีการอัปเดตชื่อของนักเรียนเป็น ID = 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();
      }
   }
}

รหัสด้านบนจะดึงชื่อของนักเรียนทั้งหมดจากฐานข้อมูล