网上大部分的方法都是通过在My.ini或是My_default.ini中添加–skip-grant-tables的方法来实现跳过Mysql密码来连接数据库,并更改密码,然而都没有成功。

以下命令行代码均在管理员模式下操作

第一步:关闭Mysql服务

首先,确保自己已经关闭了Mysql的服务

  1. cd "d:\Program Files\mysql8\bin"(此处输入自己的Mysql安装地址)
  2. net stop mysql

Mysql 8.0以上重置初始密码的方法(Win10) - 图1

第二步:跳过Mysql密码验证

关闭Mysql服务之后,继续在 d:\Program Files\mysql8\bin 目录下进行操作,输入命令

  1. mysqld --console --skip-grant-tables --shared-memory

在输入这行代码之后,我们就已经成功跳过Mysql的密码登录了
Mysql 8.0以上重置初始密码的方法(Win10) - 图2

第三步:无密码方式进入Mysql

在上述步骤之后,再打开一个管理员模式运行的cmd.exe。
进入 mysql 下的 bin 目录后,直接登录mysql。
在命令行中输入以下代码

  1. cd "d:\Program Files\mysql8\bin"(此处输入自己的Mysql安装地址)
  2. mysql -u root -p

此时会显示让你输入密码,直接回车,就可以成功连接Mysql

第四步:将登陆密码设置为空

输入代码,将密码设置为空(此时还不能直接修改密码,必须先设置为空,否则会报错)。

  1. use mysql; (使用mysql数据表)
  2. update user set authentication_string='' where user='root';(将密码置为空)
  3. quit; (然后退出Mysql)

Mysql 8.0以上重置初始密码的方法(Win10) - 图3

第五步:更改自己的登陆密码

这里分为两个部分

  1. 关闭第一个cmd窗口(一定要关闭!)
  2. 在第二个窗口中输入代码
    1. net stop mysql (关闭mysql服务, 虽然会显示没有开启服务,但是以防万一)
    2. net start mysql (再打开mysql服务)
    3. mysql -u root -p
    (此处会显示输入密码,直接回车就好了,第四步我们已经将他置为空了)
    1. ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码';(更改密码)
    Mysql 8.0以上重置初始密码的方法(Win10) - 图4

    最后一步:验证密码是否修改成功

    1. quit(退出mysql
    2. mysql -u root -p
    3. (输入新密码,再次登录)