mysql5.7后修改root用户密码

本文详细介绍了如何在Linux环境中安全模式启动MySQL,修改root用户的密码,包括停服、启动、连接、更新密码、刷新权限、重启服务以及验证新密码的过程,确保旧密码失效。

一、首先停掉mysql进程服务

killall -TERM mysqld

二、安全模式启动mysql

mysqld_safe --skip-grant-tables &

三、连接mysql

mysql

四、更改root密码

update mysql.user set authentication_string=password( '1234456') where user='root';

注意password(新密码),而且不要加and Host = 'localhost'这部分,会更改失败。

五、刷新权限

mysql> flush privileges;

mysql> quit;

六、重启mysql服务

service mysqld start

七、用新root密码连接

mysql -u root -p

输入新密码可以连接,而且旧密码已失效。

<think>好的,用户想了解如何在MySQL 5.7中重置或修改root用户密码。我需要根据提供的引用内容,整理出正确的步骤。首先,我要确认用户提到的MySQL版本是5.7,而引用里提到了5.7之前、5.7的Linux和Windows方法。可能需要区分不同系统下的步骤。 用户的问题是关于MySQL 5.7的,所以引用[2]和[3]都是相关的,而引用[1]是5.7之前的,可能需要注意区别。接下来,我需要分别整理Linux和Windows下的步骤,因为两个系统的方法可能不同。 在Linux下,引用[2]提到使用--skip-grant-tables启动服务,然后更新密码,最后刷新权限。需要检查是否有停止和启动服务的步骤,以及命令是否正确。比如,使用update语句修改密码后需要flush privileges,然后重启服务。 在Windows下,引用[3]提到类似的方法,但可能需要通过任务管理器关闭服务,然后使用mysqld启动跳过权限检查,再运行更新密码的命令。需要注意的是Windows可能需要管理员权限的命令提示符,并且路径可能不同。 另外,用户可能对安全模式下的操作不太熟悉,需要详细说明每个步骤,避免遗漏关键命令,比如使用UPDATE语句后的flush和重启服务。同时,需要注意MySQL 5.7之后user表中的密码字段是authentication_string,而不是之前的password,这可能影响语句的正确性。 还要提醒用户修改密码后测试登录,确保新密码生效。如果有任何步骤失败,可能需要检查服务是否正常运行,命令是否正确,以及是否有权限问题。最后,生成相关问题时要围绕密码重置、不同系统下的差异、安全模式的作用等,帮助用户深入理解。</think>在 MySQL 5.7 中重置 root 用户密码的步骤如下(区分 Linux 和 Windows 系统): ### Linux 系统操作步骤 1. **停止 MySQL 服务** ```bash sudo systemctl stop mysql ``` 2. **启动安全模式** 使用 `--skip-grant-tables` 参数跳过权限验证: ```bash sudo mysqld_safe --skip-grant-tables & ``` 3. **无密码登录 MySQL** 新开终端窗口执行: ```bash mysql -u root ``` 4. **更新密码字段** ```sql UPDATE mysql.user SET authentication_string = PASSWORD('新密码') WHERE User='root'; FLUSH PRIVILEGES; EXIT; ``` 5. **重启服务** ```bash sudo systemctl restart mysql ``` [^2] ### Windows 系统操作步骤 1. **关闭 MySQL 服务** 通过任务管理器或命令: ```bat net stop mysql ``` 2. **启动跳过权限模式** 在 CMD 中执行(需管理员权限): ```bat mysqld --skip-grant-tables ``` 3. **新窗口登录并修改密码** 新开 CMD 窗口执行: ```bat mysql -u root UPDATE mysql.user SET authentication_string = PASSWORD('新密码') WHERE User='root'; FLUSH PRIVILEGES; EXIT; ``` 4. **重启服务** ```bat net start mysql ``` [^3] ### 关键注意事项 - MySQL 5.7 使用 `authentication_string` 字段存储密码,而非早期版本的 `password` 字段[^1] - 修改后需执行 `FLUSH PRIVILEGES` 刷新权限 - 密码强度需符合策略要求(建议包含大小写字母、数字和符号)
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值