SqlDateTime overflow. Must be between 1/1/1753 12:00:00 AM and 12/31/9999 11:59:59 PM.

相信很多人进行数据存储时,会遇上如标题的异常错误。

其实也不算上一个错误。

当你的程序中有宣告一个字段的数据类型为DateTime时,但你又没有赋值给它,就进行存储时,它就会得到这样一个结果。

看看下面的情况:


看到否,在程序中DateTime默认情况之下是这个值{1/1/0001 12:00:00 AM},其实它就是.NET Framework中DateTime类型最小默认值。而在数据库中DateTime类型字段,默认最小值是1/1/1753 12:00:00。显然,超出了MS SQL DateTime数据类型的最小值范围,导致数据溢出错误。

那我们怎解决它呢?其实是很简单的。只要在存储数据库之前判断一下,如果值等于"1/1/0001 12:00:00 AM" ,那就等System.Data.SqlTypes.SqlDateTime.Null

看看代码示例:


还可以使用DateTime.MinValue去替换Convert.ToDateTime("1/1/0001 12:00:00 AM")。


当然,有一个前提是数据表存储这个字段是设为可空的,如果不是可空的,你需要在前端程序一定有值给它,也就没有这个情况出现了。

 

以下内容于2024-10-25 15:45补充添加


今天修改程序,又遇上此问题,好得以前有写问题随笔。

 

model如下写法:

 

xxx.aspx.cs


最后,传入数据:

 

经过这样处理,前端用户不管是否填写日期,均不会有此异常提示,当然在前端页面中,用户一旦有填写,还需要对用户填写的是否为有效的日期。

哈哈,如果你从数据读取出来是空值时,它显示是怎样的?

 

显示如下:


如上所显示,Insus.NET觉得很不友好。正常来说,空值时,显示时,应该什么都不显示才对的。
那改一下程序:

最后,可以把上面存储入数据库和从数据读取显示转换的代码,写成一个静态方法:

 

posted @ 2016-12-11 18:13  Insus.NET  阅读(2414)  评论(0编辑  收藏  举报