在工作中我们正在寻找移动到ORM(仍然使用ADO的访问数据库!)我开始使用实体框架构建,一切顺利,直到我将它分离为它自己的.dll(所以我们可以拥有所有使用相同数据库逻辑的网站/ crm / production / barcoding系统)。
问题在于处理DbEntityValidationExceptions,我的初始测试代码(有效)
public override int SaveChanges(System.Data.Objects.SaveOptions options)
{
try{return base.SaveChanges(options);}
catch (DbEntityValidationException dbEx)
{
foreach (var validationErrors in dbEx.EntityValidationErrors)
{
foreach (var validationError in validationErrors.ValidationErrors)
{
Trace.TraceInformation("Class: {0}, Property: {1}, Error: {2}",
validationErrors.Entry.Entity.GetType().FullName,
validationError.PropertyName,
validationError.ErrorMessage);
}
}
//handle here
throw;
}
}
但是现在没有被捕获,我还在处理一个通用的threadException。有没有办法访问原始数据(转换threadException?)或者我应该采取不同的方法。我想我只需要朝着正确的方向努力,我就能想出办法。
问候,皮特
更新:
调用GetValidationErrors有点问题。我注意到我的数据库Context有ObjectCtext的baseClass而不是DbContext(所以我不能调用ValidateEntity)。我正在使用启用了默认代码生成的Entity Framework 5 - 如果有帮助,请使用数据库第一种方法。
答案 0 :(得分:1)
在致电SaveChanges
之前检查验证错误。有点像...
var errors = context.GetValidationErrors();
if(errors.Any())
{
//handle validation errors
}
else
{
context.SaveChanges();
}
来自内存,因此确切的语法可能不正确。
答案 1 :(得分:0)
这就是我最终的结果(当我了解更多有关EF的信息时,我可能会最终充实它)
public List<DbEntityValidationException> vErrors = new List<DbEntityValidationException>();
public int DbChanges = 0;
public bool SaveChanges()
{
try
{
this.vErrors = (List<DbEntityValidationException>)base.GetValidationErrors();
if (this.vErrors.Count == 0)
{
this.DbChanges = base.SaveChanges();
return true;
}
}
catch (Exception Ex)
{
this.vErrors.Add(new DbEntityValidationException(string.Format("General Error: {0}", Ex.GetType().ToString())));
}
return false;
}
并从代码
using(Db db = new Db())
{
//changes
if(db.SaveChanges)
{
//some message using db.DbChanges
}
else
{
//handle errors in db.vErrors
}