- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在创建将在我的应用程序中使用的默认并发策略。
我决定采用乐观策略。
我的所有实体都映射为Table per Type (TPT)
(使用继承)。我很快了解到,在 Entity Framework 上使用带有继承的 RowVersion 类型的列时会出现问题:
Product
Id INT IDENTITY PRIMARY KEY
RowVersion ROWVERSION
Car (inherits Product records)
Color TYNIINT NOT NULL,
AnotherProperty....
如果我更新 Car
表的记录,Product
表中的 RowVersion 列将不会更新。
我计划在 Product
中使用类型为 datetime2 (7)
的列,如果继承此表的表的任何记录被修改,则手动更新它。
我想我正在重新发明轮子。
在 Entity Framework 中使用 Table per Type (TPT)
时,是否有另一种方法可以通过 ROWVERSION
使用乐观并发策略?
编辑
我的映射:
class Product
{
int Id { get; set; }
string Name { get; set; }
byte[] RowVersion { get; set; }
}
class Car : Product
{
int Color { get; set; }
}
CodeFirst 约定。
只有 Product
实体的 RowVersion 属性具有自定义定义:
modelBuilder.Entity<Product>()
.Property(t => t.RowVersion)
.IsConcurrencyToken();
最佳答案
在 EF6 和 EF-core 中,当使用 SQL Server 时,你必须使用这个映射:
modelBuilder.Entity<Product>()
.Property(t => t.RowVersion)
.IsRowVersion(); // Not: IsConcurrencyToken
IsConcurrencyToken 确实将属性配置为并发 token ,但是(将其用于 byte[]
属性时)
varbinary(max)
null
IsRowVersion 另一方面,
rowversion
(在 SQL Server 中,或在早期版本中为 timestamp
),因此现在,当您更新 Car
时,您会看到两个更新语句:
DECLARE @p int
UPDATE [dbo].[Product]
SET @p = 0
WHERE (([Id] = @0) AND ([Rowversion] = @1))
SELECT [Rowversion]
FROM [dbo].[Product]
WHERE @@ROWCOUNT > 0 AND [Id] = @0
UPDATE [dbo].[Car]
SET ...
第一个语句不会更新任何内容,但它会增加 rowversion,如果 rowversion 在其间发生更改,它将抛出并发异常。
[System.ComponentModel.DataAnnotations.Schema.Timestamp]
属性是等效于 IsRowVersion()
的数据注释:
[Timestamp]
public byte[] RowVersion { get; set; }
请注意 official documentation是不正确的。它说 IsConcurrencyToken
是 [Timestamp]
属性的流畅等效项。但是,IsRowVersion
是等效的。
关于c# - 乐观并发 : IsConcurrencyToken and RowVersion,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31330015/
我正在编写一个 Web 应用程序,两个不同的用户可以在其中更新事物列表,例如待办事项列表。我已经意识到,乐观锁定机制效果最好,因为我不希望出现高争用情况。 我一直在查看事务隔离级别,现在我有点困惑。看
这个问题在这里已经有了答案: Pessimistic versus Optimistic Concurrency (Locking versus Feedback) (3 个答案) 关闭 8 年前。
我是一名优秀的程序员,十分优秀!