linux下mysql 8.0忘记密码后重置密码 linux | mysql | mysql8 | 重置root密码

1://无密码登陆

找到mysql配置文件:my.cnf,

在【mysqld】模块添加:skip-grant-tables   保存退出;

2://使配置生效

重启mysql服务:  service mysqld restart;

3://将旧密码置空

mysql -u root -p    //提示输入密码时直接敲回车。

//选择数据库

use mysql

//将密码置空

update user set authentication_string = '' where user = 'root';

//退出

quit

4://去除免密码登陆

删掉步骤1的语句  skip-grant-tables

重启服务  service mysqld restart

5://修改密码

mysql -u root -p  //提示输入密码时直接敲回车,刚刚已经将密码置空了

ALTER USER 'root'@'localhost' IDENTIFIED BY 'abc123@xxx';//'abc123@xxx'
此句命令若报错, 可能是localhost在实际应用中作了修改,可以改为以下命令行 
ALTER USER 'root'@'%' IDENTIFIED BY 'abc123@xxx';//'abc123@xxx'

 密码形式过于简单则会报错

以上简单方式不能成功,必然是因为此机器上的MySQL经过了很多修改,否则以上标准步骤一般会成功,所以就得混合一些操作,

3)选择数据库

use mysql

4)查看用户

select user,host from user;

5)删除root用户

delete from user where user='root';

6)操作前,刷新权限

flush privileges;

7)新增root用户

    CREATE USER 'root'@'%' IDENTIFIED with mysql_native_password  BY 'root';
    GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;
    flush privileges;

8)退出
quit

你可能感兴趣的:(mysql,linux,数据库)