mysql 5.7.18 Can't change dir to引发的一系列问题(初始化data、改root密码)

本文介绍MySQL5.7在初始化过程中遇到的问题及解决办法,包括使用mysqld--initialize命令重置root密码并生成临时密码,以及如何通过SQL语句设置新的root密码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

c:\program files\mysql\Mysql Server 5.7\bin\mysqld –console
会报错:

mysqld: Can’t change dir to ‘c:\Program Files\MySQL\MySQL Server 5.7\data\’ (Errcode: 2 - No such file or directory)

StackOverflow上的解决办法:
在Mysql Server 5.7目录下建一个my.ini文件,内容如下:
[mysqld]
datadir=”X:\Your Directory Path and Name”

然后运行 mysqld –initialize

运行后,cmd窗口无任何提示,之后就悲剧了,用
mysql -u root -p
登录,始终提示密码不对。

经过查资料发现,–initialize会重置root密码,并生成一个随机的临时密码,下次登录需要用这个密码。
按照文档说,这个临时密码会显示在cmd窗口,但并没有。
原因在于当初初始化时应该用 –console选项来输出,在没有输出的情况下,这个密码会被记录到log中。于是开始看log存在哪里。
发现 mysql的log文件是二进制的,而且有很多log文件。

如果不查这个密码,还有一个解决办法,就是重置root密码,具体方法看文档吧,以前的 mysqld_safe的命令在5.7中似乎无效了。
现在的方法是在mysqld中使用 init_file选项。

先搁置,等解决后再更新,坑爹的 stackoverflow,呵呵。


最终解决办法:
新建一个txt文件,里面写上修改密码的SQL语句。
ALTER USER ‘root’@’localhost’ IDENTIFIED BY ‘MyNewPass’;
然后启动mysql服务器
mysqld –init-file=path:\initfileName
执行后,即可修改root密码。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值