在SQL中插入一行时在“时间”列自动生成系统时间?

在SQL中如输入
ALTER TABLE [dbo].[订单表]
alter column 时间 datetime default getDate();
为什么执行时候会显示:
消息 156,级别 15,状态 1,第 2 行
关键字 'default' 附近有语法错误。

MySQL 里面.
默认值, 不允许使用 函数

你想在时间列生成系统时间的话可以这样(更新数据时仍保持输入的时间)
alter column 时间 timestamp DEFAULT CURRENT_TIMESTAMP

如果想在更新的时候令时间列变成更新的时间,可以这样:
alter column 时间 timestamp DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP

输入的时候注意,要把时间列设为null,不然会使用输入的时间
如 insert into table(时间) values(null);
温馨提示:答案为网友推荐,仅供参考
第1个回答  2012-12-27
已经存在的字段是不能这样来加默认值的,你可以用如下方式来设定
ALTER TABLE dbo].[订单表]
ADD CONSTRAINT col_b_def DEFAULT getdate() FOR 时间 ;本回答被提问者采纳
第2个回答  推荐于2017-08-18
在SQL中插入一行时在“时间”列自动生成系统时间?
已经存在的字段是不能这样来加默认值的,你可以用如下方式来设定
ALTER TABLE dbo].[订单表]
ADD CONSTRAINT col_b_def DEFAULT getdate() FOR 时间 ;本回答被网友采纳
第3个回答  2012-12-26
这个你可以试试分布执行
1:更改字段类型为DATETIME类型
ALTER TABLE [订单表] ALTER COLUMN 时间 DATETIME
2:为该字段设置默认值
alter table [订单表] add constraint defaultValue DEFAULT GETDATE() for 时间

希望能帮到你……
第4个回答  2012-12-26
getDate()不能这样写
相似回答