因为是转载文章 在此标明出处,以前有文章是转的没标明的请谅解,因为有些已经无法找到出处,或者与其它原因。
如有冒犯请联系本人,或删除,或标明出处。
因为好的文章,以前只想收藏,但连接有时候会失效,所以现在碰到好的直接转到自己这里。
原文 出处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”,猜测是缺乏命名空间引用。
于是添加了:
- using System.Data.Validation;
对应程序修改为:
- try
- { entities.Operate911.Add(operate911);
- entities.SaveChanges();
- }
- catch (DbEntityValidationException dbEx)
- {
- }
查看原因是写补充程序的时候,对某一不允许空的列无数据填充,修改之后,启动程序,测试成功。
但是,如果不写异常的话,继续提示最上错误。
而且,“catch (DbEntityValidationException dbEx)”这一句后的参数“dbEx”可以不用写。
继续不明...
09.12补充:
以上try、catch书写不对,没有将异常抛出,更改为:
- try
- { var operateSpt = new OperateSpt(ymd, timeNow, Operate);
- entities.OperateSpts.Add(operateSpt);
- entities.SaveChanges();
- }
- catch (DbEntityValidationException ex)
- {
- MessageBox.Show(ex.Message);
- }
运行结果如下图。
继续不明...
补充:问题解决。
原因:写入的数据与表设定不一致。
我的原因是在某一步的时候,写入的数据为空,但是原表设置为“不允许为空”,所以当进行到这一步操作时会出现异常。
个人太粗心,在查看数据的时候看到其他操作写入了数据,就一直没有想到这个问题。