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

发布于:2024-05-17 ⋅ 阅读:(171) ⋅ 点赞:(0)

前言:
在日常的开发中我们有可能忘记了我们自己设置的密码,譬如说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> set password=password("Qs23=zs32");
3)更改mysql密码策略
mysql> set global validate_password_length=4;
mysql> set global validate_password_policy=0;
4)设置简单好记的密码
mysql> set password=password("123456");
5)进入msyql库
mysql> use mysql;
6)查询user表
mysql> select user, host from user;
7)修改user表,把Host表内容修改为%
mysql> update user set host="%" where user="root";
8)刷新
mysql> flush privileges;
9)退出
mysql> quit;

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

vim  /etc/my.cnf

在这里插入图片描述

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

输入mysql -uroot -p

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