mysql 同步时间_MYSQL 更新时间自己主动同步与创建时间默认值共存问题

本文作者:苏生米沿

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

Center

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

再看5.7版本号的

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值