jeudi 5 mars 2015

Is using TransactionScope a good idea when reading data using Entity Framework 6?

I've been reading a document from Microsoft's patterns & practices group (Data Access for Highly-Scalable Solutions: Using SQL, NoSQL, and Polyglot Persistence).


In Chapter 3, in the section "Retrieving Data from the SQL Server Database", the authors discuss using Entity Framework to load entities from a database. Here's a bit of their sample code:



using (var context = new PersonContext())
{
Person person = null;

using (var transactionScope = this.GetTransactionScope())
{
person = context.Persons
.Include(p => p.Addresses)
.Include(p => p.CreditCards)
.Include(p => p.EmailAddresses)
.Include(p => p.Password)
.SingleOrDefault(p => p.BusinessEntityId == personId);

transactionScope.Complete();
}

// etc...
}


Note the use of a custom transaction scope via the GetTransactionScope method, implemented in their base context class like so:



public abstract class BaseRepository
{
private static TransactionOptions transactionOptions = new TransactionOptions()
{
IsolationLevel = IsolationLevel.ReadCommitted
};

protected virtual TransactionScope GetTransactionScope()
{
return new TransactionScope(TransactionScopeOption.Required, transactionOptions);
}
}


My question: is the use of a TransactionScope in this way overkill, particularly for data reads, when using Entity Framework 6? In other words, is this "old" guidance that has now been superseded? (The document was authored in 2013, just for reference).


(I realised after posting that the answer to this question might be somewhat opinion-based, sorry about that.)


Aucun commentaire:

Enregistrer un commentaire