加入收藏 | 设为首页 | 会员中心 | 我要投稿 银川站长网 (https://www.0951zz.com/)- 云通信、基础存储、云上网络、机器学习、视觉智能!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

mysql datetime报错如何处理

发布时间:2023-04-06 13:07:23 所属栏目:MySql教程 来源:
导读:MySQL建表时datetime报错在student数据库中创建stu表,执行以下建表语句CREATE TABLE stu ( id int(12) NOT NULL AUTO_INCREMENT, name varchar(150) CHARACTER SET utf8 DEFAULT NULL, age int(20), createTime

MySQL建表时datetime报错

在student数据库中创建stu表,执行以下建表语句

CREATE TABLE stu (

  id int(12) NOT NULL AUTO_INCREMENT,

  name varchar(150) CHARACTER SET utf8 DEFAULT NULL,

  age int(20),

  createTime datetime DEFAULT CURRENT_TIMESTAMP,

  updateTime datetime DEFAULT CURRENT_TIMESTAMP,

  PRIMARY KEY (id)

) ENGINE=InnoDB AUTO_INCREMENT=16 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

报 Invalid default value for 'createTime'错,上网百度说是MySQL5.6之后才支持datetime设置默认值,然后将datetime改成时间戳timestamp。

再次执行时,报 Incorrect table definition; there can be only oneTIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT or ON UPDATEclause错,这个是因为为多个timestamp设置current_timestamp。

最好的解决办法是将MySQL升级为高版本,比如说5.7,8.0,我从官网下载MySQL8.0版后,安装完成,使用Navicat连接MySQL报2059的错。据说是因为8.0和之前版本的加密规则不一致导致的。

使用命令行进入MySQL界面,输入下面的命令即可

#注意:root1是连接数据库的密码,可以更改为自己想用的密码

ALTER USER 'root'@'localhost' IDENTIFIED BY 'root1' PASSWORD EXPIRE NEVER; #修改数据库的加密规则 

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'root1'; #更新一下localhost的密码 

FLUSH PRIVILEGES; #刷新权限

以上就是“mysql datetime报错如何解决”这篇文章的所有内容,感谢各位的阅读

(编辑:银川站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!