1、下载mysql-5.7.17-winx64.zip
2、解压
解压到想安装的目录下,我的是D:\mysql-5.7.17-winx64
3、配置my.ini
在D:\mysql-5.7.17-winx64目录下新建my.ini文件,输入以下配置代码:
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[mysqld]
sql-mode=""
#设置3306端口
port = 3306
# 设置mysql的安装目录
basedir=D:\Mysql\mysql-5.7.17-winx64
# 设置mysql数据库的数据的存放目录
datadir=D:\Mysql\mysql-5.7.17-winx64\data
# 允许最大连接数
max_connections=200
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
4、安装
以管理员身份运行cmd,执行以下命令:
mysqld -install mysql
注:服务名默认为mysql,若无需要,建议不更改
5、初始化
mysqld --initialize-insecure
注:–initialize有两个-,后边没有空格
初始化后,D:\mysql-5.7.17-winx64目录下回出现data目录
6、启动服务
net start mysql
7、登录mysql,修改密码
默认没有密码
搞定!
二、卸载
1、关闭服务
以管理员身份运行cmd,执行以下命令:
net stop mysql
2、卸载
mysqld -remove mysql
3、删除文件
4、删除注册表信息
清除注册表中的该MySQL服务,有几个地方:
a、HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Eventlog\Application\MySQL 目录删除
b、HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Services\Eventlog\Application\MySQL 目录删除
c、HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Eventlog\Application\MySQL 目录删除
注册表中的ControlSet001、ControlSet002不一定是001和002,可能是ControlSet005、006之类,删除的时候都删除就可以 。
三、常见问题
1、data文件错误
原因:一般初始化之前已存在data文件就会出现这个错误,或者data文件缺少了某些文件
解决:先执行mysqld -remove,然后把data文件删除,如果删除不了重启一下就可以了,之后重新进行安装就没问题了。如果想保留之前的data文件,可以先把data文件拷贝到其他地方,安装好之后再将原data文件中多的文件拷贝进去就行了,具体参考我的另一篇文章mysql通过拷贝数据文件方式迁移数据库
2、密码错误
原因1:使用mysqld –initialize方法安装会生成一个随机字符串组成的密码,这个密码在错误日志D:\mysql-5.7.13-winx64\data\green.err(green是用户名)可以找到。
原因2:忘记密码
解决:如果忘记密码或找不到随机密码,可以通过以下方法跳过权限修改密码
以管理员身份运行cmd,执行以下命令:
net stop mysql//关闭服务
mysqld --skip-grant-tables;//设置mysql登录--skip-grant-tables模式
打开一个新的cmd
mysql//直接登录mysql
update mysql.user set authentication_string=password('123456') where user='root' and Host = 'localhost';//修改密码
//特别提醒注意的一点是,新版的mysql数据库下的user表中已经没有Password字段了,而是将加密后的用户密码存储于authentication_string字段
flush privileges;//刷新权限,退出--skip-grant-tables模式,很重要!
重启电脑,然后mysql就可以连接了
但是此时操作似乎功能不完全,还要在登录状态下修改一次密码
alter user 'root'@'localhost' identified by '123456';
还可以这样:
set password for 'root'@'localhost'=password('123456');
或这样:
set password=password('123456');
mysql error 3065的问题:
最近自己做了个小项目,把项目往linux迁移的时候出现了个小问题,登陆之后的列表页面不显示,刚开始以为是代码问题,代码改了一遍又一遍,后来在liunx的mysql测试sql的时候有一条sql报错了,但是我在本地测试是没问题的,看了下mysql报的是error 3065,原来是linux的mysql和我本地的mysql版本不一样。。按照网上的方法成功解决:
1.修改mysql的配置文件并保存:vim /etc/my.cnf
2.mysqld 字段下添加一行:sql-mode=""
3.重启mysql:service mysqld restart (那篇文章的重启方法不行,自己找了一个可以用的)
然后启动项目,OK!