MySQL提示Access denied for user ''@'localhost'”的解决

时间:2020-12-13 19:19:07

记得那时因为没有网络,把root密码改错了写成了:
update user set password="122" where user="root";
之后mysql就开始不工作了。
#mysql -u root -p
#123
就会出现:ERROR 1045 (28000): Access denied for user ''@'localhost' (using password: NO)
只能这样:
#mysql -u root
mysql> use mysql
又出现了ERROR 1045 (28000): Access denied for user ''@'localhost' (using password: NO)
找了好久资料:
解决方法:

1.关闭mysql
   # service mysqld stop
2.屏蔽权限
   # mysqld_safe --skip-grant-table
   屏幕出现: Starting demo from .....
3.新开起一个终端输入
   # mysql -u root mysql
   mysql> UPDATE user SET Password=PASSWORD('newpassword') where USER='root';
   mysql> FLUSH PRIVILEGES;//记得要这句话,否则如果关闭先前的终端,又会出现原来的错误
   mysql> \q
这样就好了。