SqlDateTime overflow. Must be between 1/1/1753 12:00:00 AM and 12/31/9999 11:59:59 PM.
2016-12-11 18:13
309 查看
相信很多人进行数据存储时,会遇上如标题的异常错误。
其实也不算上一个错误。
当你的程序中有宣告一个字段的数据类型为DateTime时,但你又没有赋值给它,就进行存储时,它就会得到这样一个结果。
看看下面的情况:
看到否,在程序中DateTime默认情况之下是这个值{1/1/0001 12:00:00 AM},其实它就是.NET Framework中DateTime类型最小默认值。而在数据库中DateTime类型字段,默认最小值是1/1/1753 12:00:00。显然,超出了MS SQL DateTime数据类型的最小值范围,导致数据溢出错误。
那我们怎解决它呢?其实是很简单的。只要在存储数据库之前判断一下,如果值等于"1/1/0001 12:00:00 AM" ,那就等System.Data.SqlTypes.SqlDateTime.Null
看看代码示例:
还可以使用DateTime.MinValue去替换Convert.ToDateTime("1/1/0001 12:00:00 AM")。
当然,有一个前提是数据表存储这个字段是设为可空的,如果不是可空的,你需要在前端程序一定有值给它,也就没有这个情况出现了。
其实也不算上一个错误。
当你的程序中有宣告一个字段的数据类型为DateTime时,但你又没有赋值给它,就进行存储时,它就会得到这样一个结果。
看看下面的情况:
看到否,在程序中DateTime默认情况之下是这个值{1/1/0001 12:00:00 AM},其实它就是.NET Framework中DateTime类型最小默认值。而在数据库中DateTime类型字段,默认最小值是1/1/1753 12:00:00。显然,超出了MS SQL DateTime数据类型的最小值范围,导致数据溢出错误。
那我们怎解决它呢?其实是很简单的。只要在存储数据库之前判断一下,如果值等于"1/1/0001 12:00:00 AM" ,那就等System.Data.SqlTypes.SqlDateTime.Null
看看代码示例:
还可以使用DateTime.MinValue去替换Convert.ToDateTime("1/1/0001 12:00:00 AM")。
当然,有一个前提是数据表存储这个字段是设为可空的,如果不是可空的,你需要在前端程序一定有值给它,也就没有这个情况出现了。
相关文章推荐
- HoloLens开发手记 - Vuforia开发概述 Vuforia development overview
- npm install 本地安装与全局安装的区别
- 张小龙谈如何做将产品做简单转自雷锋网
- 张小龙的产品思考笔记
- 10、rpm 包的安装与卸载
- JBPM工作流
- 汇编的压栈(PSHM)和出栈(POPM)
- 命令误删恢复方法
- Exploit Development – Stack Overflow
- 从备考PMP到与项目经理同呼吸
- npm 加速方案
- 高级产品经理教你如何进行用户画像及其应用场景
- 静态分析工具PMD使用说明
- NVMe PM951 硬盘写入速度优化
- npm部分常用指令
- PMAC 误差补偿的方法及步骤
- 12. Takeaways: Setting up development and test sets 小结:建立开发集和测试集(《MACHINE LEARNING YEARNING》翻译)
- kernel rpm包的制作
- jbpm
- JBPM