mysql root用户强制登录_【MySQL】免安装版安装并启动成功后,无法登录,root帐户密码强制重设...

问题重现(仅限Windows环境)

MySQL> mysql -u root -p

Enter password:

ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

解决方案:

首先打开MySQL根目录下的配置文件 my.ini,在 [mysqld]这个条目下加入 skip-grant-tables 保存退出后。

然后重启一次MySQL服务:开始->运行->cmd(快捷键Win+R)

关闭mysql服务:输入 net stop mysql

开户mysql服务:输入 net start mysql

场景测试:

用CMD打开MySQL

开始->运行->cmd:输入mysql -u root -p,出现password:,这时直接回车,如果可以直接进入,不再出现ERROR 1045 (28000),说明已经进入数据库管理,但很多操作都会受限制,因为我们不能grant(没有权限)。

修改密码:

接下来,我们需要做的就是马上修改密码,并关闭MySQL空密码功能,毕竟是安全问题,按下面的流程走(红色部分为输入部分,粉红色的是执行后显示的代码不用输入):

第一步:进入mysql数据库

输入:mysql> use mysql;

显示:Database changed

第二步:给root用户设置新密码,蓝色部分自己输入:(这里提示一下,新版本的MySQL不知道从什么时候开始,把密码字段从原来的password换成了authentication_string)

输入:mysql> u pdate user set authentication_string=password("新密码") where user="root";

显示:Query OK, 1 rows affected (0.01 sec)

显示:Rows matched: 1 Changed: 1 Warnings: 0

第三步:刷新数据库

输入:mysql> flush privileges;

显示:Query OK, 0 rows affected (0.00 sec)

第四步:退出mysql

输入:mysql> quit

再回到 my.ini 这个文件,把我们刚才加入的"skip-grant-tables"这行删除,保存退出再重启mysql就可以了。

恶心的MySQL

使用新版本的同学是不是感觉以上方法行不通,不要怕,因为Mysql最近又增加了一道技术关,多走一步即可:

1862 - your password has expired to log in you must change it using a client that supports expired passwords

(密码已过期,请想尽一切办法更改,其实是为了防止你暴力修改。)

继续回到我们强行越权,修改密码后,继续使用老方法,将“password_expired(密码过期)”字段的值update改为“N”,然后继续操作,即可解决问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值