年末总结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<DbEntityValidationResult> validationResult = ex.EntityValidationErrors;
foreach (DbEntityValidationResult result in validationResult)
{
ICollection<DbValidationError> 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控制台输出的错误信息。
以上。