MySQL 默认日期时间通过 phpmyadmin
Posted
技术标签:
【中文标题】MySQL 默认日期时间通过 phpmyadmin【英文标题】:MySQL default datetime through phpmyadmin 【发布时间】:2012-10-15 08:45:06 【问题描述】:在现有数据库中,我有年龄列 (INT)。现在我需要将其设置为 dob (DATETIME)。
我尝试通过 phpMyAdmin 执行此操作,将 CURRENT_TIMESTAMP 作为answer with 138 upvotes 定义的默认值。然而 PHPMyAdmin 抱怨#1067 - invalid default value for 'dob'
如附件截图所示:
有人可以建议我为什么会收到这个错误以及如何解决这个问题吗?
【问题讨论】:
想知道出生日期如何将当前时间作为默认值? DATETIME Vs TIMESTAMP @Mithun。只是暂时的价值。稍后将随其他值而变化。 现在这样工作 【参考方案1】:You can't set CURRENT_TIMESTAMP 作为 DATETIME 的默认值。
但您可以使用 TIMESTAMP 来做到这一点。
查看区别here。
来自this博客的话
数据类型规范中的 DEFAULT value 子句表示列的默认值。除了一个例外,默认值必须是一个常量;它不能是函数或表达式。
这意味着,例如,您不能将日期列的默认值设置为 NOW() 或 CURRENT_DATE 等函数的值。
例外情况是您可以将 CURRENT_TIMESTAMP 指定为 TIMESTAMP 列的默认值。
【讨论】:
谢谢。我使用 null 作为临时值。最初我试图通过not null
并使用当前日期作为默认值,但似乎这是不可能的。暂时允许 null 并且它起作用了。
对于未来的读者:请注意,这不再适用。自 mysql 5.6.5 起,DATETIME
可以将 CURRENT_TIMESTAMP
作为默认值。 dev.mysql.com/doc/refman/5.6/en/timestamp-initialization.htmldev.mysql.com/doc/refman/8.0/en/timestamp-initialization.html【参考方案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();
【讨论】:
以上是关于MySQL 默认日期时间通过 phpmyadmin的主要内容,如果未能解决你的问题,请参考以下文章
通过 PhPMyAdmin 在 MySql Server 上设置默认时区