关于时间的处理,在输入值的时候,由于没有输入,结果在数据库中却保存为1900-01-01,这样显然不符合要求。
经过测试:
1.发现如果给日期时间类型的赋予默认当前时间,则在insert表中字段没有的情况下,存入数据库的值就是当前时间,这个没有疑问,但是mysql中不支持时间类型的默认值。
2.如果给日期字段(以datetime为例)一个null的value,则保存到数据库是null,也没有问题。
3.但当给日期字段一个空字符串(''),此时数据库将转换为1900-01-01 00:00:00.000。
4.如果insert的字段没有,也没有默认值,此时保存到数据库的值还是null。
测试sql语句如下:
建表
create table timeTest(
tid int identity primary key,Time1 datetime default(getdate()),--默认值为当前时间
Time2 datetime,
Time3 datetime,
Time4 datetime,
t3 int)
insert into timeTest(Time2,Time3,t3) values('',null,12);
select tid,Time1 as '默认值',Time2 '空字符串''''',Time3 'null',Time4 '未插入',t3 from timeTest;