EF 4.1 Code First - 确定哪些属性已更改

Dyl*_*ter 16 c# entity-framework change-tracking code-first

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

Sla*_*uma 29

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

var entry = context.Entry(myEntity);
var namesOfChangedProperties = entry.CurrentValues.PropertyNames
    .Where(p => entry.Property(p).IsModified);
Run Code Online (Sandbox Code Playgroud)

这里有几点需要注意:

  • 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; }
    }
    
    Run Code Online (Sandbox Code Playgroud)

    ...然后,如果myEntity是a Person,CurrentValues.PropertyNames将包含" Id "," Name "和" Address ",但不包含" Address.Country "或" Address.City "(也不包括" Country "或" City ").

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

  • 很棒,也适用于Entity framework 6! (2认同)