mysql8运行上的数据库忘记了密码,于是搜了个解决办法按照步骤开始重置密码,但是在第二步运行mysqld --shared-memory --skip-grant-tables这行命令之后出现如图所示的错误,请问有大佬知道怎么解决吗???
2020-10-12T09:36:03.543175Z 0 [System] [MY-010116] [Server] C:\Program Files\MySQL\MySQL Server 8.0\bin\mysqld.exe (mysqld 8.0.21) starting as process 31732
2020-10-12T09:36:03.546849Z 0 [Warning] [MY-010091] [Server] Can't create test file C:\Program Files\MySQL\MySQL Server 8.0\data\mysqld_tmp_file_case_insensitive_test.lower-test
2020-10-12T09:36:03.546995Z 0 [Warning] [MY-010091] [Server] Can't create test file C:\Program Files\MySQL\MySQL Server 8.0\data\mysqld_tmp_file_case_insensitive_test.lower-test
2020-10-12T09:36:03.547392Z 0 [ERROR] [MY-013276] [Server] Failed to set datadir to 'C:\Program Files\MySQL\MySQL Server 8.0\data\' (OS errno: 2 - No such file or directory)
2020-10-12T09:36:03.568224Z 0 [ERROR] [MY-010119] [Server] Aborting
2020-10-12T09:36:03.568417Z 0 [System] [MY-010910] [Server] C:\Program Files\MySQL\MySQL Server 8.0\bin\mysqld.exe: Shutdown complete (mysqld 8.0.21) MySQL Community Server - GPL.
我的服务也是停止了的
以下为搜索的重置密码解决方法:
1.以管理员身份运行命令行,输入命令:net stop mysql,以停止MySQL服务
2.设置跳过验证,进入到mysql安装目录下的bin路径,在mysql/bin/目录下输入命令:“mysqld --shared-memory --skip-grant-tables”,(注意:一定要有–shared-memory,否则无法正常设置–skip-grant-tables并启动mysql服务),正常情况下,输完这条命令,该命令行窗口应该卡住不动。
3.无密码登录:新开一个CMD窗口,进入到mysql安装目录下的bin路径,无需重复启动mysql服务,在mysql/bin/目录下输入"mysql",此时应该可以连接成功,作者尝试的时候大多是卡在了这里,原因参照第二步。
4.重置root密码为空(注意:这里需先置为空密码,否则无法登陆):在第三步的cmd窗口中输入命令:update mysql.user set authentication_string='' where User = 'root'; 。
5.退出所有命令行,重新登陆数据库,(若显示服务未启动,需先启动MySQL服务,输入net start mysql)使用如下命令重新修改root密码:alter user 'root'@'localhost' identified by '123';。如出现问题可参见如下解决方法:https://blog.csdn.net/hunt_er/article/details/82901331
至此密码重置成功。