24

在现有数据库中,我有年龄列 (INT)。现在我需要将其设置为 dob (DATETIME)。

我尝试通过 PHPMyAdmin 这样做,将 CURRENT_TIMESTAMP 作为默认值,由answer with 138 upvotes定义。然而,PHPMyAdmin 正在抱怨#1067 - invalid default value for 'dob',如随附的屏幕截图所示:

错误截图

有人可以建议我为什么会收到该错误以及如何解决该错误吗?

4

5 回答 5

27

您不能使用 DATETIME 将 CURRENT_TIMESTAMP 设置为默认值。

但是你可以用 TIMESTAMP 来做到这一点。

看看这里的区别。

这个博客的话

数据类型规范中的 DEFAULT value 子句指示列的默认值。除了一个例外,默认值必须是一个常量;它不能是函数或表达式。

例如,这意味着您不能将日期列的默认值设置为 NOW() 或 CURRENT_DATE 等函数的值。

例外情况是您可以将 CURRENT_TIMESTAMP 指定为 TIMESTAMP 列的默认值。

于 2012-10-25T08:04:48.143 回答
4

也将字段的类型设置为 TIMESTAMP。

在此处输入图像描述

于 2017-07-25T15:26:51.583 回答
3

我不认为你可以用 mysql date 来实现。您必须使用时间戳或尝试这种方法..

CREATE TRIGGER table_OnInsert BEFORE INSERT ON `DB`.`table`
FOR EACH ROW SET NEW.dateColumn = IFNULL(NEW.dateColumn, NOW());
于 2012-10-25T08:26:31.030 回答
2

您收到该错误是因为默认值current_time对 type 无效DATETIME。这就是它所说的,这就是正在发生的事情。

您可以使用的唯一字段current_time是时间戳。

于 2012-10-25T08:02:27.683 回答
1

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();
于 2015-02-19T13:39:48.617 回答