mysql datetime报错如何解决

网友投稿 571 2023-11-11

mysql datetime报错如何解决

今天小编给大家分享一下mysql datetime报错如何解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

mysql datetime报错如何解决

mysql datetime报错的解决办法:1、将datetime改成时间戳timestamp;2、将MySQL升级为高版本;3、执行“ALTER USER root@localhost IDENTIFIED BY root1 PASSWORD EXPIRE NEVER;”命令即可。

MySQL建表时datetime报错

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

CREATE TABLE stu (   id int(12NOT NULL AUTO_INCREMENT,   name varchar(150CHARACTER SET utf8 DEFAULT NULL,   age int(20),   createTime datetime DEFAULT CURRENT_TIMESTAMP,   updateTime datetimeDEFAULT CURRENT_TIMESTAMP,   PRIMARY KEY (id) ) ENGINE=InnoDBAUTO_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 WITHmysql_native_passwordBY root1#更新一下localhost的密码  FLUSH PRIVILEGES#刷新权限

以上就是“mysql datetime报错如何解决”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:如何删除mysql-bin
下一篇:mysql如何修改host
相关文章