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补充添加:
经过这样处理,前端用户不管是否填写日期,均不会有此异常提示,当然在前端页面中,用户一旦有填写,还需要对用户填写的是否为有效的日期。
哈哈,如果你从数据读取出来是空值时,它显示是怎样的?
如上所显示,Insus.NET觉得很不友好。正常来说,空值时,显示时,应该什么都不显示才对的。
那改一下程序:
最后,可以把上面存储入数据库和从数据读取显示转换的代码,写成一个静态方法: