mac上安装MySQL5.7重置密码

Mac系统版本10.11.6

1.安装MySQL5.7.15版本,使用DMG方法安装,具体安装方法这里就不说了

2.安装好后,使用mysql -u root -p登录系统时需要输入密码,这里我们不知道密码是啥,试了好多网上的方法都不行,终于找到了

3.打开终端,具体步骤如下

  • sudo /usr/local/mysql/support-files/mysql.server stop
  • sudo /usr/local/mysql/bin/mysqld_safe --skip-grant-tables
  • 不要关闭当前窗口,打开另一窗口,进行以下操作
  • sudo /usr/local/mysql/bin/mysql -u root
  • use mysql
  • update user set authentication_string=password('你的密码') where user='root';
  • flush privileges
当你使用 mysql -u root -p命令登录成功后,随便使用MySQL命令,如show databases;会出现下面情况

ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.
使用下面命令
SET PASSWORD = PASSWORD('密码')
搞定!

### 如何在 Mac OS X 上重置 MySQL 5.7 的 root 密码 #### 停止 MySQL 服务 为了安全起见,在执行任何操作前,需先停止正在运行的 MySQL 服务。可以通过以下命令实现: ```bash sudo /usr/local/mysql/support-files/mysql.server stop ``` 如果此命令无法正常工作,则可能需要通过活动监视器手动终止 `mysqld` 进程[^3]。 #### 启动 MySQL 安全模式 启动 MySQL 并跳过权限验证表以允许无密码访问数据库: ```bash sudo /usr/local/mysql/bin/mysqld_safe --skip-grant-tables & ``` 注意:该进程会在后台运行,因此无需关闭当前终端窗口[^2]。 #### 登录 MySQL 数据库 打开一个新的终端窗口并尝试以管理员身份登录至 MySQL: ```bash sudo /usr/local/mysql/bin/mysql -u root ``` #### 更新 Root 用户密码 一旦成功连接到 MySQL 控制台,按照如下顺序更新 root 用户的认证字符串: 1. 切换到 `mysql` 数据库: ```sql use mysql; ``` 2. 使用 SQL 查询语句更改 root 用户的新密码(假设新密码为 `newpwd`): ```sql UPDATE user SET authentication_string=PASSWORD('newpwd') WHERE User='root'; ``` 3. 应用更改并刷新权限: ```sql FLUSH PRIVILEGES; ``` #### 验证新的根用户凭证 最后一步是为了确认新设定的有效性以及安全性增强措施完成情况: 1. 修改后的最终配置可通过重新定义用户的识别符进一步加强保护级别: ```sql ALTER USER 'root'@'localhost' IDENTIFIED BY 'newpwd'; ``` 2. 结束会话退出客户端程序: ```sql QUIT; ``` #### 正常重启 MySQL 服务器 返回初始状态下的常规运作模式非常重要,这包括结束先前处于特殊授权豁免状态下工作的实例和服务恢复默认行为路径上的所有组件恢复正常运转流程中的每一个环节都至关重要不可忽视任何一个细节部分从而确保整个系统的稳定性和可靠性达到预期目标效果最佳实践标准水平之上。 ```bash sudo killall mysqld_safe sudo /usr/local/mysql/support-files/mysql.server start ``` 此时应该能够使用刚刚设置好的新密码来管理您的 MySQL 实例了[^2]。 ```python def reset_mysql_password(): import os commands = [ "sudo /usr/local/mysql/support-files/mysql.server stop", "sudo /usr/local/mysql/bin/mysqld_safe --skip-grant-tables &", "sudo /usr/local/mysql/bin/mysql -u root" ] for cmd in commands[:-1]: os.system(cmd) reset_mysql_password() ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值