在现有数据库中,我有年龄列 (INT)。现在我需要将其设置为 dob (DATETIME)。
我尝试通过 PHPMyAdmin 这样做,将 CURRENT_TIMESTAMP 作为默认值,由answer with 138 upvotes定义。然而,PHPMyAdmin 正在抱怨#1067 - invalid default value for 'dob'
,如随附的屏幕截图所示:
有人可以建议我为什么会收到该错误以及如何解决该错误吗?
在现有数据库中,我有年龄列 (INT)。现在我需要将其设置为 dob (DATETIME)。
我尝试通过 PHPMyAdmin 这样做,将 CURRENT_TIMESTAMP 作为默认值,由answer with 138 upvotes定义。然而,PHPMyAdmin 正在抱怨#1067 - invalid default value for 'dob'
,如随附的屏幕截图所示:
有人可以建议我为什么会收到该错误以及如何解决该错误吗?
我不认为你可以用 mysql date 来实现。您必须使用时间戳或尝试这种方法..
CREATE TRIGGER table_OnInsert BEFORE INSERT ON `DB`.`table`
FOR EACH ROW SET NEW.dateColumn = IFNULL(NEW.dateColumn, NOW());
您收到该错误是因为默认值current_time
对 type 无效DATETIME
。这就是它所说的,这就是正在发生的事情。
您可以使用的唯一字段current_time
是时间戳。
DateTime 的最佳方法是使用触发器:
/************ 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();