当我们在使用Domain Service Class以及Entity Framework工作的时候,可能会出现因为隐藏的内部代码,而不知道错在哪里。
比如,在客户端程序需要向服务器端提交一个数据项,这个数据项包含了一个时间。
当我输入是: 1/1/0001 12:00:00 AM时,始终不对,百思不得其解。还以为是Entity Model的问题,这个问题困扰了我一段时间。
解决办法是:在DomainDataSource中加入一个SumittedChanges的事件。如:
private void LibraryDataSource_OnSubmittedChanges(object sender, SubmittedChangesEventArgs e)
{
if (e.HasError)
{
System.Diagnostics.Debug.WriteLine(e.Error.ToString());
e.MarkErrorAsHandled();
}
}
这样可以在Output中看到出现的问题。方便我们定位问题的原因。在Output中显示:
System.ServiceModel.DomainServices.Client.DomainOperationException: Submit operation failed. An error occurred while updating the entries. See the inner exception for details. InnerException 消息: SqlDateTime overflow. Must be between 1/1/1753 12:00:00 AM and 12/31/9999 11:59:59 PM.
这样我们知道了问题的原因在于输入的时间字符串范围不对。按照Output中指示的进行修改后,即完成。这也就表明我们需要加入输入验证