[MySQL] mysql 5.5和 5.6 timestamp default 默认值CURRENT_TIMESTAMP问题

TIMESTAMP在MySQL5.5中的行为:

1.第一个未设置默认值的TIMESTAMP NOT NULL字段隐式默认值:CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP

2.后面未设置默认值的TIMESTAMP NOT NULL字段隐式默认值:0000-00-00 00:00:00

3.不支持多个CURRENT_TIMESTAMP 默认值

5.5的建表语句类似这样:

复制代码
CREATE TABLE `audit_log` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `ent_id` int(10) unsigned NOT NULL DEFAULT '0',
  `rule_id` int(10) unsigned NOT NULL DEFAULT '0',
  `rules_detail` varchar(2048) NOT NULL DEFAULT '' COMMENT '规则详情',
  `sender_email` varchar(512) NOT NULL DEFAULT '' COMMENT '发件人被审核邮箱',
  `receiver_email` varchar(512) NOT NULL DEFAULT '' COMMENT '收件人邮箱',
  `subject` varchar(512) NOT NULL DEFAULT '' COMMENT '主题',
  `createtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `start_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
  `end_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
  `status` tinyint(3) unsigned NOT NULL DEFAULT '1' COMMENT '当前状态(1 通过,2 拒绝,3 超时拒绝,4 超时通过)',
  `reviewer_leader` varchar(512) NOT NULL DEFAULT '' COMMENT '审核人',
  PRIMARY KEY (`id`),
  KEY `idx_ent_id` (`ent_id`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8 COMMENT='审核日志表'
复制代码

 

 

TIMESTAMP在MySQL5.6中的行为:

支持多个CURRENT_TIMESTAMP 默认值,但是不支持设置默认值为0000-00-00 00:00:00

5.6的可以这样:

  `createtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `start_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `end_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,

 

posted @   唯一客服系统开发笔记  阅读(2399)  评论(0编辑  收藏  举报
编辑推荐:
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
阅读排行:
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
历史上的今天:
2019-11-20 [MySQL] 解决Error 1698: Access denied for user 'root'@'localhost'
2019-11-20 [Go] gocron源码阅读-判断是否使用root用户执行
2019-11-20 [日常] 前端资源测试机上忽略版本号的的nginx配置
2018-11-20 [PHP] 多进程通信-消息队列使用
点击右上角即可分享
微信分享提示
1
chat with us