1. 程式人生 > >Springboot連線MySQL8.0出現的問題

Springboot連線MySQL8.0出現的問題

以前用的是5.7版本的MySQL,在學習實踐Springboot的時候順帶升級了一下8.0,遇到了一些坑,在這記錄一下,有碰到同類問題的童鞋需要自取。

使用 navicat連線發現報錯1251- Client does not support authentication protocol 錯誤

這個筆者查詢資料發現是新版本的加密規則變了,在mysql8之後,加密規則是caching_sha2_password,之前的是mysql_native_password,所以解決辦法要不就是升級navicat要不就是修改加密規則。

這裡修改加密規則:

1.進入MySQL的bin目錄開啟CMD,然後輸入mysql -u root -p,輸入密碼

2.然後輸入

ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER; #修改加密規則

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '輸入你的密碼'; #更新一下使用者的密碼 

FLUSH PRIVILEGES; #重新整理許可權

Mysql8.0)Could not create connection to database server - java mysql connector

這是因為沒有更新驅動的原因,在Maven中更新下mysql-connector的版本

<!-- MySQL 連線驅動依賴 -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.11</version>
</dependency>

<!--properties檔案中更改driver-->
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

使用JDBC連線MySql時出現:The server time zone value '�й���׼ʱ��' is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration 

這是MyBatis時區錯誤,在連結庫的url中加serverTimezone=UTC

spring.datasource.url=jdbc:mysql://localhost:3306/axin?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC