10

アトミック操作でチェックしてから更新したいと思います。トランザクションを管理するために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;
        }
    }
}
4

1 に答える 1

18

流暢なAPI( http:// msdn )を使用してプロパティを構成する場合は、プロパティ( http://msdn.microsoft.com/en-us/data/gg193958.aspx)、IsConcurrencyToken()、または.IsRowversionでConcurrencyCheckアノテーションを使用できます。 microsoft.com/en-us/data/jj591617#1.12)。通常、データベースには行バージョン列があります。

于 2012-10-25T03:32:51.620 に答える