对一个或多个实体的验证失败。有关详细信息,请参阅“EntityValidationErrors”属性。
分析:
EF 通常采用的单个实体访问数据 比如 全局只生成一个数据访问的Enityt
解决办法
取消验证:
db.Configuration.ValidateOnSaveEnabled = false;
int count = db.SaveChanges();
db.Configuration.ValidateOnSaveEnabled = true;
或:
//执行验证业务
//context.Entry<T>(entity).GetValidationResult(); //取消验证
try
{
context.SaveChanges();
}
catch (Exception e)
{
}
或者采取应用程序 取同一个数据访问:
public static class DbContextHelper
{
private static DbContext context = null;
private const string SessionKey_DbContext = "DBContextFactory";
public static DbContext GetStudentEvaluateDbContext()
{
if (CallContext.GetData(SessionKey_DbContext)==null)
{
CallContext.SetData(SessionKey_DbContext, new DBContextFactory());
}
return CallContext.GetData(SessionKey_DbContext) as DBContextFactory;
}
}
this.context = DbContextHelper.GetStudentEvaluateDbContext() as DBContextFactory;
意外错误:
当我们已经取消验证后 通常都可以正常修改数据,但当我改为取同一个数据访问时,修改数据还是会报这个错误,这通常是因为IIS 线程池还缓存这旧的EF访问器 与新的访问方式产生不同的EF访问 所以 简单的办法 重启VS ,IIS,清除缓存 再重新试一次 就OK了 前提是确保不存在生成其他的EF访问