Bootstrap

msql8.x忘记密码

本来是想用5.x版本和8.x一起使用的,找了下文章摸索了下,发现自己还是不太会,只能使用其中一个,另一个5.x如果想用就会连接失败。

不过8.x的知道怎么使用了,就让5.x的先放着吧。

一方法和二方法都参考了一些文章
放两个链接吧:
https://blog.csdn.net/qq_34974749/article/details/105864533
https://www.jb51.net/article/178834.htm
应该会有用的。

方法一:

①win+R,cmd管理员登录,进入到mysql安装的路径下。

②使用mysql -uroot -p 回车后输入密码发现错误,没办法,找回密码吧。

③删除mysql安装目录中的data文件夹

④确保my.ini这里面的配置文件正确

[mysqld]
# 设置3306端口
port=3306
# 设置mysql的安装目录
basedir=D:\software\mysql-8.0.20-winx64\bin
# 设置mysql数据库的数据的存放目录
datadir=D:\software\mysql-8.0.20-winx64\Data
# 允许最大连接数
max_connections=200
# 允许连接失败的次数。这是为了防止有人从该主机试图攻击数据库系统
max_connect_errors=10
# 服务端使用的字符集默认为UTF8
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 默认使用“mysql_native_password”插件认证
default_authentication_plugin=mysql_native_password
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[client]
# 设置mysql客户端连接服务端时默认使用的端口
port=3306
default-character-set=utf8

⑤使用命令sc delete mysql,删除mysql服务,如果不确定是不是mysql,可以用sc query mysql 查看是否存在。

⑥删除完后创建服务:mysqld -install 出现Service successfully installed表示安装成功。

⑦ mysqld --initialize-insecure --user=mysql# 生成data目录并创建root用户

⑧mysqld --initialize --user=root --console 生成root用户的初始化密码。

⑨启动mysql:net start mysql#如果启动成功,就继续执行,不过一般来说,上面步骤没有报错,接下来就没啥问题了。

⑩当然可能会出现mysql数据库初始密码错误的可能,再重复从⑤的操作开始。
如果有随机密码了,就用root登录就成功了。
这里登录成功后还可以修改密码:
alter user ‘root’@'localhost’IDENTIFIED BY ‘你要设置的新密码’;
刷新:
flush privileges;

方法二:

这里还有一个不用密码登录的方法,不过感觉作用不是很大。
使用命令:mysqld --console --skip-grant-tables --shared-memory
这个命令使用后,窗口会进行挂起,重新打开一个cmd用管理员身份打开新的窗口,
进行无密码登录:mysql -uroot -p 回车后不输入密码再回车。

修改密码的操作如下:
use mysql; (使用mysql数据表)
update user set authentication_string=’’ where user=‘root’;(将密码置为空)
quit; (然后退出Mysql)

总结:感觉这里有些命令能复制就复制吧,毕竟手打可能出错。吃过一次亏,忙活好久。

;