MySQL 忘记root密码及MySQL修改root密码的方法

时间:2022-11-13 16:03:05

MYSQL启动方式有三种:

/etc/init.d/mysql start|stop|restart

/usr/local/mysql/bin/mysqld_safe &

/usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf &

1、修改/etc/my.cnf文件,在[mysqld]下面添加skip-grant-tables并重启
登录:
[root@trcloud-gtt-dw ~]# mysql -uroot -p
Enter password:
这里直接回车
注:如果此种方法也无法登录数据库。看后面
2、cat /var/log/mysqld.log  查找的初始值密码.使用初始密码登陆以后;
3、MySQL5.7在安装完后,第一次启动时,会在root目录下生产一个随机的密码,文件名为/root/.mysql_secret
4、关闭正在运行的 MySQL :
 # service mysql stop
 # mysqld_safe --skip-grant-tables &
为了安全可以这样禁止远程连接:
# mysqld_safe --skip-grant-tables --skip-networking &
注:此种方法启动数据库无法使用IP连接数据库,需要重启/etc/my.cnf文件

使用mysql连接server:
# mysql -p
更改密码:

mysql> updaate mysql.user set authentication_string=password('123qwe') wheree user='root' and Host = 'localhost';
*特别提醒注意的一点是,新版的mysql数据库下的user表中已经没有Password字段了
而是将加密后的用户密码存储于authentication_string字段
mysql> flush privileges;
mysql> quit;
修改完毕。重启
# service mysql restart
然后mysql就可以连接了
但此时操作似乎功能不完全,还要alter user…

mysql> alteer user 'root'@'localhost' identified by '123';
这样也可以:

mysql> set password for 'root'@'localhost'=password('123');
重点给大家介绍下mysql 5.7 root密码修改

MySQL管理者密码设置或修改:

依据官方说明5.6以后版本,第一次启动时会在root目录下生产一个随机密码,文件名.mysql_secret。

# cat /root/.mysql_secret
# Password set for user 'root@localhost' at 2017-03-17 23:12:10
:Jj+FTiqvyrF
[root@bright ~]# cd /usr/local/mysql/bin/
[root@bright bin]# ./mysqladmin -u root -h localhost password '123456' -p
Enter password: #此行输入.mysql_secret里第二行内容

mysqladmin: [Warning] Using a password on the command line interface can be insecure.
Warning: Since password will be sent to server in plain text, use ssl connection to ensure password safety.
官方的方式,笔者无论是否使用--skip-grant-tables启动mysql都测试失败,亲们可以测试:
mysql -uroot -p'password' #password即.mysql_secret里的密码
mysql>SET PASSWORD = PASSWORD('newpasswd');


旧版本,安装后ROOT无密码,按如下操作:
方法一:
service mysqld stop #停止mysql服务
mysqld_safe --skip-grant-tables & #以不启用grant-tables模式启动mysql
mysql -uroot -p #输入命令回车进入,出现输入密码提示直接回车。
mysql>use mysql;
mysql>update user set password=PASSWORD("123456")where user="root"; #更改密码为 newpassord
mysql>flush privileges; #更新权限
mysql>quit #退出
方法二:
service mysqld stop #停止mysql服务
mysqld_safe --skip-grant-tables & #以不启用grant-tables模式启动mysql
mysql -uroot -p #输入命令回车进入,出现输入密码提示直接回车。
mysql > set password for root@localhost = password('mysqlroot');
方法三:
/path/mysqladmin -u UserName -h Host password 'new_password' -p