0

在工作中,我们希望迁移到 ORM(仍在使用 ADO 的 access 数据库!)我开始使用实体框架进行构建,一切进展顺利,直到我将其分离到自己的 .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?)或者我应该采取不同的方法。我想我只需要朝着正确的方向前进,我就能想出办法。

问候,皮特

更新:

嗯,调用 GetValidationErrors 有点问题。我注意到我的数据库上下文具有 ObjectContext 的基类而不是 DbContext(所以我不能调用 ValidateEntity)。我正在使用启用了默认代码生成的 Entity Framework 5 - 如果有帮助,请使用数据库优先方法。

4

2 回答 2

1

在调用之前检查验证错误SaveChanges。就像是...

var errors = context.GetValidationErrors();
if(errors.Any())
{
   //handle validation errors
}
else
{
    context.SaveChanges();
}

来自内存,因此确切的语法可能不正确。

于 2013-02-12T13:46:38.017 回答
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
}
于 2013-02-13T16:47:28.163 回答