Springboot連線MySQL8.0出現的問題
阿新 • • 發佈:2018-12-15
以前用的是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