在ABP中,你可以使得Entity直接继承接口 IHasConcurrencyStamp
然后再EF中的XXXDbContextModelCreatingExtensions中的ConfigureByConvention会看到如下代码
public static void TryConfigureConcurrencyStamp(this EntityTypeBuilder b)
{
if (b.Metadata.ClrType.IsAssignableTo<IHasConcurrencyStamp>())
{
b.Property("ConcurrencyStamp").IsConcurrencyToken().HasMaxLength(40)
.HasColumnName("ConcurrencyStamp");
}
}
上面表示有这个字段ConcurrencyStamp的时候,设置为IsConcurrencyToken,这东西和RowVersion都是为了处理并发写入的问题
举个例子有一个数据A.age X读取的时候为1,Y读取的时候为1,这个时候X提交修改为3,然后Y又提交修改为2,按照默认这个提交是可以完成的,不过对于Y来说,我是从1修改到2,而实际是3修改为2,所以应该要引发异常!
某一个模型要引入这个IHasConcurrencyStamp 我们只需要这个操作
/// <summary>
/// 工作流规则
/// </summary>
[Comment("工作流规则")]
public class LineRoute : Entity<int>,IHasConcurrencyStamp

文章介绍了如何在ABP框架中使用IHasConcurrencyStamp处理并发问题,包括在DbContext的ModelCreating和SaveChanges方法中的应用。ConcurrencyStamp用于手动校验,RowVersion自动管理但仅限MSSQL。

2686

被折叠的 条评论
为什么被折叠?



