环境
Ubuntu
情景
忘记MysqL root用户密码,现在需要重置root用户密码
解决
1、停止MysqL服务
$ service MysqL stop
2、修改my.cnf
文件
@H_301_23@# 查找my.cnf文件在哪里
$ find / -name my.cnf
/var/lib/dpkg/alternatives/my.cnf
/etc/alternatives/my.cnf
/etc/MysqL/my.cnf
@H_301_23@# 修改my.cnf文件,在文件新增 skip-grant-tables,在启动MysqL时不启动grant-tables,授权表
$ vim /etc/MysqL/my.cnf
[MysqLd]
skip-grant-tables
3、启动MysqL服务
$ service MysqL restart
4、更改MysqL root用户密码
$ MysqL
@H_301_23@# 选择MysqL数据库
MysqL> use MysqL;
@H_301_23@# 更改user表中root用户密码
MysqL> update user set authentication_string==PASSWORD("new_pass") where user='root';
@H_301_23@# 注意:可能不同的数据库版本密码的字段名称不一样
@H_301_23@# 我的数据库版本是5.7.21,user表中的密码字段是:authentication_string
MysqL> select version();
+@H_301_23@-------------------------+
| version() |
+@H_301_23@-------------------------+
| 5.7.21-0ubuntu0.16.04.1 |
+@H_301_23@-------------------------+
1 row in set (0.00 sec)
@H_301_23@# 可以通过以下命令查看user表的密码字段名称
MysqL> show create table user\G;
5、再次修改my.cnf文件
需要把my.cnf
配置文件改回去,我们把skip-grant-tables
注释掉就可以了
$ vim /etc/MysqL/my.cnf
[MysqLd]
@H_301_23@# skip-grant-tables
6、再次重启MysqL
$ service MysqL restart
@H_301_23@# 现在我们可以用新root密码登录MysqL了
$ MysqL -u root -p
原文链接:https://www.f2er.com/ubuntu/349541.html