mysql只能有一列是timestamp的问题

本文探讨了在MySQL中创建包含两个TIMESTAMP字段(created_at和updated_at)的表时遇到的问题。当试图设置默认值为CURRENT_TIMESTAMP时,可能会遇到错误提示。文章详细解释了如何正确地定义这两个字段,确保在插入新记录时可以正常工作。

MySQL Error “There can be only one TIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT clause” even though I'm doing nothing wrong

http://jasonbos.co/two-timestamp-columns-in-mysql/


这是一个非常常见的表:有create_time , update_time,甚至可以说是规范,当然我们想这些时间自动更新,交给Mysql处理,但是问题来了:

创建一个这样的表:

CREATE TABLE `test_table` (
`id` INT( 10 ) NOT NULL,
`created_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
`updated_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
) ENGINE = INNODB;

原来Mysql会自动处理:

CREATE TABLE `test_table` (
`id` INT( 10 ) NOT NULL,
`created_at` TIMESTAMP NOT NULL DEFAULT 0,
`updated_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
) ENGINE = INNODB;
INSERT INTO test_table (id, created_at, updated_at) VALUES (1, NULL, NULL);

have fun...

转载于:https://my.oschina.net/ifeixiang/blog/425012

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值