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
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

闲不住的程序员

您的打赏将是我最大的鼓励感谢

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值