重裝了電腦,安裝了最新版的MySQL資料庫,結果Navicat連線Mysql報1251錯誤,sqlyog報2058錯誤,但window指令進入mysql,帳號密碼都是正確的。
在網路上查的是,出現這個原因是mysql8之前的版本中加密規則是mysql_native_password,而在mysql8之後,加密規則是caching_sha2_password。
解決問題方法有兩種,一種是升級navicat驅動程式;一種是把mysql使用者登入密碼加密規則還原成mysql_native_password。
相關推薦:《Navicat for mysql使用圖文教學》
我常用的是第二種方式:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password'; #修改加密规则 ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER; #更新一下用户的密码 FLUSH PRIVILEGES; #刷新权限
我看好多人拿著命令直接複製,這樣是不對的。
'root' 為你自己定義的用戶名
'localhost' 指的是用戶開放的IP,可以是'localhost'(僅本機訪問,相當於127.0.0.1) ,可以是具體的'*.*.*.*'(具體某一IP),也可以是'%' (所有IP均可訪問)
'password' 是你想使用的用戶密碼
這樣,問題就解決了。
以上是mysql與navicat建立連線出現1251錯誤怎麼解決的詳細內容。更多資訊請關注PHP中文網其他相關文章!