首先是 EF 代码中的自定义时间戳属性

本文关键字:自定义 时间戳 属性 代码 EF | 更新日期: 2023-09-27 18:33:43

我首先在我的项目中使用 EF 6.1 代码。对于以下实体,我想在更改CodeName值时增加数据库中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 中完成这项工作吗?

首先是 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;
    }