MySQL从5.5升级到5.6,TIMESTAMP的变化
来源:互联网 发布:网络布线从入门到精通 编辑:程序博客网 时间:2024/05/20 21:19
前言
前段时间,系统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,原文地址:http://blog.csdn.net/ghsau/article/details/45625841,转载请注明。
0 0
- MySQL从5.5升级到5.6,TIMESTAMP的变化
- MySQL的TIMESTAMP 的变化
- linux上的mysql从5.5升级到5.6
- mysql 5.6 timestamp变化--explicit_default_for_timestamp
- 从Indy9升级到Indy10时IdTcpServer的变化
- 从Indy9升级到Indy10时IdTcpServer的变化
- 从Indy9升级到Indy10时IdTcpServer的变化
- Ubuntu 12.04.1 mysql从5.5升级到5.6
- 在CentOS上把MySQL从5.5升级到5.6
- 在CentOS上把MySQL从5.5升级到5.6
- centos mysql从5.1升级到5.6
- mysql 从 version 5.1 到 6.0的变化
- 从 Delphi 7 升级到 Delphi 2010 基本数据类型的变化
- MySQL从5.0升级到5.1注意的问题
- suse 11 mysql 如何从5.1升级到5.5
- 手动从Mysql 5.1.X 升级到 5.5.X 要注意的其它内容
- 升级mysql-connector-java中timestamp的坑
- 一次mysql 5.5升级到5.6导致的ERROR 1805
- JavaScript传各种方法值
- 我所理解的抽象
- Android 系统上抓取数据包方法
- 字符串中找出连续最长的数字串
- 机房重构 报表 “不能传泛型?”
- MySQL从5.5升级到5.6,TIMESTAMP的变化
- apt-get常用命令
- 2015河南ACM省赛 - 小记
- Centos 6.5安装git
- Jquery基础教程之-选择元素
- xts可扩展的时间序列
- CloudSimExample1-仿真步骤
- 动态配置连接数据库
- 循环链表 ——解决约瑟夫环