Entity-framework-native-sql

提供:Dev Guides
移動先:案内検索

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クエリ

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

上記のコードは、データベースからすべての生徒の名を取得します。