mysql8.0免安装版修改密码_Mysql8.0版本修改密码命令行(windows)

本文详细介绍了如何在Windows环境下,通过命令行修改MySQL8.0免安装版的密码。首先,通过命令行或任务管理器停止MySQL服务,然后以管理员身份运行cmd,使用`mysqld --shared-memory --skip-grant-tables`启动MySQL。接着,新窗口中无需密码登录,执行SQL命令更新root用户的密码。注意8.0版本中`password`字段已废弃,需使用`authentication_string`。在修改密码后,需刷新权限并重新登录验证。若出现2059错误,需更改加密规则为`mysql_native_password`。
摘要由CSDN通过智能技术生成

1.停止你正在运行的mysql

方法一:命令行:net stop mysql

方法二:任务管理器 --> 服务 --> mysql右键关闭

2.管理员身份运行cmd,输入

mysqld --shared-memory --skip-grant-tables

注:mysqld --skip-grant-tables这个命令8.0以上已经失效

此时这个窗口就不能动了,以管理员身份运行打开一个新窗口

d8396c41d440

ff8335a70b0a28bd966fb635edbb417.png

3.在新窗口cd到当前目录 ,键入

mysql -uroot -p

密码不用输入,直接回车过去,如图:

d8396c41d440

d380acb7817f72ba99510f959b7da2b.png

4.输入 use mysql;,进入mysql

5.输入置空密码命令

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

注:8.0以上版本 ‘password’ 字段已经不管用了,会报错,相关的命令比如:update mysql.user set password='newpassword' where user='root';一同失效

d8396c41d440

301f92b6c3038890b9389dd9b8e2f42.png

6.输入设置新密码命令

alter user 'root'@'localhost' identified by '设置的新密码'

7.必填:flush privileges;

这个时候可能报错:The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement;

解决:刷新权限表:flush privileges;

d8396c41d440

a7913cb6354dba2015d0894fc20a6c6.png

8.Ctrl+Z退出mysql,重新运行,使用新密码登录,完成

mysql -h localhost -u root -p

d8396c41d440

53eb9bee0cf41f8ab14dacbe75ff4d2.png

9.如果使用navicat连接数据库时报错2059,原因是mysql8 之前的版本中加密规则是mysql_native_password,而在mysql8之后,加密规则是caching_sha2_password,我们在这里修改一下加密规则就好了

mysql -h localhost -u root -p //登录

use mysql; //选择数据库

ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER; //更改加密方式

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '你的密码'; //更新用户密码

FLUSH PRIVILEGES; //刷新权限

再ps:上边链接的方法试了一下,第八步命令需要敲双引号,不然会报错

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值