EF 4 - 更新具有时间戳列的表时出现异常

本文关键字:异常 时间戳 更新 EF | 更新日期: 2023-09-27 17:57:06

我在SQL Server中创建了下表

CREATE TABLE [dbo].[Role](
   [Id] [int] IDENTITY(1,1) NOT NULL,
   [Name] [nvarchar](20) NOT NULL,
   [CreatedDate] [datetime] NULL,
   [TIMESTAMP] [timestamp] NOT NULL,
   [ModifiedDate] [datetime] NULL,
   CONSTRAINT [PK_TBL_ROLES] PRIMARY KEY CLUSTERED ([Id] ASC)
       WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, 
             ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY].

使用 EF,我创建了一个带有 byte[] 类型的时间戳列的 ste 类,该列是只读的。

我使用数据上下文从我的数据库中检索一个对象,例如

var roleObject = roleService.getObject(id);

现在我更改角色名称如下

roleObject.Name = "New Name";
roleObject.ModifiedDate = DateTime.Now;

最后,我使用以下通用方法调用我的存储库来持久化对象

public void PersistUpdatedItem(T entity){
   _ctx.ApplyCurrentValues(typeof (T).Name, entity);
   _ctx.ObjectStateManager.ChangeObjectState(entity, EntityState.Modified);
   _ctx.SaveChanges();
}

注意 ctx 是我的会话对象,T 是实体类。在这一点上,我得到一个例外

无法更新时间戳列

有人可以帮我解决这个问题吗?

谢谢

EF 4 - 更新具有时间戳列的表时出现异常

两点:

  • 不能Timestamp属性设置为"只读"。EF 必须能够设置该值,因此属性必须具有资源库,并且资源库的辅助功能必须与设计器中定义的辅助功能相同。
  • Timestamp属性必须配置"并发模式固定"和"存储生成的模式"。这两种配置都在设计器的属性窗口中定义。

只需从模型对象中删除时间戳即可。