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