开发者

EF Code First - IsConcurrencyToken()

Simple, but yet mysterious for me: Why do StringPropertyConfiguration (and all the other PropertyConfiguration) class(es) have 2 overloads for IsConcurrencyToken()?

The first:

public StringPropertyConfiguration IsConcurrencyToken()

Configures the property to be used as an optimistic concurrency token.

And the second:

public StringPropertyConfiguration IsConcurrencyToken(bool?)

Configures whether or not the property is to be used as an optimistic concurrency token.

Why would you use one over the other? As I see it, there's no difference at all between those two overloads (atleast not when working with them)..开发者_Python百科.

By using the first you would write something like:

modelBuilder.Entity<Author>()
    .Property(x => x.Name)
    .IsConcurrencyToken();

And by using the second you would write:

modelBuilder.Entity<Author>()
    .Property(x => x.Name)
    .IsConcurrencyToken(true/false/null);

Have I missed something?


My opinion...

The IsConcurrencyToken() defaults to true to provide a simple, fluent manner to define the entity.

The IsConcurrencyToken(bool?) allows the author to definitively set the ConcurrencyMode of the entity. This is useful for advanced scenarios:

  • Overriding the [ConcurrencyCheck] attribute on the POCO
  • Allowing a convention (removed in EF 4.1 RTW) to enable/disable the ConcurrencyMode based on some custom convention

Finally, I think IsConcurrencyToken(false) is better than IsNotConcurrencyToken().

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜