Mysql数据库从5.6.28版本升到8.0.11版本部署项目时遇到的问题及解决方法
Posted yigeqiu
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mysql数据库从5.6.28版本升到8.0.11版本部署项目时遇到的问题及解决方法相关的知识,希望对你有一定的参考价值。
来源:https://www.jb51.net/article/139923.htm
mysql数据库版本从5.6.28升到8.0.11过程中部署项目时遇到的问题和解决方法,具体介绍如下所示:
首先这个项目用到了hibernate4.2.0,链接mysql5.6.28没问题,换到8.0.11,启动报错
1.Caused by: org.hibernate.HibernateException: Connection cannot be null when ‘hibernate.dialect‘ not set
报错就配置吧
启动项目不报错了,但是访问项目报错了
2.访问报错com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Client does not support authentication protocol requested by server; consider upgrading MySQL client
原因是:安装mysql8过程中的Authentication Method这一配置过程,基于不同的加密方式,如果选择第一种强加密,就会出现我之前描述的现象;应该选第二种验证方式,即保留旧有的加密方式。
所以解决办法有3种:
1.重新装mysql8,注意选择第二种,保留旧的加密方式。
2.MySQL Installer可以直接修改Authentication Method配置
3.直接执行语句修改
1
2
3
4
|
mysql> ALTER USER ‘root‘ @ ‘localhost‘ IDENTIFIED WITH mysql_native_password BY ‘123456‘ ; Query OK, 0 rows affected (0.11 sec) mysql> FLUSH PRIVILEGES ; Query OK, 0 rows affected (0.01 sec) |
注:root是用户名,localhost是特指本机,mysql_native_password是旧的密码验证机制,123456是密码
以上是关于Mysql数据库从5.6.28版本升到8.0.11版本部署项目时遇到的问题及解决方法的主要内容,如果未能解决你的问题,请参考以下文章
Mysql 8.0.11版本,安装成功,使用Navicat连接失败。