linux下忘记mysql root密码解决办法

1、编辑MySQL配置文件my.cnf
系统运维 温馨提醒:qihang01原创内容版权所有,转载请注明出处及原文链接

vi /etc/my.cnf #编辑文件,找到[mysqld],在下面添加一行skip-grant-tables
[mysqld]
skip-grant-tables
:wq! #保存退出
service mysqld stop #停止mysql服务

2、进入MySQL控制台
mysql -uroot -p #直接按回车,这时不需要输入root密码。

3、修改root密码

系统运维 温馨提醒:qihang01原创内容版权所有,转载请注明出处及原文链接

update mysql.user set password=password('mysql') where User="root" and Host="localhost";

高版本:update mysql.user set authentication_string=password('mysql') where User="root" and Host="localhost";

mysql8.0修改方式

alter mysql.user 'root'@'localhost' IDENTIFIED BY 'Mysql@1234'; (有的时候是localhost有的时候是%,查看方式:select user,host from user;)

如果还报:ERROR 1396 (HY000): Operation CREATE USER failed for 'root'@'localhost'

则:删除用户,在新增

drop user 'root'@'localhost';

create user 'root'@'localhost' identified by 'Mysql@1234';
flush privileges; #刷新系统授权表

4、取消/etc/my.cnf中的skip-grant-tables
vi /etc/my.cnf 编辑文件,找到[mysqld],删除skip-grant-tables这一行
:wq! #保存退出

5、重启mysql
service mysqld restart #重启mysql,这个时候mysql的root密码已经修改为123456

6、进入mysql控制台
mysql -uroot -p #进入mysql控制台
123456 #输入密码

7、再次更改密码,否则控制台会报错

错误:【You must reset your password using ALTER USER statement before executing this statement】

修复方法:alter user user() identified by "123456";

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值