MySQL 5.6 中 TIMESTAMP有那些变化

2019-01-04 21:26:57王振洲

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参数未来会消失 我们不要过度依赖数据库的特性,这些特性会给应用程序造成掣肘

您可能感兴趣的文章:

MySQL 5.6 中的 TIMESTAMP 和 explicit_defaults_for_timestamp 参数MySQL 5.6 中 TIMESTAMP 的变化分析MySQL 5.6 中TIMESTAMP with implicit DEFAULT value is deprecated错误Mysql中的Datetime和Timestamp比较mysql 数据类型TIMESTAMPmysql之TIMESTAMP(时间戳)用法详解MySQL错误TIMESTAMP column with CURRENT_TIMESTAMP的解决方法解析mysql中UNIX_TIMESTAMP()函数与php中time()函数的区别MySQL timestamp自动更新时间分享mysql多个TimeStamp设置的方法解读mysql From_unixtime及UNIX_TIMESTAMP及DATE_FORMAT日期函数MySQL timestamp的类型与时区实例详解