mac + mysql
在创建表的时候遇到了Invalid default value for 'created_at'的错误,不知道什么原因造成的。
CREATE TABLE `test` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`title` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
`created_at` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
`updated_at` timestamp NOT NULL DEFAULT '1970-01-01 00:00:00',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
默认数据使用“0000-00-00 00:00:00”报错,使用“1970-01-01 00:00:00”也同样报错。
首先谢谢各位的帮助,费了很大的劲终于找到了解决办法:
首先用下面的命令看下sql_mode
如果查询的结果如下:
如果结果中含有NO_ZERO_IN_DATE, NO_ZERO_DATE
则执行下面的命令:
timestamp 是数字
1970-00-00 这是 date格式
类型不同
timestamp这个字符类型是有范围的,如果要使用0000-00-00 00:00:00就只能使用字符串了
可以参考我的这篇博客:http://www.cnblogs.com/chenmh/p/4565986....