sql server 时间1900-01-01

关于时间的处理,在输入值的时候,由于没有输入,结果在数据库中却保存为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;




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值