(转)SqlDateTime 溢出。必须介于 1/1/1753 12:00:00 AM 和 12/31/9999 11:59:59 PM之间

Posted 学以致用

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了(转)SqlDateTime 溢出。必须介于 1/1/1753 12:00:00 AM 和 12/31/9999 11:59:59 PM之间相关的知识,希望对你有一定的参考价值。

原因:

    出现这种问题多半是因为你插入或者更新数据库时,datetime字段值为空默认插入0001年01月01日造成datetime类型溢出。

    传给数据库表的时间类型值是null值。这里的null指的是程序代码中的null,多数出现这种情况的场景是:在程序里面定义了一个时间类型的变量,没有给赋值,就传给数据库,这时这个变量的值默认是赋成了01年01月01日;由于数据库中DateTime类型字段,最小值是1/1/1753 12:00:00,而.NET Framework中,DateTime类型,最小值是1/1/0001 0:00:00,显然,超出了sql的值的最小值范围,导致数据溢出错误。

    .NET Framework框架与数据库 时间类型最小值不同,从.NET Framework框架向数据库传时间类型的值会出错。

解决方法: 

    使用System.Data.SqlTypes.SqlDateTime.MinValue替代System.DateTime类型,这样SqlDateTime的MinValue和Sql中DateTime的范围吻合,就不会再出现以上的错误了。

    如果日期在文本框中不填写,则给其赋一个最小值

       

 

 原文:http://blog.csdn.net/mazhaojuan/article/details/8194253

以上是关于(转)SqlDateTime 溢出。必须介于 1/1/1753 12:00:00 AM 和 12/31/9999 11:59:59 PM之间的主要内容,如果未能解决你的问题,请参考以下文章

SqlDateTime 溢出。必须介于 1/1/1753 12:00:00 AM 和 12/31/9999 11:59:59 PM之间---解决办法

SqlDateTime 溢出。必须介于 1/1/1753 12:00:00 AM 和 12/31/9999 11:59:59 PM之间。”应该如何解决?

如何解决SqlDateTime 溢出

c#sqldatetime 溢出怎么解决

如何在不使用IUserType的情况下查询数据库时防止NHibernate SqlDateTime溢出?

将数据表中的所有 DateTime 列转换为 SqlDateTime 列