實體框架 - 原生 SQL



在實體框架中,您可以使用 LINQ 查詢您的實體類。您還可以使用 DbCOntext 直接對資料庫執行原始 SQL 查詢。這些技術可以平等地應用於使用程式碼優先和 EF 設計器建立的模型。

現有實體上的 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 查詢

可以使用 Database 類上的 SqlQuery 方法建立返回任何型別(包括原始型別)的例項的 SQL 查詢。例如 -

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();
      }
   }
}

以上程式碼將從資料庫中檢索所有學生的姓氏。

廣告