MySQL密碼正確卻無法本地登錄的解決方法
MySQL root密碼正確,卻怎么也無法從本地登錄MySQL,提示
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
這里后來經(jīng)高人指點才發(fā)現(xiàn)mysql庫中的user表缺少一個root指向host:localhost的數(shù)據(jù)項,只有一個root指向host:主機名的數(shù)據(jù)項,故怎么也無法利用root賬戶登錄MySQL。
總結(jié)一點就是root賬戶缺失了訪問localhost主機的賬戶信息,導致無法本地登錄。
模擬測試如下:

那有什么辦法恢復root登錄呢?
這里記錄一下今天遇到的糾結(jié)事情:
首先kill掉MySQL進程然后在啟動mysql的參數(shù)中加入
會發(fā)現(xiàn)這時無密碼就可以登錄mysql了。

當然我們還必須修復root賬戶丟失的數(shù)據(jù)項。
這里有兩種解決方案:
第一種是因為root賬戶初始的時候有3條記錄,包含root對應localhost,hostname,127.0.0.1三條賬戶數(shù)據(jù),我們可以update host為其他兩項中一項為localhost即可。
第二種是直接insert一條記錄,host為localhost即可
總結(jié)一下:即使root的host包含了主機名,127.0.0.1那么依然是無法正常登錄的,這里必須要有l(wèi)ocalhost的host才行。
相關(guān)文章
MySQL數(shù)據(jù)時區(qū)問題以及datetime和timestamp類型存儲的差異
這篇文章主要介紹了MySQL數(shù)據(jù)時區(qū)問題以及datetime和timestamp類型存儲的差異,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-11-11
SQL中row_number()?over(partition?by)的用法說明
這篇文章主要介紹了SQL中row_number()?over(partition?by)的用法說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07
如何修改mysql數(shù)據(jù)庫的max_allowed_packet參數(shù)
本篇文章是對修改mysql數(shù)據(jù)庫的max_allowed_packet參數(shù)進行了詳細的分析介紹,需要的朋友參考下2013-06-06
簡析mysql字符集導致恢復數(shù)據(jù)庫報錯問題
這篇文章主要介紹了簡析mysql字符集導致恢復數(shù)據(jù)庫報錯問題,具有一定參考價值,需要的朋友可以了解。2017-10-10
CentOS 7 安裝Percona Server+Mysql
這篇文章主要介紹了CentOS 7 安裝Percona Server+Mysql的相關(guān)資料,需要的朋友可以參考下2018-11-11

