Entity Framework执行时出现提示Validation for one or more entities.

年末总结6

这是我在将ADO.NET转成EF过程中,update语句遇到的问题。也适用insert插入语句。
提示:**Validation for one or more entities.
See ‘EntityValidationErrors’property for more details balabala**
详细信息并没有指明是哪个字段出错,所以可以使用try catch获得错误字段。

try
{
    Context.SaveChanges();//数据库存入数据
}
catch (DbEntityValidationException ex)
{
    StringBuilder errors = new StringBuilder();
    IEnumerable validationResult = ex.EntityValidationErrors;
    foreach (DbEntityValidationResult result in validationResult)
    {
        ICollection validationError = result.ValidationErrors;
        foreach (DbValidationError err in validationError)
        {
            errors.Append(err.PropertyName + ":" + err.ErrorMessage + "\r\n");
        }
    }
    Console.WriteLine(errors.ToString());
    //简写
    //var validerr = ex.EntityValidationErrors.First().ValidationErrors.First();
    //Console.WriteLine(validerr.PropertyName + ":" + validerr.ErrorMessage);
}

注意看console控制台输出的错误信息。
以上。

你可能感兴趣的:(Entity Framework执行时出现提示Validation for one or more entities.)