c# - 使用 EF5 更新实体

标签 c# entity-framework

我刚刚开始一个新项目,之前使用 Entity Framework 度过了愉快的时光,我在最新版本中进行了 Nuget。一切顺利,直到我尝试更新一个实体。我有以下代码;

using (var c = new EFContext())
{
      Data.User u = new Data.User() { UserId = UserId };
      c.Users.Attach(u);
      u.FailedPasswordAttemptCount = newFailedPasswordAttemptCount;
      c.SaveChanges();
}

这在 EF4 中运行良好。但是在 EF5 中,由于我在用户表 (UserName) 中有一个不可为 null 的字段,因此出现 DbEntityValidationException。

我可以通过使用空用户名创建我的 Data.User 对象并告诉 EF 哪些属性已被修改来解决这个问题,

using (var c = new EFContext())
{
      Data.User u = new Data.User() { UserId = UserId, UserName = "" };
      ...
      c.Entry(u).Property("FailedPasswordAttemptCount ").IsModified = true;
      ...
}

但这似乎不是特别易于管理,因为更多不可为 null 的字段被添加到此表和许多其他表中。

This question声明 Attach 仅适用于从 EntityObject 派生的实体。所以我假设 EF5 对象不是由此派生的。

任何人都知道如何更新我的实体而不必每次都指定所有不可为 null 的字符串字段。

感觉我错过了一些非常明显的东西......

最佳答案

如果这是现有用户,您可以这样做...

c.Users.First(user=>user.UserId == UserId).FailedPasswordAttemptCount =         newFailedPasswordAttemptCount;

c.SaveChanges(); 

顺便说一句,在 EF5 代码优先中,实体类不派生自任何东西,但仍然可以附加。

或者,您返回到您的附加方式,但我认为您需要关闭此保存的验证,因为 EF 似乎只验证整个实体或什么都不验证

using (var c = new EFContext()) 
{       
    c.Configuration.ValidateOnSaveEnabled = false; 
    Data.User u = new Data.User() { UserId = UserId };       
    c.Users.Attach(u);       
    u.FailedPasswordAttemptCount = newFailedPasswordAttemptCount;       
    c.SaveChanges(); 
} 

关于c# - 使用 EF5 更新实体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12894452/

相关文章:

c# - 如何制定 GroupJoin() 声明

c# - 如何使用模型优先方法使用动态连接字符串但仍使用 EDMX 中的数据模型?

c# - 具有从同一数据库中的基础 DbContexts 进行多次迁移和继承的 Entity Framework

c# - 当属性抛出错误时,如何将其设置为空值?

c# - 为 devexpress 向导创建一个步骤指示器

c# - 如何在 Controller 的构造函数中获取当前用户的数据?

C# 单元测试来测试 Dto 属性的属性

c# - MVC - Entity Framework - 这属于哪里?

c# - 对 EntityFramework 和 "normal"SQL 调用使用相同的 SqlConnection

c# - 'float' 的最大值是多少?