为了账号安全,请及时绑定邮箱和手机立即绑定

坑人的MYSQL 5.5,不支持字段类型为datetime且默认值为NOW()的建表语句

标签:
MySQL

复制过来的建表语句如下:

DROP TABLE IF EXISTS `sys_role_user`;
CREATE TABLE `sys_role_user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `role_id` int(11) NOT NULL COMMENT '角色id',
  `user_id` int(11) NOT NULL COMMENT '用户id',
  `operator` varchar(20) NOT NULL DEFAULT '' COMMENT '操作者',
  `operate_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '最后一次更新的时间',
  `operate_ip` varchar(20) NOT NULL DEFAULT '' COMMENT '最后一次更新者的ip地址',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=18 DEFAULT CHARSET=utf8mb4;

执行后,报错了:
图片描述
然后搜错误编码Err-1067····,清一色的修改sql_model,屡试都不行,后来想到 会不会是版本的原因,因为貌似之前也遇到过mysql版本造成的datatime一些错误····,然后直接搜“mysql5.5datetime类型不能设默认值”,很好,好像找到靠谱点的解决方案了·····
图片描述
一般选第一篇进去咯~
里面是这样说的:
主要是在5.5版本不支持字段类型为datetime且默认值为NOW()的字段
同时,也不支持CURRENT_TIMESTAMP

然后 就只有改成timestamp咯,嗯 ,学会搜索和了解各个工具版本特性的不同很重要啊。

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
JAVA开发工程师
手记
粉丝
5
获赞与收藏
6

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消