出自:http://zhanqifeng2008.blog.163.com/blog/static/3529281720115893451736/
一、错误原因:
传给数据库的时间类型的值为NULL,或者为DateTime.MinValue
这里的NULL指的是程序代码里面的null,大多数出现这种情况的情景是:在程序里面定义了一个时间类型的变量,没有给赋值,就传给数据库(或存储过程了)。这时这个变量的值默认是赋成了01年01月01日。
二、解决方法:
第1种方法:
1、 对日期字段,没赋值的地方或用DateTime.MinValue的地方都换为,SqlDateTime.MinValue
2、 定义一个不程序中不可能用的最小值常量,对日期字段,没赋值的地方或用DateTime.MinValue的地方用此常量
public class DateTimeConst
{
/// <summary>
/// 无效时间(缺省时间)
/// </summary>
public static readonly DateTime INVALID_DATETIME = new DateTime(1900, 1, 1);
}
第2种方法:
在C#中,数据NULL值转换成DataTime时为DateTime.MinValue=0001-01-01
但数据库时间范围是1/1/1753 -
解决方法为
if (date == System.DateTime.MinValue)
XXX= System.DateTime.Now;
else
XXX=date;
-------------
通常情况下,我们不在日期字段里存入空值.
当没有日期值时存入'1900-1-1',这个叫做默认时间值。
在读取数据的时候,遇到1900-1-1就认为数据库该时间没有值