【转载】mysql安装常见问题(系统找不到指定的文件、发生系统错误 1067 进程意外终止)

在安装mysql时老是会遇到这样那样的问题,每次从新安装都会花不少时间来排查。在 网上其实有不少相关的文章,但不少都只讲了方法,但没讲具体细节问题,致使没法解决问题。其实有时候知道问题的缘由,但老是由于一些细节问题没有注意到, 反复的尝试,浪费了不少时间。如今把我安装过程当中遇到的问题以及该注意的问题记录下来。mysql

环境:windows7sql

mysql版本:mysql-5.6.10-win32数据库

若是是默认安装,那么mysql会被安装到目录C:\Program Files\MySQL\MySQL Server 5.6中,特别要注意该目录,下面会说明缘由。windows

通常状况下,安装完mysql后,咱们都但愿直接能够链接使用,可是实际状况却不必定能这样顺利。安装完成后,直接在CMD中输入命令:google

C:\Windows\system32>mysql -uroot  编码

'mysql' 不是内部或外部命令,也不是可运行的程序或批处理文件。  spa

这是因为没有配置环境变量致使的,固然也能够先切换到mysql的安装目录再执行命令,不过那不是麻烦么。命令行

首先配置环境变量,把mysql所在目录的bin目录添加到path环境变量中(如何设置环境变量的具体操做省略,能够google一大把)。server

配置好环境变量后,该能够链接mysql了吧?试试看mysql -uroot,咦,怎么回事:rem

C:\Windows\system32>mysql -uroot  

ERROR 2003 (HY000): Can't connect to MySQL server on 'localhost' (10061)  

什么缘由?难道是服务没有启动,来启动服务看看:

C:\Windows\system32>net start mysql  

服务名无效。 

请键入 NET HELPMSG 2185 以得到更多的帮助。  

竟然服务名无效?打开windows服务一看,原来是安装完mysql后根本没有安装mysql服务,须要咱们手动安装。

安装mysql的服务很“简单”,在命令行中输入:

C:\Users\MikanMu>mysqld --install  

Install/Remove of the Service Denied!  

咦,怎么回事?这是因为没有权限形成的,须要在启动命令行时以管理员身份运行才行。关闭当前cmd窗口从新以管理员身份运行:

C:\Windows\system32>mysqld --install  

Service successfully installed.  

提示成功安装。很好,安装完服务后,启动起来看看:

C:\Windows\system32>net start mysql  

发生系统错误 2。 

系统找不到指定的文件。  

我了个去,这又是怎么回事?上网各类查,都说是须要在mysql配置文件中添加路径:

basedir=C:/Program Files/MySQL/MySQL Server 5.6
datadir=C:/Program Files/MySQL/MySQL Server 5.6/data

好吧,我试试,mysql-5.6.10-win32默认的配置文件是在C:/Program Files/MySQL/MySQL Server 5.6/my-default.ini,或者本身创建一个my.ini文件,在其中添加配置:

[mysqld]
basedir=C:/Program Files/MySQL/MySQL Server 5.6
datadir=C:/Program Files/MySQL/MySQL Server 5.6/data

注意:一、安装目录下因为权限的缘由不能直接创建文件,须要在其余地方创建并添加好相应的配置后,再拷贝到安装目录C:/Program Files/MySQL/MySQL Server 5.6下。

二、网上有的说配置中的目录分隔符必须是正斜杠‘/’,可是通过实验,‘/’、‘\’、‘\\’都没有问题,都是能够的。

三、basedir这个配置是mysql的安装目录,记住,必定是要配置到C:/Program Files/MySQL/MySQL Server 5.6这个目录,不能到C:/Program Files/MySQL就完了。

四、my.ini文件的编码必须是英文编码(如windows中的ANSI),不能是UTF-8或GBK等。

上面操做完成后(必定要注意细节),再来启动一下服务:

C:\Windows\system32>net start mysql  

发生系统错误 2。

系统找不到指定的文件。  

怎么仍是报这个错?难道不是因为配置的缘由?对,不是因为上面的配置的问题,但上面的配置添加后也没有错。那是什么缘由?

这里是最须要注意的地方,在安装mysql服务时,必定要切换到mysql安装目录的bin目录下,无论你是否配置环境变量,不然在安装完后启动服务仍是会报上面的错误。

切换到bin目录后,先删除前面安装的mysql服务(删除服务不必定要到bin目录),再从新在bin目录下安装mysql服务,而后启动:

C:\Windows\system32>cd ../..  

C:\>cd Program Files\MySQL\MySQL Server 5.6\bin

C:\Program Files\MySQL\MySQL Server 5.6\bin>mysqld --remove  

Service successfully removed.  

C:\Program Files\MySQL\MySQL Server 5.6\bin>mysqld --install  

Service successfully installed.   

C:\Program Files\MySQL\MySQL Server 5.6\bin>net start mysql  

MySQL 服务正在启动 .  

MySQL 服务已经启动成功。  


哇,终于成功了!!

如今来验证一下不须要添加my.ini文件,也是能够正常启动服务的,只要是在bin 目录下安装的服务就行。只须要中止mysql服务,把服务删除后,再把mysql安装目录下的my.ini文件删除掉,再从新安装服务,启动mysql服 务,看看能不能正常启动便可,实验证实,是能够正常启动的。

C:\Program Files\MySQL\MySQL Server 5.6\bin>net stop mysql  

MySQL 服务正在中止.  

MySQL 服务已成功中止。  

C:\Program Files\MySQL\MySQL Server 5.6\bin>mysqld --remove  

Service successfully removed.  

C:\Program Files\MySQL\MySQL Server 5.6\bin>mysqld --install  

Service successfully installed. 

C:\Program Files\MySQL\MySQL Server 5.6\bin>net start mysql  

MySQL 服务正在启动 .  

MySQL 服务已经启动成功。  

终于大功告成!!!看看能不能链接:

C:\Program Files\MySQL\MySQL Server 5.6\bin>mysql -uroot  

Welcome to the MySQL monitor.  Commands end with ; or \g.  

Your MySQL connection id is 3  

Server version: 5.6.10 MySQL Community Server (GPL) 

Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. 

Oracle is a registered trademark of Oracle Corporation and/or its  

affiliates. Other names may be trademarks of their respective  

owners. 

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. 

mysql>  

彻底没有问题。

另外,mysql默认的root用户是没有设置密码的,咱们能够修改root用户密码,方法以下:

一、直接在cmd命令行,不须要进入mysql

mysqladmin -u root password '新密码'  

二、在mysql中,必定要链接到某个数据库

mysql> use mysql  

Database changed  

mysql> update user set password=password('新密码') where user='root';  

Query OK, 3 rows affected (0.00 sec)  

Rows matched: 3  Changed: 3  Warnings: 0  

mysql> flush privileges;  

Query OK, 0 rows affected (0.00 sec)  

相关文章
相关标签/搜索