4

我在 winforms 应用程序中实现 EF 5,并将上下文 (DBContext) 保存在表单的私有字段中。

我尝试添加一个实体,因为它有一些无效的属性,我得到一个 DBEntityValidationException。然后,我将这些属性设置为有效值并尝试再次添加它,我收到完全相同的 DBEntityValidationException。

我想知道我是否需要清除任何东西?这是代码。

private SystemEntities _context = new SystemEntities(); // class field

try
{
    Customer customer = ... // set properties here
    _context.Customers.Add(customer);
    _context.SaveChanges();
}
catch (DBEntityValidationException ex)
{
    // get exception even though properties are updated with valid values
}

更新实体时我没有观察到这个问题。非常感谢。

4

2 回答 2

4

这些评论为我指明了正确的方向。我没有尝试保存更改并捕获异常,而是首先获得验证结果:

var results = new List<ValidationResults>();
Validator.TryValidateObject(entity, new ValidationContext(entity, null, null), results, true);

问题在于它实际上是在将无效实体添加到集合中,因此它在随后的尝试中不断抛出异常。谢谢!

于 2013-02-08T21:03:05.407 回答
0

这里有两个非常好的答案。这个独立的验证太棒了。我一直在寻找这个。

这对于任何批处理操作都非常有用。

因此,请使用独立验证,或者如果您正在捕获 DBEntityValidationException,则从 DbContext 的本地缓存中清除无效实体。

于 2013-03-18T17:13:15.090 回答