SqlDateTime 溢出。必须介于 1/1/1753 12:00:00 AM 和 12/31/9999 11:59:59 PM之间
2015-07-07 14:22
645 查看
错误场景:
用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
plaincopyprint?
//教职工"出生日期";这里设定一个最小日期,防止添加数据库时,时间越界问题
if (txtBornDate.Text.Trim() != "")
{
enStaff.BornDate = Convert.ToDateTime(txtBornDate.Text.Trim());
}
else
{
enStaff.BornDate = new DateTime(1900, 1, 1);
}
相关文章推荐
- 分享微信开发Html5轻游戏中的几个坑
- Extjs4.0 最新最全视频教程
- Javascript中toFixed方法的改进
- 5个常见可用性错误和解决方案
- 我是运营,我没有假期
- 在Windows 8.1的IE 11中屏蔽双击放大功能
- 解决Ajax悬停效果,无法遮蔽FLASH的问题
- DB2数据库的安装
- 通过Mootools 1.2来操纵HTML DOM元素
- 再谈Jquery Ajax方法传递到action(补充)
- WEB标准网页布局中尽量不要使用的HTML标签
- C#实现把指定数据写入串口
- “传奇”图象数据存储方式
- js可突破windows弹退效果代码
- Flash 与 html 的一些实用技巧
- Dom在ajax技术中的作用说明
- html工作中表格<tbody>标签的使用技巧
- HTML 向 XHTML1.0 兼容性指导
- JSP脚本漏洞面面观