エンティティフレームワーク-トランザクション

Entity Frameworkのすべてのバージョンで、実行するたびに SaveChanges()データベースを挿入、更新、または削除するために、フレームワークはその操作をトランザクションでラップします。SaveChangesを呼び出すと、コンテキストは自動的にトランザクションを開始し、永続性が成功したかどうかに応じてトランザクションをコミットまたはロールバックします。

  • これはすべてあなたに透過的であり、あなたはそれに対処する必要はありません。

  • このトランザクションは、操作を実行するのに十分な時間だけ続き、その後完了します。

  • このような別の操作を実行すると、新しいトランザクションが開始されます。

Entity Framework6は以下を提供します-

Database.BeginTransaction()

  • これは、既存のDbContext内で、ユーザーのトランザクションを開始および完了するためのシンプルで簡単な方法です。

  • これにより、複数の操作を同じトランザクション内で組み合わせることができるため、すべてがコミットされるか、すべてが1つとしてロールバックされます。

  • また、ユーザーはトランザクションの分離レベルをより簡単に指定できます。

Database.UseTransaction()

  • これにより、DbContextは、EntityFrameworkの外部で開始されたトランザクションを使用できます。

1つのトランザクションで複数の操作が実行される次の例を見てみましょう。コードは次のとおりです-

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         using (var dbContextTransaction = context.Database.BeginTransaction()) {

            try {

               Student student = new Student() {
                  ID = 200, 
                  FirstMidName = "Ali", 
                  LastName = "Khan", 
                  EnrollmentDate = DateTime.Parse("2015-12-1")
               };

               context.Students.Add(student);

               context.Database.ExecuteSqlCommand(@"UPDATE Course SET Title = 
                  'Calculus'" + "WHERE CourseID = 1045");

               var query = context.Courses.Where(c ⇒ c.CourseID == 1045);

               foreach (var item in query) {
                  Console.WriteLine(item.CourseID.ToString()
                     + " " + item.Title + " " + item.Credits);
               }

               context.SaveChanges();
               var query1 = context.Students.Where(s ⇒ s.ID == 200);

               foreach (var item in query1) {
                  Console.WriteLine(item.ID.ToString() 
                     + " " + item.FirstMidName + " " + item.LastName);
               }

               dbContextTransaction.Commit();
            } catch (Exception) {
               dbContextTransaction.Rollback();
            }

         }
      }
   }
}
  • トランザクションを開始するには、基になるストア接続が開いている必要があります。

  • したがって、Database.BeginTransaction()を呼び出すと、接続がまだ開かれていない場合は開かれます。

  • DbContextTransactionが接続を開いた場合、Dispose()が呼び出されたときに接続を閉じます。