下面是EF Core中的一个Person实体:
public partial classPerson
{public int Id { get; set; }public string Code { get; set; }public string Name { get; set; }public DateTime? CreateTime { get; set; }public DateTime? UpdateTime { get; set; }
}
其中我们通过Fluent API指定了Code是Key属性,用来Update和Delete数据(包括DbSet的Contains方法也是查找的实体的Key属性值):
modelBuilder.Entity(entity =>{
entity.Property(e=>e.Id).ValueGeneratedOnAdd();
entity.HasKey(e=> e.Code);//声明列Code是实体的Key属性
});
现在我们可以通过代码先new一个Person实体,然后声明其Key属性列Code的值,及要修改的列Name的值,这样EF Core就会为我们生成只修改列Name的Sql语句:
using (TestDBContext testDBContext = newTestDBContext())
{
Person person= new Person() { Code = "A" ,Name="Tom"};//列Code是Key,声明Key属性列Code的值,及要修改的列Name的值
testDBContext.Attach(person);//告诉EF