linux下 MySQL数据库忘记密码解决方案

前言:
在日常的开发中我们有可能忘记了我们自己设置的密码,譬如说Mysql数据库的密码,不过不要担心,小编整理了2个方法带给大家。

方法一​
查看初始化密码进行登录:

grep 'temporary password' /var/log/mysqld.log

查看mysql的初始密码
在这里插入图片描述

在root@localhost后面的就是mysql初始的密码,以上图为例 初始密码则为:ukehBfivW1

方法二
直接跳过数据库密码验证:

1、用vi指令进入mysql配置文件/etc/my.cnf并修改

vim /etc/my.cnf

在最后添加一句话skip-grant-tables,用命令wq保存并退出
在这里插入图片描述

如果无法保存或修改,先查看文件权限然后用chmod修改文件权限为可读可写

注意:

如果提示错误:The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement

则要先关闭数据库服务:systemctl stop mysqld.service

然后在修改mysql配置文件/etc/my.cnf

最后在启动mysql数据库服务:systemctl restart mysqld.service

2、重启数据库服务

输入systemctl restart mysqld.service

3、使用sql语句来修改密码

直接在输入mysql,然后输入sql语句并执行
在这里插入图片描述
在这里插入图片描述

设置复杂密码(由于mysql密码策略,此密码必须足够复杂)

mysql> flush privileges;
-- 重新执行密码修改语句
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';
mysql> flush privileges;

然后再修改mysql配置文件/etc/my.cnf,将跳过密码验证skip-grant-tables删除,保存并退出

vim  /etc/my.cnf

在这里插入图片描述

使用新的密码登录
mysql -u root -p123456
在这里插入图片描述

1)更改mysql密码策略
mysql> set global validate_password_length=4;
mysql> set global validate_password_policy=0;
2)进入msyql库
mysql> use mysql;
3)查询user表
mysql> select user, host from user;
4)修改user表,把Host表内容修改为%
mysql> update user set host="%" where user="root";
5)刷新
mysql> flush privileges;
6)退出
mysql> quit;

4、密码修改成功后,使用修改后的密码来登录

输入mysql -uroot -p

然后输入你设置的密码就可以成功登录

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

杨安尧

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

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

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

打赏作者

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

抵扣说明:

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

余额充值