【赵渝强老师】解决MySQL丢失root用户密码

在这里插入图片描述
  在早期的MySQL数据库中,用户的密码是保存在“mysql.user”表中的“password”字段中。但是从MySQL 5.7版本开始“password”字段改成“authentication_string”字段。例如,下面的语句将查询MySQL中用户的密码。

mysql> select host,user,authentication_string from user;

# 输出的信息如下:
+--------------+------------------+------------------------------------------+
| host         | user             | authentication_string                    |
+--------------+------------------+------------------------------------------+
| %            | root             | *DA9A17B9F8055D5C1C913421889357F6A35565F7|
| %            | user001          | *DA9A17B9F8055D5C1C913421889357F6A35565F7|
| 192.168.79.% | myadmin          | *DA9A17B9F8055D5C1C913421889357F6A35565F7|
| localhost    | mysql.infoschema | $A$005$THISISACOMBINATIONOFINVALID...... |
| localhost    | mysql.session    | $A$005$THISISACOMBINATIONOFINVALID...... |
| localhost    | mysql.sys        | $A$005$THISISACOMBINATIONOFINVALID...... |
| localhost    | root             | *DA9A17B9F8055D5C1C913421889357F6A35565F7|
+--------------+------------------+------------------------------------------+

  对于root用户需码丢失这种问题,可以通过特殊方法登录,MySQL服务器,然后在root用户下重新设置登录密码。视频讲解如下:

解决MySQL丢失root用户密码

【赵渝强老师】解决MySQL丢失root用户密码

(1)停止MySQL数据库服务。

systemctl stop mysqld

(2)编辑配置文件“/etc/my.cnf”,在[mysqld]块的末尾添加一行:

skip-grant-tables

(3)重启MySQL服务。

systemctl start mysqld

(4)直接登录MySQL。

mysql

(5)查询“mysql.user”表的信息。

mysql> use mysql;
mysql> select host, user, authentication_string from user;

# 输出的信息如下:
+--------------+------------------+------------------------------------------+
| host         | user             | authentication_string                    |
+--------------+------------------+------------------------------------------+
| %            | root             | *DA9A17B9F8055D5C1C913421889357F6A35565F7|
| %            | user001          | *DA9A17B9F8055D5C1C913421889357F6A35565F7|
| localhost    | mysql.infoschema | $A$005$THISISACOMBINATIONOFINVALID...... |
| localhost    | mysql.session    | $A$005$THISISACOMBINATIONOFINVALID...... |
| localhost    | mysql.sys        | $A$005$THISISACOMBINATIONOFINVALID...... |
| localhost    | root             | *DA9A17B9F8055D5C1C913421889357F6A35565F7|
+--------------+------------------+------------------------------------------+

(6)置空root用户的密码。

mysql> update user set authentication_string='' where user='root';

(7)刷新一下权限。

mysql> flush privileges;

(8)重新设置root用户的密码。

mysql> alter user 'root'@'%' identified by 'Weblogic_123';
mysql> alter user 'root'@'localhost' identified by 'Weblogic_123';

(9)退出MySQL命令行,使用新的密码登录MySQL。

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

赵渝强老师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值