本文分析了mysql登錄報錯提示:ERROR 1045 (28000)的解決方法。分享給大家供大家參考,具體如下:
一、問題:
公司linux系統的mysql數據庫root用戶設置過密碼,但常常用命令'mysql -u root -p'登錄報錯,有時又能登錄。登錄報錯信息為:
[root@localhost ~]# mysql -u root -p Enter password: ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
二、原因:數據庫中存在空用戶所致
三、解決方法:
1、停用mysql服務:
# service mysql stop
2、輸入命令:
# mysqld_safe --user=mysql --skip-grant-tables --skip-networking &
3、登入數據庫:
# mysql -u root mysql
4、
mysql> use mysql;
5、
mysql> select user,host,password from user;
結果如下:
+------+-----------------------+----------+
| user | host | password |
+------+-----------------------+----------+
| root | % | mima |
| root | localhost.localdomain | mima |
| root | 127.0.0.1 | mima |
| | localhost | |
| | localhost.localdomain | |
+------+-----------------------+----------+
6、將上面查詢出來的空用戶刪除:
mysql> delete from user where user='';
7、退出數據庫:
mysql> quit
8、啟動mysql服務:
# service mysql start
9、重新用命令:
mysql -u root -p
登錄,OK!
更多關於MySQL相關內容感興趣的讀者可查看本站專題:《MySQL事務操作技巧匯總》、《MySQL存儲過程技巧大全》、《MySQL數據庫鎖相關技巧匯總》及《MySQL常用函數大匯總》
希望本文所述對大家MySQL數據庫計有所幫助。