windows10下同时安装mysql5.5,mysql5.7以及mysql8.0

首次安装mysql5.5,直接next,next安装即可。

下载免安装mysql5.7.32

官网下载确实有点慢,可以下载我上传到论坛的链接地址
mysql57安装包

解压后

在这里插入图片描述
默认没有my.ini,创建文件
把路径改成解压目录,端口改为3307

安装

使用管理员身份打开cmd,按照自己的目录使用mysqld执行如下命令,(遇到的坑进入到bin目录直接使用mysqld,如果之前版本的mysql的bin目录设置了path,用的是环境变量中的mysqld)

D:\wamp\mysql-5.7.32-winx64\bin\mysqld.exe install mysql5.7 --defaults-file="D:\wamp\mysql-5.7.32-winx64\my.ini"
# 初始化数据库,生成Data文件夹
D:\wamp\mysql-5.7.32-winx64\bin\mysqld.exe --initialize

如果安装错误,需要删除,可以使用命令: sc delete 服务名称

跳过密码

跳过密码登录
在这里插入图片描述
增加如上代码,重启mysql服务器
连接上数据库以后

use mysql;
update user set authentication_string=PASSWORD('root') where User='root';
update user set plugin ='mysql_native_password' where User='root';
flush privileges;

设置密码完成以后,在去掉 mysqld下面的 skip-grant-tables

启动

net start mysql5.7 或者直接使用系统自带的服务打开
net stop mysql5.7  停止

在这里插入图片描述
两个mysql互不影响,不用停用一个才能启动另外一个

安装mysql8.0

csdn资源下载地址
mysql8.0.23

需要注意的是,上面配置文件中的跳过密码已经不生效,我踩过的坑,(直接在初始化之前在my.ini中增加了 skip-grant-tables,导致启动 服务也不报错,一连接mysql服务就自动关闭了,纠结了一小会)。只要服务安装成功了,启动不了,大部分都是配置文件有错误

解决方法:
获取密码在初始化的时候通过添加–console来获取初始密码

D:\wamp\mysql-8.0.23\bin\mysqld.exe --initialize --console

输出:
D:\wamp\mysql-8.0.23>D:\wamp\mysql-8.0.23\bin\mysqld.exe --initialize --console
2021-03-01T09:49:27.534608Z 0 [System] [MY-013169] [Server] D:\wamp\mysql-8.0.23\bin\mysqld.exe (mysqld 8.0.23) initializing of server in progress as process 12804
2021-03-01T09:49:27.564082Z 1 [System] [MY-013576] [InnoDB] InnoDB initialization has started.
2021-03-01T09:49:33.976497Z 1 [System] [MY-013577] [InnoDB] InnoDB initialization has ended.
2021-03-01T09:49:45.438091Z 6 [Note] [MY-010454] [Server] A temporary password is generated for root@localhost: .fsSf)gYl9D&

我们使用这个密码只能在命令行连接,无法通过Navicat连接,如果想要使用Navicat连接还需要执行如下命令
#修改密码
# 修改密码规则
ALTER USER 'root'@'localhost' IDENTIFIED BY '上面获取到的密码' PASSWORD EXPIRE NEVER;
#修改密码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码';
#刷新权限
FLUSH PRIVILEGES;

Navicat报错页面

如果不修改密码会提示 密码已过期,使用cmd登录然后修改密码。有的也可能会出现如下报错
在这里插入图片描述
通过上面的修改密码可以解决。

还需要注意的是在mysql8.0中字符utf8编码问题,urf8已经被多次定义,需要具体指明使用哪一个,这里用的是 utf8mb4

附上my.ini

[mysqld]
port = 3310
basedir="D:/wamp/mysql-8.0.23"
datadir="D:/wamp/mysql-8.0.23/Data/"
max_connections=200
character-set-server=utf8mb4
default-storage-engine=INNODB
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 默认使用“mysql_native_password”插件认证
default_authentication_plugin=mysql_native_password

[mysql]
default-character-set=utf8mb4
[client]
#设置mysql客户端连接服务端时默认使用的端口
port=3310
default-character-set=utf8mb4

猜你喜欢

转载自blog.csdn.net/abc8125/article/details/114258377
今日推荐