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

发布于:2021-10-27 09:46:57

c:program filesmysqlMysql Server 5.7inmysqld ?console
会报错:


mysqld: Can’t change dir to ‘c:Program FilesMySQLMySQL Server 5.7data’ (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密码。

相关推荐

最新更新

猜你喜欢