[Err] 1294 - Invalid ON UPDATE clause for ‘comment_time‘ column

针对MySQL低版本导致无法自动更新记录日期的问题,本文提供了一种无需卸载重装的解决方案:通过创建触发器,在用户表更新前自动设置当前时间作为记录日期。

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

mysql版本低原因导致。不想卸载重装的方法:创建游标

改前:

CREATE TABLE `user`  (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '用户登录表',
  `account` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户账户',
  `password` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户密码',
  `email` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '邮箱',
  `phone` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户电话',
  `user_name` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户昵称',
  `sex` int(2) NULL DEFAULT 1 COMMENT '用户性别(0女,1男)',
  `birthday` datetime NULL DEFAULT NULL COMMENT '出生日期',
  `record_date` datetime NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '注册日期',
  `is_vip` int(2) NULL DEFAULT 0 COMMENT '是否VIP用户',
  `role_id` int(11) NULL DEFAULT 0 COMMENT '权限ID(0普通用户,1管理员)',
  PRIMARY KEY  USING BTREE (`id`)
) ENGINE = InnoDB AUTO_INCREMENT = 13 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

改后:

CREATE TABLE `user`  (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '用户登录表',
  `account` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户账户',
  `password` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户密码',
  `email` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '邮箱',
  `phone` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户电话',
  `user_name` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户昵称',
  `sex` int(2) NULL DEFAULT 1 COMMENT '用户性别(0女,1男)',
  `birthday` datetime NULL DEFAULT NULL COMMENT '出生日期',
  `record_date` datetime NULL DEFAULT NULL    COMMENT '注册日期',
  `is_vip` int(2) NULL DEFAULT 0 COMMENT '是否VIP用户',
  `role_id` int(11) NULL DEFAULT 0 COMMENT '权限ID(0普通用户,1管理员)',
  PRIMARY KEY  USING BTREE (`id`)
) ENGINE = InnoDB AUTO_INCREMENT = 13 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
DELIMITER //
CREATE TRIGGER `user` BEFORE UPDATE ON `user` 
 FOR EACH ROW SET NEW.`record_date` = NOW()
//
DELIMITER ;

总结:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值