MySQL5.6以前对timestamp的一些限制

栏目: 数据库 · 发布时间: 7年前

内容简介:最近在做一个项目,其中需要建立一张管理员的表,DDL语句如下:这一切在我本地环境运行的时候都很正常,但当我在测试环境的数据库运行此段SQL的时候,却出现了如下错误:一开始我还以为是SQL写错了,所以惯性的检查了一遍SQL,还是没发现毛病,网上的很多回答都是关于SQL_MODEL,但我的

最近在做一个项目,其中需要建立一张管理员的表,DDL语句如下:

CREATE TABLE `manager` (
  `id` char(36) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL,
  `name` varchar(10) NOT NULL COMMENT '姓名',
  `phone` varchar(11) NOT NULL COMMENT '手机号码',
  `createdAt` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `updatedAt` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  `deletedAt` datetime,
  PRIMARY KEY (`id`),
  UNIQUE KEY phone (`phone`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='管理员';
复制代码

这一切在我本地环境运行的时候都很正常,但当我在测试环境的数据库运行此段 SQL 的时候,却出现了如下错误:

[42000][1067] Invalid default value for 'createdAt'
复制代码

一开始我还以为是SQL写错了,所以惯性的检查了一遍SQL,还是没发现毛病,网上的很多回答都是关于SQL_MODEL,但我的 SQ_MODEL 是空的,所以并不是这个问题。

最后定位到问题是版本的问题, 因为我本地的 MySQL 版本是5.6,而测试环境的是5.5 ,所以就出现这个问题,关于这个问题还有一点就是在5.5的版本中一个字段是不能同时有两个 CURRENT_TIMESTAMP 的,而5.6之后就解除了一系列的限制。

Previously, at most one TIMESTAMP column per table could be automatically initialized or updated to the current date and time. This restriction has been lifted. Any TIMESTAMP column definition can have any combination of DEFAULT CURRENT_TIMESTAMP and ON UPDATE CURRENT_TIMESTAMP clauses. In addition, these clauses now can be used with DATETIME column definitions. For more information, see Automatic Initialization and Updating for TIMESTAMP and DATETIME.官方解释


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

游戏化思维

游戏化思维

[美] 凯文·韦巴赫(Kevin Werbach)、[美] 丹·亨特(Dan Hunter) / 周逵、王晓丹 / 浙江人民出版社 / 2014-4 / 36.90

[内容简介] ●本书由开设了全世界第一个游戏化课程的沃顿商学院副教授凯文·韦巴赫和丹·亨特所著,第一次全面系统地介绍游戏化的理论,阐述了如何将游戏的理念应用到商业实践中。 ●作者指出,在商业竞争日益激烈的今天,传统的激励方式渐渐失效,未来的管理将更多地建立在员工和消费者的内在动机和自我激励上。这些制作精良、设计巧妙的游戏建立在多年来对人类动机和人类心理的研究基础之上,可以最大限度地激发......一起来看看 《游戏化思维》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

html转js在线工具
html转js在线工具

html转js在线工具

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具