如何在不先检索记录的情况下更新记录的单个属性?我在EF Code First 4.1的背景下提出要求
说我有一个类User,映射到数据库中的表Users:
class User
{
public int Id {get;set;}
[Required]
public string Name {get;set;}
public DateTime LastActivity {get;set;}
...
}
Run Code Online (Sandbox Code Playgroud)
现在我想更新用户的LastActivity.我有用户名.我可以通过查询用户记录,将新值设置为LastActivity,然后调用SaveChanges()来轻松完成.但这会导致冗余查询.
我通过使用Attach方法来解决.但是因为EF在Name上抛出了验证异常,如果它为null,我将Name设置为随机字符串(不会更新回DB).但这似乎不是一个优雅的解决方案:
using (var entities = new MyEntities())
{
User u = new User {Id = id, Name="this wont be updated" };
entities.Users.Attach(u);
u.LastActivity = DateTime.Now;
entities.SaveChanges();
}
Run Code Online (Sandbox Code Playgroud)
如果有人能为我提供更好的解决方案,我会非常高兴.请原谅我有任何错误,因为这是我第一次就SO提问.