架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 8546|回复: 0

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

[复制链接]
发表于 2015-10-8 20:47:51 | 显示全部楼层 |阅读模式
因为是转载文章 在此标明出处,以前有文章是转的没标明的请谅解,因为有些已经无法找到出处,或者与其它原因。

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

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

原文 出处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 plaincopy
using System.Data.Validation;  

对应程序修改为:
[csharp] view plaincopy
try  
{    entities.Operate911.Add(operate911);  
    entities.SaveChanges();  
}  
catch (DbEntityValidationException dbEx)   
{  

}  
启动,无异常提示,“operate911”没有将数据写入数据库表。
查看原因是写补充程序的时候,对某一不允许空的列无数据填充,修改之后,启动程序,测试成功。



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

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

继续不明...



09.12补充:

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


[csharp] view plaincopy
try  
{      var operateSpt = new OperateSpt(ymd, timeNow, Operate);  
        entities.OperateSpts.Add(operateSpt);  
        entities.SaveChanges();  
}  

catch (DbEntityValidationException ex)  
{  
    MessageBox.Show(ex.Message);  
}  

运行结果如下图。


继续不明...



补充:问题解决。

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

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

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





上一篇:大众点评和美团要合并了,互利共赢。
下一篇:ASP.NET获取根目录的方法集合
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2024-4-25 20:56

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表