windows下的mysql数据库修改密码(忘记密码时)

1. 本人mysql版本为mysql-5.7.30-winx64

2. 在mysql安装目录下(本人的为D:\Software\mysql-5.7.30-winx64)打开my.ini文件

在这里插入图片描述

3. 在[mysqld]部分的末尾添加skip-grant-tables,意思是启动MySQL服务的时候跳过权限表认证。

在这里插入图片描述
如果skip-grant-tables写错位置,会出现如下错误(上面两个错误原因是密码错误):
在这里插入图片描述

4. 重启mysql服务(win+R,输入services.msc,点击enter,找到mysql服务,点击重启动)

在这里插入图片描述
在这里插入图片描述

5. 此时打开cmd窗口,输入mysql -uroot -p(进入mysql安装目录的bin目录下键入该命令,要不要进入bin目录有待确认,不想搞了,有缘者自行确认吧~)

此时会弹出一个Enter password:
不用输任何字符,直接单击enter,然后就可以进入mysql命令行了
在这里插入图片描述
在这里插入图片描述

6. 修改root账户密码,使用命令update user set password=password(“newPassword”) where user=“root”;会报错

-- 进入mysql数据库,root相关信息在mysql数据库的user表中
use mysql
-- 网上大部分是使用这条命令修改密码,但是我的版本的mysql的user表没有password列,我吐了
update user set password=password("newPassword") where user="root";

在这里插入图片描述
查百度发现,5.7 版本password 字段改成authentication_string,password函数还是原来的password函数

-- 修改密码
update user set authentication_string=password("newPassword") where user="root";
-- 更新权限
flush privileges;  

在这里插入图片描述

7. 退出,使用密码登录

-- 此时在使用无密码登录的会就会报错,如下图所示(有缘者请评论告知本人为何会如此?)
mysql -uroot -p

-- xxx是新密码
mysql -uroot -pxxx

在这里插入图片描述

8. 感觉还是要把my.ini中添加的代码删掉比较好,我是删了,你们随意…

-----------结束

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值