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

时间:2022-06-17 17:15:12

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

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

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

原文 出处http://blog.csdn.net/snowinfish/article/details/11567301



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

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

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

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

http://www.cnblogs.com/zhourq/archive/2011/11/03/2234720.html

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

于是添加了:

[csharp]  view plain copy
  1. using System.Data.Validation;  

对应程序修改为:

[csharp]  view plain copy
  1. try  
  2. {    entities.Operate911.Add(operate911);  
  3.     entities.SaveChanges();  
  4. }  
  5. catch (DbEntityValidationException dbEx)   
  6. {  
  7.   
  8. }  
启动,无异常提示,“operate911”没有将数据写入数据库表。

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


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

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

继续不明...


09.12补充

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

[csharp]  view plain copy
  1. try  
  2. {      var operateSpt = new OperateSpt(ymd, timeNow, Operate);  
  3.         entities.OperateSpts.Add(operateSpt);  
  4.         entities.SaveChanges();  
  5. }  
  6.   
  7. catch (DbEntityValidationException ex)  
  8. {  
  9.     MessageBox.Show(ex.Message);  
  10. }  

运行结果如下图。


继续不明...


补充:问题解决。

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

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

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