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";