zoukankan      html  css  js  c++  java
  • SqlDateTime 溢出。必须介于 1/1/1753 12:00:00 AM 和 12/31/9999 11:59:59 PM之间


    错误场景:

        用ASP.NET制作web网站的添加用户功能时,调用写好的存储过程出错哭

     

    错误提示:

     


    出错原因:

        出现这种问题多半是因为你插入或者更新数据库时,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的值的最小值范围,导致数据溢出错误。

        我遇到的情况是:

        我是用sqlParameter传给存储过程需要的值,然后存储过程用insert语句等实现添加用户功能。有一些日期时间数据是不需要代码给传值的。但我的代码里面定义了所有的sqlparameter,多出来的sqlparameter虽然在数据库中没有参数接受,但如果传进来一个有问题的datetime类型,同样报错。

     

    原来如此:

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

     

    解决方法:

     

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

        我对日期数据处理的方式,如下所示:如果日期在文本框中不填写,则给其赋一个最小值

           

    1. //教职工"出生日期";这里设定一个最小日期,防止添加数据库时,时间越界问题  
    2.         if (txtBornDate.Text.Trim() != "")  
    3.         {  
    4.             enStaff.BornDate = Convert.ToDateTime(txtBornDate.Text.Trim());  
    5.         }  
    6.         else  
    7.         {  
    8.             enStaff.BornDate = new DateTime(1900, 1, 1);  
    9.         }  
  • 相关阅读:
    经常让程序员恼火的一些事情你是否也遇到过一些?
    CRC文件解压缩问题
    你在淘宝买件东西背后的复杂技术 技术普及帖
    程序员需要戒骄戒躁
    IT路上的应该注意自我规划 学习规划与自我修炼
    腾讯,我最恨别人用枪顶着我的头(转)
    软件管理,软件生命周期,软件过程名词解释
    程序员需要掌握的最终技术是什么? “终极技术”:应对困境的方法和信念
    程序员如何缓解“电脑病”
    新浪微博XSS攻击事件
  • 原文地址:https://www.cnblogs.com/q101301/p/3663631.html
Copyright © 2011-2022 走看看