Как включить проверку concurrency с использованием кода EF 5.0 First?
Я хотел бы сделать check-then-update в атомной операции. Я использую dbcontext для управления транзакцией. Я ожидал получить исключение, если запись была изменена другим потоком, но исключение не выбрасывается. Любая помощь будет оценена по достоинству. Здесь мой вывод:
Thread-4: Reading...
Thread-5: Reading...
Thread-5: Updating destination 1
Thread-4: Updating destination 1
Thread-4: SaveChanges
Thread-5: SaveChanges
Вот мой фрагмент кода:
public static void Main(string[] args)
{
PopulateData();
(new Thread(UpdateDestination1)).Start();
(new Thread(UpdateDestination1)).Start();
}
public static void UpdateDestination1()
{
using (var context1 = new BreakAwayContext())
{
Console.WriteLine("Thread-{0}: Reading...", Thread.CurrentThread.ManagedThreadId);
var d = context1.Destinations.FirstOrDefault();
Console.WriteLine("Thread-{0}: Updating destination {1}", Thread.CurrentThread.ManagedThreadId, d.DestinationId);
d.Name = "Thread-" + Thread.CurrentThread.ManagedThreadId;
try
{
context1.SaveChanges();
Console.WriteLine("Thread-{0}: SaveChanges", Thread.CurrentThread.ManagedThreadId);
}
catch (OptimisticConcurrencyException)
{
Console.WriteLine("OptimisticConcurrencyException!!!");
throw;
}
}
}
Ответы
Ответ 1
Вы можете использовать аннотацию ConcurrencyCheck для свойства (http://msdn.microsoft.com/en-us/data/gg193958.aspx) или IsConcurrencyToken() или .IsRowversion при настройке свойства с помощью свободного API (http://msdn.microsoft.com/en-us/data/jj591617#1.12). Как правило, в базе данных должен быть столбец rowversion.