青训营项目记录2:windows环境安装Mysql的踩坑记录 | 青训营笔记

41 阅读3分钟

这是我参与「第五届青训营 」伴学笔记创作活动的第 10 天

后端青训营需要使用mysql作为数据库存储,因此介绍windows环境下安装mysql的步骤和遇到的坑。

确认本地是否已经安装Mysql

  1. 按【win+r】快捷键打开运行;
  2. 输入services.msc,点击【确定】;
  3. 在打开的服务列表中查找mysql服务,如果没有mysql服务,说明本机没有安装mysql,反之,说明本机安装了mysql服务。

image.png

下载Mysql安装包

点击mysql安装包下载链接:dev.mysql.com/downloads/m… 选择window版本,点击下载按钮,如下所示:

1674646599246.png

image.png

添加配置文件并安装Mysql

  1. 下载好mysql安装包后,将其解压到指定目录,并记下解压的目录,后续用于环境变量配置

image.png

  1. 在bin目录同级下创建一个文件,命名为my.ini
  2. 编辑my.ini文件,文件内容如下。这里注意文件路径一定要用双斜杠,我一开始照着某些教程用的单斜杠,结果后续初始化mysql服务时报错:[ERROR] [MY-010338] [Server] Can't find error-message file
[mysqld]
# 设置3306端口
port=3306
# 设置mysql的安装目录 ---windows环境一定要用双斜杠,否则报错----
basedir=D:\\software\\mysql-8.0.32-winx64
# 设置mysql数据库的数据的存放目录
datadir=D:\\software\\mysql-8.0.32-winx64\\data
# 允许最大连接数
max_connections=200
# 允许连接失败的次数。
max_connect_errors=10
# 服务端使用的字符集默认为utf8
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 默认使用“mysql_native_password”插件认证
#mysql_native_password
default_authentication_plugin=mysql_native_password
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[client]
# 设置mysql客户端连接服务端时默认使用的端口
port=3306
default-character-set=utf8
  1. 打开cmd进入mysql的bin文件下,依次执行命令:
# 安装mysql 安装完成后Mysql会有一个随机密码
mysqld --initialize --console
# 安装mysql服务并启动
mysqld --install mysql

在这过程中记得截图,或者复制粘贴这个密码,记录随机生成的密码,如下图所示

屏幕截图 2023-01-25 192757.jpg

安装成功后显示如下:

image.png

修改Mysql密码

  1. 在本机启动mysql服务

image.png

image.png

找到mysql服务,右键启动

image.png

  1. 继续在cmd上执行以下命令
mysql -uroot -p

回车后输入上面安装时保存的初始密码,进入mysql里面:

image.png

  1. 在mysql里面继续执行以下命令
# 修改密码为123mysql
ALTER USER 'root'@'localhost' IDENTIFIED BY 'newpassword';

image.png

注意结尾需要有一个封号,回车按照指引执行完后,代表密码修改成功,再输入exit;退出即可

配置环境变量

  1. 新建系统变量:
    变量名:MYSQL_HOME
    变量值:文件的解压目录

image.png

  1. 修改path变量

image.png

总结

经过以上5个步骤,mysql就安装结束了,有以下两点需要注意:

  1. mysql初始密码必须记住,最好不要使用截图的方式,我第一次生产的密码中数字1和字母l,数字0和字母O肉眼难以区分,非常麻烦,使用复制粘贴方式保留密码则不会有问题
  2. my.ini中的路径配置记得使用双斜杠\,如果使用单斜杠会报错:[ERROR] [MY-010338] [Server] Can't find error-message file