对一个或多个实体的验证失败。有关详细信息,请参见“EntityVali

因为是转载文章 在此标明出处,以前有文章是转的没标明的请谅解,因为有些已经无法找到出处,,或者与其它原因。

如有冒犯请联系本人,或删除,或标明出处。

因为好的文章,以前只想收藏,但连接有时候会失效,所以现在碰到好的直接转到自己这里。

原文 出处

在VS2012里建立ADO.NET实体模型写数据的时候,一直提示“未处理DbEntityValidationException”,"对一个或多个实体的验证失败。有关详细信息,请参见“EntityValidationErrors”属性"。

自己测试了下两个实体,主要是“operate911”引起的错误。

上网查资料,参考了下面这篇文章。

《关于如何查看 EntityValidationErrors 详细信息的解决方法》

但是在写异常的时候,系统没有“DbEntityValidationException”,猜测是缺乏命名空间引用。

于是添加了:

[csharp]view plaincopy

usingSystem.Data.Validation;

对应程序修改为:

[csharp]view plaincopy

try{entities.Operate911.Add(operate911);entities.SaveChanges();}catch(DbEntityValidationExceptiondbEx){}

启动,无异常提示,“operate911”没有将数据写入数据库表。

查看原因是写补充程序的时候,对某一不允许空的列无数据填充,修改之后,启动程序,测试成功。

但是,如果不写异常的话,继续提示最上错误。

而且,“catch (DbEntityValidationException dbEx)”这一句后的参数“dbEx”可以不用写。

继续不明…

09.12补充:

以上try、catch书写不对,没有将异常抛出,更改为:

[csharp]view plaincopy

try{varoperateSpt=newOperateSpt(ymd,timeNow,Operate);entities.OperateSpts.Add(operateSpt);entities.SaveChanges();}catch(DbEntityValidationExceptionex){MessageBox.Show(ex.Message);}

运行结果如下图。

继续不明…

补充:问题解决。

原因:写入的数据与表设定不一致。

我的原因是在某一步的时候,写入的数据为空,但是原表设置为“不允许为空”,所以当进行到这一步操作时会出现异常。

个人太粗心,在查看数据的时候看到其他操作写入了数据,就一直没有想到这个问题。

遇见你,是我一生的幸运;爱上你,

对一个或多个实体的验证失败。有关详细信息,请参见“EntityVali

相关文章:

你感兴趣的文章:

标签云: