17

我正在使用 Entity Framework 4.1 Code First。是否有内置方法来获取自从数据库加载实体以来发生了哪些属性更改的列表?我知道代码首先检测到一个对象已更改,但有没有办法准确获取哪些属性已更改?

4

1 回答 1

29

对于标量和复杂属性,您可以使用以下内容提取实体的更改属性名称myEntity

var entry = context.Entry(myEntity);
var namesOfChangedProperties = entry.CurrentValues.PropertyNames
    .Where(p => entry.Property(p).IsModified);

这里有几点需要注意:

  • CurrentValues.PropertyNames仅包含标量和复杂属性,不包含导航属性。

  • 复杂属性意味着:只有在实体上声明的复杂属性的名称,而不是复杂类型本身的实际单个属性,例如:如果你有这个模型......

    [ComplexType]
    public class Address
    {
        public string Country { get; set; }
        public string City { get; set; }
    }
    
    public class Person
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public Address Address { get; set; }
    }
    

    ... 那么,如果myEntity是 a PersonCurrentValues.PropertyNames将包含“ Id ”、“ Name ”和“ Address ”,但不包含“ Address.Country ”或“ Address.City ”(也不包含“ Country ”或“ City ”)。

  • 如果一个复杂属性被标记为已修改(.IsModified在上面的代码中是true),那么这意味着引用(Person.Address在上面的示例中)已经改变,不管复杂类型内部的属性值(Country和)是否已经改变City. 或者复杂类型的任何属性已更改(CountryCity已更改)。我相信不可能找出哪一个,因为 EF 总是将所有复杂类型属性的 UPDATE 命令发送到数据库,即使只有一个属性发生了变化而另一个属性保持不变。我会由此得出结论,EF 不会跟踪单个复杂类型属性的更改。

于 2011-08-19T00:14:12.350 回答