1、到mysql官网(http://dev.mysql.com/downloads/mysql/)下载压缩包,我的是win7 64位的,根据自己的系统进行下载

window安装mysql5.7.11_ide

2、解压到自己的目录,我的是 E:\software\dataBase\mysql-5.7.11-winx64,并修改其目录下的my-default.ini文件

 

 # For advice on how to change settings please see

 # http://dev.mysql.com/doc/refman/5.7/en/server-configuration-defaults.html

 # *** DO NOT EDIT THIS FILE. It's a template which will be copied to the

 # *** default location during install, and will be replaced if you

 # *** upgrade to a newer version of MySQL.


 [client]
 default-character-set=utf8
 
 [mysqld]
 port=3306
 basedir =E:\software\dataBase\mysql-5.7.11-winx64
 datadir =E:\software\dataBase\mysql-5.7.11-winx64\data
 tmpdir =E:\software\dataBase\mysql-5.7.11-winx64\data
 socket =E:\software\dataBase\mysql-5.7.11-winx64\data\mysql.sock
 log-error =E:\software\dataBase\mysql-5.7.11-winx64\data\mysql_error.log
 
 #server_id = 2
 #skip-locking

 max_connections=100
 table_open_cache=256
 query_cache_size=1M
 

 tmp_table_size=32M
 thread_cache_size=8


 innodb_data_home_dir=E:\software\dataBase\mysql-5.7.11-winx64\data
 innodb_flush_log_at_trx_commit =1
 innodb_log_buffer_size=128M
 innodb_buffer_pool_size=128M
 innodb_log_file_size=10M
 innodb_thread_concurrency=16
 innodb-autoextend-increment=1000
 join_buffer_size = 128M
 sort_buffer_size = 32M
 read_rnd_buffer_size = 32M
 max_allowed_packet = 32M
 explicit_defaults_for_timestamp=true
 sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"
 #sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

 

3、以管理员身份运行cmd  ,cd 到 E:\software\dataBase\mysql-5.7.11-winx64\bin目录

4、执行 mysqld.exe --initialize --user=mysql 命令

5、执行 mysqld.exe -install  安装服务命令

6、执行 net start mysql 检查是否安装成功

 

7、执行mysql mysql -uroot -p 进入mysql

8、输入密码,第一次密码可以从下面文件中找到

window安装mysql5.7.11_ide_02

输入密码,进入如下界面

window安装mysql5.7.11_sed_03

9、执行  ALTER USER 'root'@'localhost' IDENTIFIED WITH MYSQL_NATIVE_PASSWORD BY '123456';  命令 重新设置密码

 

ALTER USER 'root'@'localhost' IDENTIFIED WITH MYSQL_NATIVE_PASSWORD BY '123456';

 

问题汇总:在之前的开启服务过程中失败了很多次,也是从网上各种找问题原因,下面我就介绍一下我遇到的问题,仅供大家参考,如果还有其它问题欢迎提出。

Q1:第一次安装的时候,按照网上的方法创建了my.ini目录,当时的文件内容如下:

[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8 
[mysqld]
#设置3306端口
port = 3306 
# 设置mysql的安装目录
basedir=D:\sw\mysql-5.7.12-winx64
# 设置mysql数据库的数据的存放目录
datadir=D:\sw\mysql-5.7.12-winx64\data
# 允许最大连接数
max_connections=200
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB

看到这里和我第二步中的my.ini文件内容的区别了么?没错,basedir和datadir的路径写法不一样,“\”和"\\"的区别,这个导致的问题后面会说

然后进入bin目录下,输入mysqld -install,会提示安装成功,继续启动服务,执行net start mysql,会发现服务启动不了,报一下错误:服务正在启动,服务无法启动,服务没有报告任何错误,请键入NET HELPMSG 3534,于是去搜关键字,发现很多人说是缺少data目录,卸载安装5.6.X的就可以,于是看了一下自己的解压文件发现确实没有,但是没想去卸载安装,因为安装别的版本的话这个问题还是存在,下次碰到了还是解决不了啊,如果时版本的问题,官网发布了,那么多人安装,有问题肯定能在网上找到的,于是继续找问题和答案。

继续百度找mysql如何创建data文件,看到了网友的方法:1在压缩文件下创建data空文件夹2创建my.ini文件,内容同Q1,3初始化data文件夹,执行mysqld  --initialize-inscure (不设置root密码,建议使用),这时候问题来了:

D:\sw\mysql-5.7.12-winx64\bin>mysqld –initialize-insecure
mysqld: Can't change dir to 'D: w\mysql-5.7.12-winx64\data\' (Errcode: 2 - No su
ch file or directory)
2016-04-12T02:31:24.980888Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is
 deprecated. Please use --explicit_defaults_for_timestamp server option (see doc
umentation for more details).
2016-04-12T02:31:24.980888Z 0 [Warning] Insecure configuration for --secure-file
-priv: Current value does not restrict location of generated files. Consider set
ting it to a valid, non-empty path.
2016-04-12T02:31:24.980888Z 0 [Note] mysqld (mysqld 5.7.12) starting as process
10788 ...
2016-04-12T02:31:24.981888Z 0 [ERROR] Can't find error-message file 'D:\sw\mysql
-5.7.12-winx64\bin\ w\mysql-5.7.12-winx64\share\errmsg.sys'. Check error-message
 file location and 'lc-messages-dir' configuration directive.
2016-04-12T02:31:24.982888Z 0 [Warning] Can't create test file D: w\mysql-5.7.12
-winx64\data\PC-20150316207.lower-test
2016-04-12T02:31:24.982888Z 0 [Warning] Can't create test file D: w\mysql-5.7.12
-winx64\data\PC-20150316207.lower-test
2016-04-12T02:31:24.983888Z 0 [ERROR] failed to set datadir to D: w\mysql-5.7.12
-winx64\data\
2016-04-12T02:31:24.984888Z 0 [ERROR] Aborting


2016-04-12T02:31:24.985888Z 0 [Note] Binlog end
2016-04-12T02:31:24.986888Z 0 [Note]

执行完后报这个错误,看这个提示Can't change dir to 'D: w\mysql-5.7.12-winx64\data\' (Errcode: 2 - No su
ch file or directory),好像是说当前目录不存在,而且诡异的是 'D: w\mysql-5.7.12-winx64\data\' 这个东西,data我明明是放在“D: sw\mysql-5.7.12-winx64\data\”下面的,s呢?难道是因为sw文件夹的问题?然后我试着新建一个MySql文件夹,将压缩包重新解压到该目录下,继续上面的步骤,会发现执行mysqld  --initialize-inscure通过了,而且在data目录下生成了一堆文件:

window安装mysql5.7.11_mysql_04

心中窃喜,这下总该成功了吧,然后执行mysqld -install,安装成功,激动人心的时刻来了,启动服务,执行net start mysql,然而事与愿违:还是报了服务正在启动,服务无法启动,服务没有报告任何错误,请键入NET HELPMSG 3534

心中一阵沮丧,什么情况啊……

问题还是没解决啊,继续找答案,发现有网友说data目录下是不是没有mysql文件夹,于是我去对照了一下5.6.17的发现他的data目录下有三个文件夹和一堆文件:

window安装mysql5.7.11_sed_05

按照网友的说法,我将mysql整个文件拷贝到我的data目录下,继续执行net start mysql,终于成功启动了服务。

服务终于启动了,总是觉得有点不完美,我的data目录为什么跟别人的不一样,为什么网上那么多人执行mysqld  --initialize-inscure的时候成功了,没有问题,而我的总是不行呢?说明这个问题还是存在隐患,继续找答案,关键在在于:

mysqld: Can't change dir to 'D: w\mysql-5.7.12-winx64\data\' (Errcode: 2 - No su
ch file or directory)

这个错误应该还是没有解决的,扒拉了半天,有网友提示了my.ini中basedir和datadir的问题,"\"应该用"\\"代替,于是重新解压在"D:\sw"(我想验证是不是目录问题所以重新解压到这个下面验证)下面,修改my.ini,重新按本文开始的步骤执行,完美通过,此时来看data目录会发现该有的文件都有了:

window安装mysql5.7.11_ide_06

The service already exists!
The current server installed: E:\wnmp\mysql-5.7.14\bin\mysqld MySQL

 

特别提醒,如果出现

D:\MySQL\mysql-5.7.14-winx64\bin>mysqld install
The service already exists!
The current server installed: D:\mysql-5.7.14-winx64\bin\mysqld MySQL

 

使用语句

sc delete MySQL

学习时的痛苦是暂时的 未学到的痛苦是终生的