加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

SqlDateTime 溢出。必须介于 1/1/1753 12:00:00 AM 和 12/31/999

发布时间:2020-12-16 01:56:42 所属栏目:百科 来源:网络整理
导读:错误场景: 用ASP.NET制作web网站的添加用户功能时,调用写好的存储过程出错 错误提示: 出错原因: 出现这种问题多半是因为你插入或者更新数据库时,datetime字段值为空默认插入0001年01月01日造成datetime类型溢出。 传给数据库表的时间类型值是null值。这

错误场景:

用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的范围吻合,就不会再出现以上的错误了。

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

[csharp] view plain copy print ?
  1. //教职工"出生日期";这里设定一个最小日期,防止添加数据库时,时间越界问题
  2. if(txtBornDate.Text.Trim()!="")
  3. {
  4. enStaff.BornDate=Convert.ToDateTime(txtBornDate.Text.Trim());
  5. }
  6. else
  7. enStaff.BornDate=newDateTime(1900,1,1);
  8. }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读