首先是 EF 代码中的自定义时间戳属性
本文关键字:自定义 时间戳 属性 代码 EF | 更新日期: 2023-09-27 18:33:43
我首先在我的项目中使用 EF 6.1 代码。对于以下实体,我想在仅更改Code
和Name
值时增加数据库中Version
字段值(我在断开连接的情况下更新我的实体):
public class Product
{
public int Id {get; set;}
public string Code {get; set;}
public string Name {get; set;}
public string Title {get; set;}
public int Version {get; set;}
}
使用[TimeStamp]
批注会导致当实体的任何属性值更改时[TimeStamp]
属性更改。
有什么方法可以在 EF 中完成这项工作吗?
您可以检查属性的状态是否已更改。这里 MSDN 链接
更新代码可能如下所示。
public void Update(Product product) {
if (context.Entry(product).Property(u => u.Code).IsModified && context.Entry(product).Property(u => u.Name).IsModified) {
product.Version += 1;
}
context.Entry(product).State = System.Data.Entity.EntityState.Modified;
}