【mysql 登录故障】ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using passwor:yes)
前言:这是一个比较常见的问题,但是触发原因众说纷纭,目前我还没能够找到最信服的原因。网上比较多的说法是
a.因为多次密码输错的原因。
b.因为mysql服务没正常启动。
c.因为data所在的盘空间不足。(这个比较罕见。)
1.重置密码的第一步就是跳过MySQL的密码认证过程,方法如下:
root 00:22:26~$ vim /etc/my.cnf (注:windows下修改的是my.ini)
2.在文档内搜索mysqld定位到[mysqld]文本段:
在[mysqld]后面任意一行添加“skip-grant-tables”用来跳过密码验证的过程,如下图所示:
保存文档并退出
3.接下来我们需要重启MySQL:
service mysqld restart (如此不好使自行百度其它方法重启)
4.重启之后输入mysql即可进入mysql。
5.接下来就是用sql来修改root的密码
mysql> update user set password=password("你的新密码") where user="root"; mysql> flush privileges; mysql> quit
到这里root账户就已经重置成新的密码了。
5.编辑my.cnf,去掉刚才添加的内容,然后重启MySQL。大功告成!