首次安装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