继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

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

好的丶文西
关注TA
已关注
手记 7
粉丝 5
获赞 6

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

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咯,嗯 ,学会搜索和了解各个工具版本特性的不同很重要啊。

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP