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

转载 2015年07月07日 14:22:10

错误场景:

    用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.         }  

相关文章推荐

解决: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 之间。 问题现象: ...

小议:Work Management Service 总保持显示“ Last updated at 1/1/1901 12:00 AM”的解决方案

可能很多SharePoint管理员在部署Work Management Service时经常遇到一个问题,部署完成之后,在My Site的Task中,显示的时间为1/1/190112:00 A...

SQL Server数据类型,其中的日期有范围datetime:旧版本的日期时间类型,范围1753-01-01 to 9999-12-31,精确到3.33毫秒

整数数据类型: tinyint存储的是一个字节(8位),值范围是0-255smallint存储的是两字节(16位),值范围是-32768-32767int存储的是四字节(32位),值范围是-21...

http://blog.csdn.net/w00w12l/article/details/8143591?locationNum=14&fps=1 转载请注明出处 Android异步处理系列文章索引

在《Android异步处理二:使用AsyncTask异步更新UI界面》一文中,我们介绍了如何使用AsyncTask实现异步下载图片,并且更新图片到UI界面的方法。本篇我们将学习Framework层As...

移动互联周考面试题 http://blog.csdn.net/w00w12l/article/details/8143591?locationNum=14&fps=1

这是我的周考面试题 需要把面试题好好复习下 这样才会在工作有个好的发展 http://blog.csdn.net/w00w12l/article/details/8143591?locati...

2011-7-31 12:59:42

2011-7-31 12:59:42 int ipmc_init_sysop(void) {  int i, j, step;  struct ipmc_ioctl_getfvopinfo...

关于RTF(富文本格式)的使用 (2008-12-14 13:59:11)转载

富文本格式(RTF)规范是为了便于在应用程序之间轻松转储格式化文本和图形的一种编码方法。现在,用户可以利用特定转换软件,在不同系统如MS-DOS、Windows、OS/2、 Macintosh和Po...
  • huixx
  • huixx
  • 2011-09-05 17:21
  • 1246

判断时间段是否交叉(比如12:34~13:49与11:44~14:59)

大致思路就是先将其格式化然后再比较时间/** * 12:15~13:59 11:59~12:59 13:58-15:59与14:00-15:59 * * @param timeAr...

关于stdcall等调用& (2006-11-12 01:34:00)

关于stdcall等调用&  (2006-11-12 01:34:00) 转载▼ 标签:  杂谈   stdcall是函数调用约定的...

java算法过程:要求如下 有如下二维数组:有10行 4列 a00 a01 a02 a03 a10 a11 a12 a13

import java.util.ArrayList; import java.util.List;   public class 百度知道 {     public ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)