Navicat連線Mysql8.0.11出現1251錯誤
重灌了電腦,安裝了最新版的MySQL資料庫,結果Navicat連線Mysql報1251錯誤,sqlyog報2058錯誤,但是window命令進入mysql,賬號密碼都是正確的。
在網上查的是,出現這個原因是mysql8 之前的版本中加密規則是mysql_native_password,而在mysql8之後,加密規則是caching_sha2_password, 解決問題方法有兩種,一種是升級navicat驅動,一種是把mysql使用者登入密碼加密規則還原成mysql_native_password.
我常說的是第二種方式
ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER; #修改加密規則
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password'; #更新一下使用者的密碼
FLUSH PRIVILEGES; #重新整理許可權
--------------------------------------------------------------------------------------------------------------------------------------------------------
我看好多人拿著命令直接複製,這樣是不對的。
'root' 為你自己定義的使用者名稱
'localhost' 指的是使用者開放的IP,可以是'localhost'(僅本機訪問,相當於127.0.0.1),可以是具體的'*.*.*.*'(具體某一IP),也可以是 '%' (所有IP均可訪問)
'password' 是你想使用的使用者密碼
-----------------------------------------------------------------------------------------------------------------------------------------------------------
問題就解決了
JAVA 技術學習交流QQ群:71685345 (嚴禁廣告)