【问题标题】:MySQL default datetime through phpmyadminMySQL 默认日期时间通过 phpmyadmin
【发布时间】:2012-10-15 08:45:06
【问题描述】:

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

我尝试通过 PHPMyAdmin 执行此操作,将 CURRENT_TIMESTAMP 作为answer with 138 upvotes 定义的默认值。然而 PHPMyAdmin 抱怨#1067 - invalid default value for 'dob' 如附件截图所示:

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

【问题讨论】:

  • 想知道出生日期如何将当前时间作为默认值?
  • @Mithun。只是暂时的价值。稍后将随其他值而变化。
  • 现在这样工作

标签: mysql phpmyadmin


【解决方案1】:

You can't set CURRENT_TIMESTAMP 作为 DATETIME 的默认值。

但您可以使用 TIMESTAMP 来做到这一点。

查看区别here

来自this博客的话

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

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

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

【讨论】:

【解决方案2】:

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

【讨论】:

    【解决方案3】:

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

    CREATE TRIGGER table_OnInsert BEFORE INSERT ON `DB`.`table`
    FOR EACH ROW SET NEW.dateColumn = IFNULL(NEW.dateColumn, NOW());
    

    【讨论】:

      【解决方案4】:

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

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

      【讨论】:

        【解决方案5】:

        日期时间的最佳方式是使用触发器:

        /************ 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();
        

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 2011-07-19
          • 1970-01-01
          • 2012-12-07
          • 1970-01-01
          • 2014-01-09
          • 2012-11-02
          • 2012-02-16
          相关资源
          最近更新 更多