DataBaseContext context = new DataBaseContext(); DbTransaction transaction = context.Database.BeginTransaction().UnderlyingTransaction
Burada elde ettiğimiz transaction nesnesi veri tabanı bağlantısı açık ve işlem yapmaya hazır olan bir nesnedir. Bu işlemden sonra bu transaction nesnesini PB de kullanabiliriz:
IDatabase2 db = DatabaseFactory.GetDbObject(DbSettings.TransactionMode); db.UseExternalTransaction(transaction);
Buradan sonra PB ile yaptığımız işlemler EF ile oluşturduğumuz transaction üzerinden yapılacaktır. Normal EF kullanımından farklı olarak EF 6'da transaction bu yazıda bahsettiğimiz yöntemle başlatıldığında Commit edilmesi gerekmektedir:
context.Save(); context.Database.CurrentTransaction.Commit();
Bu işlem sırasında aşağıdaki hususlara dikkat edilmesi gerekir:
1. Dışarıda oluşturulan transaction geçerli bir durumda olmalı ve veri tabanı bağlantısı açık olmalıdır.
2. PB ile Commit veya RollBack yapıldığında PB sıralı yeni işlemleri yeni transaction kullanarak yapacaktır. Yani mevcut transaction geçerliliğini yitirecektir.
3. Bu işlem yapılırken PB transaction modda çalışır durumda olmalıdır.