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