解決MYSQL ERROR 1045 (28000): Access denied for user (using password: YES)問題
開場白:解決LINUX問題是一種樂趣,當然,能遇到問題就是上天賜的享受幸福的機會。
這次使用的是Mandriva2008spring。
因為要搞一個項目,所以需要安裝MySql,以往安裝MySql都是非常順利的,尤其MySql提供的rmp包,只需雙擊下就可以搞定~但不知道什么時候,MYSQL ERROR 1045 (28000): Access denied for user (using password: YES),這個拒絕訪問問題變得非常廣泛。
百度了一下,沒有現成的解決方法,唯有找出其問題所在了。
解決問題思路:
第一步,先使用跳過受權表訪問,命令如下:mysqld_safe --user=mysql --skip-grant-tables --skip-networking & (當然,在這之前,先停止mysql服務的運行)。
第二步,mysql -uroot mysql 登錄mysql。
第三步,訪問mysql數據庫下的user表。在我的機器上,mysql> select * from user; 得到的,竟然是
Empty set (0.00 sec)。這說明了,我的mysql沒有任何可以訪問的用戶。知道了這問題所在,解決起來就簡單了。另外一種情況有可能也存在該用戶但是權限
或密碼方面設置有問題也有可能報上面的錯誤,因此最好的辦法先刪掉該記錄再重新添加該用戶的紀錄。
第四步,mysql> INSERT INTO user(host, user, password, select_priv, insert_priv, update_priv) VALUES ('localhost', 'username', PASSWORD(‘yourpassword’), 'Y', 'Y','Y');
Query OK, 1 row affected, 3 warnings (0.00 sec)
返回成功,沒問題。嘿嘿~~~就這么簡單。
第五步,測試,再重啟下mysql服務,正常登錄,成功?。。?br />
提示:mysql系統中的mysql數據庫,存儲的是系統數據,像這里的user表存儲的是用戶信息及其訪問權限,還有其他,例如你要新建一個數據庫mydb,這數據庫有用戶me管理的話,mysql數據庫里面的db表就會存儲相關信息