Entity Framework-네이티브 SQL

Entity Framework에서 LINQ를 사용하여 엔터티 클래스로 쿼리 할 수 ​​있습니다. DbCOntext를 사용하여 데이터베이스에 대해 원시 SQL을 사용하여 쿼리를 직접 실행할 수도 있습니다. 이 기술은 Code First 및 EF Designer로 만든 모델에 동일하게 적용 할 수 있습니다.

기존 엔터티에 대한 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 쿼리

기본 형식을 포함하여 모든 형식의 인스턴스를 반환하는 SQL 쿼리는 Database 클래스의 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 메서드는 삽입, 업데이트 또는 삭제 명령과 같은 쿼리가 아닌 명령을 데이터베이스에 보내는 데 사용됩니다. 학생의 이름이 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();
      }
   }
}

위의 코드는 데이터베이스에서 모든 학생의 이름을 검색합니다.