error 1044 (42000):access denied for user ''@'localhost' to database 'mysql'錯誤解決方案

        這幾天用空密碼登錄mysql後,然後修改mysql默認密碼,使用mysql表出現過這個問題,提示:ERROR 1044 (42000): Access denied for user ''@'localhost' to database 'mysql'。網上找了一些方法,終於搞定了。

       我用的是xampp集成的mysql,之前空密碼能登進去phpmyadmin,但怎麼也進不去phpmyadmin的系統表

       後來解決成功發現是因爲mysql數據庫的user表裏,存在用戶名爲空的賬戶即匿名賬戶,導致登錄的時候是雖然用的是root,但實際是匿名登錄的,通過錯誤提示裏的''@'localhost'可以看出來。我用方法一解決了問題,


方法一:
在my.ini的[mysqld]字段加入: 
skip-grant-tables 
重啓mysql服務,這時的mysql不需要密碼即可登錄數據庫
然後進入mysql 
mysql>use mysql;
mysql>update user set password=password('新密碼') WHERE User='root'; 
mysql>flush privileges;
運行之後最後去掉my.ini中的skip-grant-tables,重啓mysqld即可。


修改mysql密碼方法二:
不使用修改my.ini重啓服務的方法,通過非服務方式加skip-grant-tables運行mysql來修改mysql密碼
停止mysql服務
打開命令行窗口,在bin目錄下使用mysqld-nt.exe啓動,即在命令行窗口執行: mysqld-nt --skip-grant-tables
然後另外打開一個命令行窗口,登錄mysql,此時無需輸入mysql密碼即可進入。
按以上方法修改好密碼後,關閉命令行運行mysql的那個窗口,此時即關閉了mysql,如果發現mysql仍在運行的話可以結束掉對應進程來關閉。
啓動mysql服務。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章