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

其实也不算上一个错误。

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

看看下面的情况:
SqlDateTime overflow. Must be between 1/1/1753 12:00:00 AM and 12/31/9999 11:59:59 PM.

看到否,在程序中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

看看代码示例:
SqlDateTime overflow. Must be between 1/1/1753 12:00:00 AM and 12/31/9999 11:59:59 PM.


还可以使用DateTime.MinValue去替换Convert.ToDateTime("1/1/0001 12:00:00 AM")。
SqlDateTime overflow. Must be between 1/1/1753 12:00:00 AM and 12/31/9999 11:59:59 PM.

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

 

相关文章:

  • 2022-12-23
  • 2021-10-26
  • 2021-06-18
  • 2022-12-23
  • 2021-12-03
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2021-05-18
  • 2021-05-31
  • 2021-06-08
  • 2021-06-09
  • 2021-12-13
相关资源
相似解决方案