win下安装多个MySQL注意点

  本机默认安装一个mysql56服务器,因为想要验证mysql57一个字符集相关的特性,所以打算在本机再装一个,安装方式采用的是压缩包的方式,非通过mysql-installer-community方式安装。坑太多了,心累的一天!:happy:

bug点陈列

1、MySQL57安装初始化之后,my.inf文件夹指定的目录没有创建,my.inf根本没有起作用。
2、MySQL57密码问题:用初始生成的密码登录,密码输入正确依旧被否认,利用mysql --skip-grant-tables修改密码多次,依旧登录不上。

问题复现及解决

其实开始安装MySQL57时,my.ini文件没有生效是导致一连串bug的根源。my.ini文件为什么没有生效呢?
复现:
关闭mysql56服务,下载mysql57安装包并解压,新建my.ini文件到mysql57安装目录,目录内容如下:

[mysqld]
#skip-grant-tables
port = 3306
basedir=E:\\mysql-5.7.31-winx64
# 数据库文件存放地址
datadir=E:\\mysql-5.7.31-winx64\\Data 
# 最大连接数
max_connections=200
character-set-server=utf8
[mysql]
default-character-set=utf8

之后执行mysql初始化命令,mysql --initialize--insecure得到一个随机码,这时候我发现E:\\mysql-5.7.31-winx64\\Data这个目录并没有生成,经查询它默认配置到了MySQL56所在的目录,我一看这不行啊,考虑到如果数据文件越来越大,必须将数据文件转移到其他盘而不是MySQL56所在的C盘。

为什么my.ini文件配置失效?

文件分隔符,其实双反斜杠和单正斜杠都可以经查询,排除。

我没有配置MySQL57目录下/bin的环境变量,并且cmd下操作的命令不是在mysql57安装bin目录下进行的,那么本机就会使用MySQL56的环境变量,那么就相当于将MySQL56初始化了一遍,而不是MySQL57,所以存在两种解决方案:(1)将MySQL57的环境变量添加到系统变量置于MySQL56的环境变量之前。(2)不添加MySQL57环境变量,在MySQL57的bin目录下运行命令。

我采用了(2),my.ini文件作用生效,data目录在MySQL57安装目录成功生成。之后执行安装MySQL57服务,cmd显示服务成功安装,之后启动服务,登录

# mysql57位服务名
mysql --install mysql57
net start mysql
# 删除mysql57服务
sc delete mysql57

当输入用户名密码的时候,输入的密码一定正确,但被否认了,当我只输入用户名,不输入密码的时候直接回车却能够进入数据库,但是只有一个访客权限,数据库只存在information_schema,没有mysql数据库,这显然不是root用户该有的样子。多次输入无解之后,只能通过修改一下密码尝试一下。接着又是一通操作:

# Linux或者win如果忘记密码,都可以使用这种方法,一种是命令行,一种是配置文件方式

# 1.跳过密码之前的配置
# 1.1.配置文件方式
# my.ini或者my.cnf,在[mysqld]添加skip-grant-tables
# 重启服务

# 1.2. 命令行方式(win)
# 关闭服务
# bin目录cmd中执行
mysqld --skip grant tables
# 这时光标卡住,这是正常的反应

# 2.更改密码
# 通过1.1或者1.2任意一种设置,都可以免密进行登录,这里以1.2方式讲解
# bin下新开cmd窗口,输入
mysql -uroot -p #两次回车
# 进入mysql,update pwd
use mysql;
update user set authentication_string =password('new_pwd') where user='root';
flush privileges;
# 退出之后开启服务再次登录

【注】mysql57之后mysql下的user表没有password字段了,也就是说不能set password=xxx,新版本的数据库将利用password函数将字符串(password)加密后设置到authentication_string这个字段中。其实还有多种更改mysql用户密码的方式。

改完密码之后,我尝试着再次登录结果还是无果。

初始登录失败,密码修改之后,还是登录失败!

之后百度了很多帖子,直到遇到了,总算解决了!

当我查看我的注册表的时候cmd->regedit,注意到这样的一个值计算机\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\mysql57,Services下存在两个mysql,一个是56,一个是57,博文中介绍的点是要修改ImagePath的值。我观察到我的mysql57中ImagePath的值竟然和mysql56的值相同,这就不应该了,mysql57应该使用它目录下的mysqld、data等等。所以我将值改为了mysql57目录,再次登录,密码正确,成功!

出现以上bug的原因,就是刚开始my.ini文件没有生效,编译安装之后使用的是MySQL56的配置,当再次做其他操作的时候,结果就会出现很多意外的错误。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要安装免费的MySQL数据库,可以按照以下步骤进行操作: 1. 打开浏览器,在MySQL官方网站上下载并安装MySQL Community Edition。确保选择与您的操作系统相匹配的版本。 2. 下载完成后,运行安装程序,并按照提示进行安装。您可以选择自定义安装,以便根据您的需求进行选择,或者使用默认设置完成安装。 3. 在安装过程中,您将被要求设置MySQL的根密码。请记住这个密码,因为将来登录MySQL时会使用到它。 4. 完成安装后,您可以通过“开始”菜单或桌面上的快捷方式启动MySQL。 5. 打开MySQL命令行客户端或使用图形界面工具(如phpMyAdmin)连接到MySQL服务器。您需要使用刚刚设置的根密码进行身份验证。 6. 成功登录后,您可以创建新的数据库、数据表、用户等。 请注意,这只是安装MySQL数据库的基本步骤。具体使用和管理数据库的过程可能需要您进一步了解和学习。您可以通过阅读MySQL官方文档或其他相关资源进一步深入了解MySQL的使用和管理技巧。 ### 回答2: 要在Windows 11上免费安装MySQL数据库,可以按照以下步骤进行操作: 1. 下载MySQL安装程序:访问MySQL官方网站,找到并下载适用于WindowsMySQL安装程序。 2. 运行安装程序:双击下载的安装程序,按照安装向导的指示进行操作。选择自定义安装选项,以便对安装进行更多的控制。 3. 选择安装组件:在选择要安装的组件页面上,确保MySQL Server选项被选中。根据需求选择其他可选组件,例如MySQL Workbench等。 4. 配置安装选项:根据个人需求,在选择安装类型页面上选择标准或详细,然后继续进行。 5. 设定root密码:在设定root用户密码页面上,输入您要设置的密码。请确保使用强密码来保护您的数据库。 6. 完成安装:在准备安装页面上,确认您所做的选择并继续安装。等待安装程序完成所有操作。 7. 配置MySQL服务:安装完成后,打开控制面板,找到“系统和安全”选项,然后选择“管理工具”,再选择“服务”。找到MySQL服务,右键单击并选择“属性”。在属性对话框的“常规”选项卡中,将启动类型设置为“自动”。 8. 启动MySQL服务:在服务属性对话框中,击“启动”按钮来启动MySQL服务。您也可以在此处选择将服务设置为自动启动。 9. 测试安装:打开命令提示符,输入“mysql -u root -p”,然后按Enter键。输入您之前设置的root密码,如果一切顺利,您将进入MySQL数据库命令行。 通过以上步骤,您将能够在Windows 11上成功安装免费的MySQL数据库,并可以通过命令行或其他客户端工具来管理和使用该数据库。 ### 回答3: 要在Windows 11上安装免费的MySQL数据库,你可以按照以下步骤进行操作: 1. 下载MySQL Community Server:访问MySQL官方网站,选择适合Windows 11的MySQL Community Server版本。在下载页面上,你可以选择下载适用于Windows操作系统的MySQL MSI安装程序。 2. 运行安装程序:下载完毕后,双击运行安装程序。在安装向导中,你可以选择自定义安装或使用默认设置。根据你的需求进行设置,并选择要安装的组件。 3. 设置MySQL配置:在安装过程中,你将被要求设置MySQL的根密码。请确保设置一个强密码,这将用于数据库管理。 4. 完成安装:完成安装程序的设置后,击“完成”按钮,MySQL数据库就被成功安装到了你的Windows 11系统。 5. 配置和管理MySQL:一旦安装完成,你可以使用命令行或图形用户界面工具来配置和管理MySQL数据库MySQL提供了MySQL Workbench等图形工具,方便你进行数据库管理和查询。 总结起来,安装免费的MySQL数据库Windows 11上并不复杂。你只需要下载适合Windows 11的MySQL Community Server版本,进行安装,并设置MySQL的根密码。随后,你就可以开始使用MySQL Workbench等工具来管理和查询你的数据库了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值