MySQL:TIMESTAMP的默认值无效
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL:TIMESTAMP的默认值无效,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1507字,纯文字阅读大概需要3分钟。
内容图文
![MySQL:TIMESTAMP的默认值无效](/upload/InfoBanner/zyjiaocheng/893/260c6f2f81c74d04b50d128a937e0199.jpg)
我收到了错误
ERROR 1067 (42000) at line 5459: Invalid default value for 'start_time'
运行以下查询时
DROP TABLE IF EXISTS `slow_log`;
CREATE TABLE IF NOT EXISTS `slow_log` (
`start_time` timestamp(6) NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
`user_host` mediumtext NOT NULL,
`query_time` time(6) NOT NULL,
`lock_time` time(6) NOT NULL,
`rows_sent` int(11) NOT NULL,
`rows_examined` int(11) NOT NULL,
`db` varchar(512) NOT NULL,
`last_insert_id` int(11) NOT NULL,
`insert_id` int(11) NOT NULL,
`server_id` int(10) unsigned NOT NULL,
`sql_text` mediumtext NOT NULL
) ENGINE=CSV DEFAULT CHARSET=utf8 COMMENT='Slow log';
我正在使用MySQL 5.7.18
$mysql --version
mysql Ver 14.14 Distrib 5.7.18, for osx10.10 (x86_64) using EditLine wrapper
根据MySQL 5.7 documentation,以下语法是
CREATE TABLE t1 (
ts TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
dt DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
);
上面的SQL语法有什么问题?
解决方法:
有趣的是,这两项工作:
`start_time` timestamp(6),
和:
`start_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
您可以使用后者 – 将精度说明符保留在定义之外.
但正确的方法是:
`start_time` timestamp(6) NOT NULL DEFAULT CURRENT_TIMESTAMP(6) ON UPDATE CURRENT_TIMESTAMP(6),
如documentation中所述:
If a
TIMESTAMP
orDATETIME
column definition includes an explicit
fractional seconds precision value anywhere, the same value must be
used throughout the column definition. This is permitted:06003
This is not permitted:
06004
内容总结
以上是互联网集市为您收集整理的MySQL:TIMESTAMP的默认值无效全部内容,希望文章能够帮你解决MySQL:TIMESTAMP的默认值无效所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。