为什么mysql指定timestamp长度就报错
发布网友
发布时间:2022-04-07 16:49
我来回答
共3个回答
懂视网
时间:2022-04-07 21:11
前言
前段时间,系统MySQL从5.5升级到了5.6,系统出现了大量的异常。大部分异常引起原因是由于TIMESTAMP的行为发生了变化。
TIMESTAMP在MySQL5.5中的行为
第一个未设置默认值的TIMESTAMP NOT NULL字段隐式默认值:
CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
后面未设置默认值的TIMESTAMP NOT NULL字段隐式默认值:
0000-00-00 00:00:00
TIMESTAMP NOT NULL字段插入NULL时,会使用隐式默认值:
CURRENT_TIMESTAMP
不支持多个CURRENT_TIMESTAMP 默认值
TIMESTAMP在MySQL5.6中的行为
支持多个CURRENT_TIMESTAMP 默认值
可以兼容5.5的行为,支持隐性默认值
explicit_defaults_for_timestamp=0
我测试安装的MySQL5.6默认使用这个参数,启动时,服务器会给出一个警告。
[Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use –explicit_defaults_for_timestamp server option (see documentation for more details).
可以去掉隐性默认值
explicit_defaults_for_timestamp=1
总结
MySQL5.5中TIMESTAMP行为是比较诡异的,会造成一些隐含的问题,比如程序中传入了NULL值
MySQL5.6中可以将TIMESTAMP的行为变得正常,但会存在兼容问题
explicit_defaults_for_timestamp参数未来会消失
我们不要过度依赖数据库的特性,这些特性会给应用程序造成掣肘
参考:http://dev.mysql.com/doc/refman/5.6/en/server-system-variables.html#sysvar_explicit_defaults_for_timestamp
本文来自:高爽|Coder,
热心网友
时间:2022-04-07 18:19
原因是当你给一个timestamp设置为on updatecurrent_timestamp的时候,其他的timestamp字段需要显式设定default值
不知道上面的说的是否有道理,也是参考别人的。
我觉得原因是因为系统默认default值冲突了。
每行加上deafult null 就行了。
热心网友
时间:2022-04-07 19:37
在MySQL的旧版本中,可以在时态类型之后指定最多19的显示宽度。这在5.5中被删除,在5.6中,时间类型的参数不再意味着显示宽度,但现在意味着分数秒的精度,最高为6表示微秒精度。