MYSQL 更新时间自动同步与创建时间默认值共存问题

本文详细介绍了在MySQL中如何通过在表创建时定义 TIMESTAMP 类型的默认值为 CURRENT_TIMESTAMP 和 ON UPDATE CURRENT_TIMESTAMP 的方式来自动填充更新时间。特别地,文章指出在MySQL 5.4版本中存在限制,而从5.5版本开始已解除这一限制。对于低版本的MySQL,可能需要采用手动或触发器的方法来实现自动更新时间的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文作者:苏生米沿

本文地址:http://blog.youkuaiyun.com/sushengmiyan/article/details/50326259

在使用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 TIMESTAMP 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

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


转载于:https://www.cnblogs.com/muyuge/p/6152456.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值