修改Mysql 8 的密码

要在 MySQL 8 中修改密码,通常推荐使用 ALTER USER 语句。MySQL 8 在安全性和权限管理上进行了改进,因此推荐使用这个方法。下面是详细步骤:

步骤 1: 使用管理员账户登录 MySQL

首先,使用具有足够权限的管理员账户(通常是 root)登录到 MySQL。你可以通过以下命令进入 MySQL 命令行客户端:

bash 复制代码
mysql -u root -p

然后输入当前的密码。

步骤 2: 修改密码

在 MySQL 8 中,可以使用 ALTER USER 语句来修改密码。例如,要修改 root 用户的密码,使用以下命令:

sql 复制代码
ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_password';
  • root 是用户名。
  • localhost 是允许访问的主机名,可以是 localhost 或者是 %(表示允许从任何主机登录)。
  • 'new_password' 是你想要设置的新密码。

步骤 3: 刷新权限

执行完 ALTER USER 命令后,为了确保密码修改立即生效,运行以下命令刷新权限:

sql 复制代码
FLUSH PRIVILEGES;

步骤 4: 退出 MySQL

修改密码后,退出 MySQL 命令行:

sql 复制代码
exit;

步骤 5: 使用新密码登录

重新登录 MySQL 时,使用你刚刚设置的新密码:

bash 复制代码
mysql -u root -p

输入你设定的新密码,应该就能成功登录了。

其他常见情况

1. 修改其他用户的密码

如果你需要修改其他用户的密码,只需将用户名和主机名替换为目标用户。例如,修改 user1 用户的密码:

sql 复制代码
ALTER USER 'user1'@'localhost' IDENTIFIED BY 'new_password';
2. 忘记密码

如果你忘记了 MySQL root 用户的密码,可以通过以下步骤进行重置。这里的步骤假设你拥有操作 MySQL 数据目录和系统权限:

2.1 停止 MySQL 服务

首先,停止 MySQL 服务。

  • Windows

    bash 复制代码
    net stop mysql
  • Linux

    bash 复制代码
    sudo systemctl stop mysql
2.2 启动 MySQL 无密码模式

然后,启动 MySQL 并跳过授权表来允许不需要密码登录。

  • Windows

    bash 复制代码
    mysqld --skip-grant-tables
  • Linux

    bash 复制代码
    sudo mysqld_safe --skip-grant-tables &
2.3 登录 MySQL

接下来,使用以下命令登录 MySQL(不需要密码):

bash 复制代码
mysql -u root
2.4 修改密码

登录 MySQL 后,执行以下命令修改 root 用户的密码:

sql 复制代码
ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_password';
2.5 退出并重启 MySQL

完成密码修改后,退出 MySQL,然后重启 MySQL 服务。

  • Windows

    bash 复制代码
    net start mysql
  • Linux

    bash 复制代码
    sudo systemctl start mysql
2.6 使用新密码登录

现在你应该能够使用新密码登录 MySQL。

bash 复制代码
mysql -u root -p

总结

  • 推荐方法 :使用 ALTER USER 语句修改密码。
  • 其他用户:修改其他用户密码时,只需替换用户名。
  • 忘记密码:通过跳过授权表重置密码。

Windows部署Mysql指南
外网连接参考此文档

相关推荐
码农学院11 分钟前
Excel批量导入到数据库的方法
数据库·oracle·excel
曾经的三心草15 分钟前
实验指导-基于阿里云函数计算的简单邮件发送服务 之数据库访问中间件
数据库·阿里云·中间件
RestCloud23 分钟前
MongoDB到关系型数据库:JSON字段如何高效转换?
数据库·mysql·mongodb
洲覆39 分钟前
Redis 64字节分界线与跳表实现原理
数据结构·数据库·redis·缓存
失因1 小时前
Nginx 特性、配置与实战部署
运维·数据库·nginx
chirrupy_hamal1 小时前
PostgreSQL 流复制参数 - synchronous_commit
数据库·postgresql
lang201509281 小时前
MySQL InnoDB表压缩:性能优化全解析
数据库·mysql
满昕欢喜1 小时前
SQL Server从入门到项目实践(超值版)读书笔记 27
数据库·sql·sqlserver
间彧1 小时前
ProxySQL详解与实战应用
数据库
间彧1 小时前
在MySQL 8.0+版本中,如果MyISAM被弃用,有哪些替代方案可以实现类似读写分离的性能优化?
数据库