在现有的数据库,我已经年龄列(INT)。 现在我需要将其设置为DOB(DATETIME)。
我试图通过phpmyadmin这样做,给CURRENT_TIMESTAMP为默认值,按照定义的答案有138个upvotes 。 然而phpMyAdmin是抱怨#1067 - invalid default value for 'dob'
,如附截图:
可有人请说明为什么我收到的错误,以及如何解决这个问题?
在现有的数据库,我已经年龄列(INT)。 现在我需要将其设置为DOB(DATETIME)。
我试图通过phpmyadmin这样做,给CURRENT_TIMESTAMP为默认值,按照定义的答案有138个upvotes 。 然而phpMyAdmin是抱怨#1067 - invalid default value for 'dob'
,如附截图:
可有人请说明为什么我收到的错误,以及如何解决这个问题?
你不能设置 CURRENT_TIMESTAMP与DATETIME默认值。
但是你可以用TIMESTAMP做到这一点。
看到其中的差别在这里 。
从话本博客
在数据类型规范的默认值子句表示为列的默认值。 有一个例外,默认值必须是常量; 它不能是一个功能或表达。
这意味着,例如,可以不设置用于一个日期栏的缺省为一个函数的值,例如NOW()或CURRENT_DATE。
唯一的例外是,您可以指定CURRENT_TIMESTAMP为默认的时间戳列。
我不认为你可以做到这一点与MySQL日期。 你必须使用时间戳或尝试此方法..
CREATE TRIGGER table_OnInsert BEFORE INSERT ON `DB`.`table`
FOR EACH ROW SET NEW.dateColumn = IFNULL(NEW.dateColumn, NOW());
设置字段作为TIMESTAMP的类型了。
你得到的错误,因为默认值current_time
是无效的类型DATETIME
。 这就是它说,这是怎么回事。
您可以使用的唯一字段current_time
上是一个时间戳。
对于日期时间的最好方法是使用触发器:
/************ ROLE ************/
drop table if exists `role`;
create table `role` (
`id_role` bigint(20) unsigned not null auto_increment,
`date_created` datetime,
`date_deleted` datetime,
`name` varchar(35) not null,
`description` text,
primary key (`id_role`)
) comment='';
drop trigger if exists `role_date_created`;
create trigger `role_date_created` before insert
on `role`
for each row
set new.`date_created` = now();