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

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密码。

你可能感兴趣的:(杂项)