博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MYSQL 更新时间自己主动同步与创建时间默认值共存问题
阅读量:6347 次
发布时间:2019-06-22

本文共 1733 字,大约阅读时间需要 5 分钟。

本文作者:苏生米沿

本文地址:

在使用SQL的时候,希望在更新数据的时候自己主动填充更新时间,那么在mysql中是怎样实现的呢?

如创建表users

CREATE TABLE RS_SIGNUPUSER (        ID VARCHAR(36)  COMMENT '主键(业务功能无关)',        USERNAME VARCHAR(50)  COMMENT '姓名',        USERGENDER VARCHAR(3) DEFAULT '0' COMMENT '性别0男1女',        IDCARDNUMBER VARCHAR(18) COMMENT '身份证号码',        USERNATION VARCHAR(6) COMMENT '民族',        BIRTHDAY DATE  COMMENT '生日',        USERAGE INTEGER COMMENT '年龄',        MOBILEPHONE VARCHAR(11) COMMENT '手机号码',	BZ VARCHAR(6) COMMENT '备注',        	CREATETIME TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '注冊时间',        CREATEUSERID VARCHAR(36) COMMENT '创建人',	PX INTEGER COMMENT '排序',        UPDATEUSERID VARCHAR(20) COLLATE utf8_bin COMMENT '更新人',	UPDATETIME TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP NULL COMMENT '更新时间',	        CONSTRAINT 	  PRIMARY KEY (ID),	  UNIQUE KEY(ZONECODE,USERZYBM)    ) COMMENT ='注冊用户表';
当中,UPDATETIME TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP NULL COMMENT '更新时间',会在更新的时候自己主动填充。啦啦啦。高兴吧。

不要高兴如此早,假设你使用的是mysql5.4版本号,那么你表创建的时候都会报错。别说更新时间了,看:

ERROR 1293 (HY000): Incorrect table definition; there can be only one TIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT or ON UPDATE clause

出错鸟,创建表就失败了。

看5.5版本号的时间戳文档:http://dev.mysql.com/doc/refman/5.5/en/timestamp-initialization.html

  • One  column in a table can have the current timestamp as the default value for initializing the column, as the auto-update value, or both. It is not possible to have the current timestamp be the default value for one column and the auto-update value for another column.

能够看到这个版本号对时间戳有限制。

再看5.7版本号的

http://dev.mysql.com/doc/refman/5.7/en/timestamp-initialization.html

已经没有这个限制了。我认为,低版本号的就仅仅能另想办法,手动或者使用触发器来做更新时间这件事情啦。要么就直接升级版本号解决这个问题。

你可能感兴趣的文章
mpvue开发小程序所遇问题及h5转化方案
查看>>
View和Activity的生命周期
查看>>
解决PHP下载大文件失败,并限制下载速度
查看>>
java B2B2C Springcloud电子商城系统—Feign实例
查看>>
java B2B2C Springcloud多租户电子商城系统 (五)springboot整合 beatlsql
查看>>
Throwable是一个怎样的类?
查看>>
三条代码 搞定 python 生成验证码
查看>>
我的友情链接
查看>>
我的友情链接
查看>>
无线和有线路由哪种性能更好
查看>>
Dwr3.0纯注解(纯Java Code配置)配置与应用浅析三之后端反向调用前端
查看>>
Ubuntu下安装遨游浏览器
查看>>
自定义Linux service脚本
查看>>
微信开发之发红包
查看>>
一键lnmp脚本&&php扩展模块安装(适用于CENTOS6.X系列)
查看>>
二维观察---文字的裁剪
查看>>
矩形覆盖
查看>>
ICMP
查看>>
界面设计模式(第2版)(全彩)
查看>>
解决VMware Workstation错误:未能锁定文件
查看>>