本文分析了mysql登錄報錯提示:ERROR 1045 (28000)的解決方法。分享給大家供大家參考,具體如下:
一、問題:
公司linux系統(tǒng)的mysql數(shù)據(jù)庫root用戶設置過密碼,但常常用命令'mysql -u root -p'登錄報錯,有時又能登錄。登錄報錯信息為:
1
2
3
|
[root@localhost ~] # mysql -u root -p Enter password: ERROR 1045 (28000): Access denied for user 'root' @ 'localhost' (using password: YES) |
二、原因:數(shù)據(jù)庫中存在空用戶所致
三、解決方法:
1、停用mysql服務:
1
|
# service mysql stop |
2、輸入命令:
1
|
# mysqld_safe --user=mysql --skip-grant-tables --skip-networking & |
3、登入數(shù)據(jù)庫:
1
|
# mysql -u root mysql |
4、
1
|
mysql> use mysql; |
5、
1
|
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、將上面查詢出來的空用戶刪除:
1
|
mysql> delete from user where user= '' ; |
7、退出數(shù)據(jù)庫:
1
|
mysql> quit |
8、啟動mysql服務:
1
|
# service mysql start |
9、重新用命令:
1
|
mysql -u root -p |
登錄,OK!
希望本文所述對大家MySQL數(shù)據(jù)庫計有所幫助。