Mysql运行sql报错:Invalid ON UPDATE clause for 'createTime' column的解决办法
从高版本的mysql导出SQL文件,然后运行SQL文件到低版本的mysql:
如果表中存在datetime字段,如下:
运行SQL文件时,将出现如下错误:
[Err] 1294 - Invalid ON UPDATE clause for 'createTime' column
解决办法:将`createTime` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,语句中的ON UPDATE CURRENT_TIMESTAMP去掉即可。
原因:高版本的mysql转储的sql文件中,datetime字段都如上图所示,但是低版本的mysql不认识ON UPDATE CURRENT_TIMESTAMP,所以报错。
举一反三:
1:如果低版本的mysql转储的sql文件,在高版本的mysql中运行是没有问题的。
2:承接1,高版本的mysql再转储出来的sql文件中,datetime字段也是不带ON UPDATE CURRENT_TIMESTAMP的(即在低版本的MySQL中运行是没问题的)。
3:承接1,如果在高版本的mysql中增加了datetime字段,则再转储出来的sql文件中,datetime字段是带ON UPDATE CURRENT_TIMESTAMP的(即在低版本的MySQL中运行是有问题的)。
Copyright ? 2013-2024 8a.hk All Rights Reserved. 八艾云 版权所有 中山市八艾云计算有限公司 粤ICP备14095776号 粤公网安备 44200002445359号
增值电信业务经营许可证编号:B1-20222012
代理域名注册服务机构:西部数码