chengloading

mysql 5.7.9版本之前修改

方法1: 用SET PASSWORD命令 
首先登录MySQL。 
格式:mysql> set password for 用户名@localhost = password(\'新密码\'); 
例子:mysql> set password for root@localhost = password(\'newpassword\'); 

方法2:用mysqladmin 
格式:mysqladmin -u用户名 -p旧密码 password 新密码 
例子:mysqladmin -uroot -poldpassword password newpassword 

方法3:用UPDATE直接编辑user表 
首先登录MySQL。 
mysql> use mysql; 
mysql> update user set password=password(\'newpassword\') where user=\'root\' and host=\'localhost\'; 
mysql> flush privileges; 

方法4:在忘记root密码的时候,可以这样 
以windows为例: 
1. 关闭正在运行的MySQL服务。 
2. 打开DOS窗口,转到mysql\bin目录。 
3. 输入mysqld --skip-grant-tables 回车。--skip-grant-tables 的意思是启动MySQL服务的时候跳过权限表认证。 
4. 再开一个DOS窗口(因为刚才那个DOS窗口已经不能动了),转到mysql\bin目录。 
5. 输入mysql回车,如果成功,将出现MySQL提示符 >。 
6. 连接权限数据库: use mysql; 。 
6. 改密码:update user set password=password("newpassword") where user="root";(别忘了最后加分号) 。 
7. 刷新权限(必须步骤):flush privileges; 。 
8. 退出 quit。 
9. 注销系统,再进入,使用用户名root和刚才设置的新密码newpassword登录。

mysql 5.7.9版本之后修改

mysql 5.7.9以后废弃了password字段和password()函数;authentication_string:字段表示用户密码。

use mysql;

首先 update user set authentication_string=\'\' where user=\'root\'

然后 ALTER user \'root\'@\'localhost\' IDENTIFIED BY \'newpassword\'

1.不需要flush privileges来刷新权限。

2.密码要包含大写字母,小写字母,数字,特殊符号。

3.顺序不能错,不然会报错。由于authentication_string字段下只能是mysql加密后的41位字符串密码,其他的会报格式错误。

分类:

技术点:

相关文章:

  • 2022-01-02
  • 2021-12-16
  • 2021-12-04
  • 2021-12-04
  • 2021-12-06
猜你喜欢
  • 2021-12-16
  • 2021-12-16
  • 2021-12-16
  • 2021-12-04
  • 2021-08-27
  • 2021-12-16
相关资源
相似解决方案