mysql8.0 zip 免安装版 配置 root 重置 修改 密码 教程

mysql8.0 zip 免安装版 配置 root 重置 修改 密码 教程


本人使用的mysql最新版本:8.0.20
在配置和重置root密码时,遇到了各种问题,在经过各种查阅资料百度后,终于搞定了,下面我们一步步来说明吧。

  • 新安装配置mysql的,请从头往后看
  • 忘记root密码需要重置的,请从【6.以非安全忽略密码的方式启动mysql(执行后,会一直处于运行状态)】开始看

在文章结尾,有说明mysql5.7版本与8.0修改密码的区别。


1. 下载mysql

官网太慢了,我自己上传的,不要币,随便下

https://blog.csdn.net/guangmo0123/article/details/106207823

2.配置环境变量

将mysql的bin目录追加至环境变量的path中,方便后续可以直接运行mysql的命令。

3.在mysql根目录手动创建mysql的配置文件——my.ini

my.ini内容如下

[mysqld]
# mysql的根目录路径,路径需要使用双斜杠(转义)
basedir=D:\\DevelopIDE\\mysql-8.0.20-winx64
# mysql的数据存放目录,不要手动创建该目录,让mysql初始化时自动创建,文件夹名必须为data
datadir=D:\\DevelopIDE\\mysql-8.0.20-winx64\\data
# mysql的端口号
port=3306

注:各位需要将其中的 basedir 和 datadir 修改为自己的mysql路径

4.以管理员的模式运行cmd(cmd窗口1)初始化mysql

mysqld --initialize

【注】

a.若安装服务时报 vcruntime140_1.dll 找不到的错误,请百度下载【微软常用运行库合集】,然后安装该工具,安装过程中会自动修复运行环境,之后再重新执行初始化命令即可

b.若提示如下错误

mysqld: [ERROR] Found option without preceding group in config file E:\mysql-8.0.16-winx64\my.ini at line 1.

mysqld: [ERROR] Fatal error in defaults handling. Program aborted!

则表示my.ini文件编码格式有误,需要修改为ANSI格式,用记事本打开,另存一下改一下编码格式即可

5.安装mysql服务(安装完成过后,不要启动服务)

mysqld --install

6.以非安全忽略密码的方式启动mysql(cmd执行后,会一直处于运行状态)

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

注:执行此命令(mysqld --shared-memory --skip-grant-tables)前,请先停止mysql服务(net stop mysql)

7.重新开启一个新的cmd窗口(cmd窗口2),直接执行mysql(无需输入root和密码),登录mysql进入命令行状态

mysql

8.使用(选择)mysql这个数据库

use mysql;

9.先清空一下原root的密码(mysql8.0特性)

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

10.退出mysql命令行模式

quit

11.退出mysql命令行模式后,就可以关闭所有cmd窗口了

 

12.自此,mysql的密码已经清空了,下次登录时,密码空着不用输入直接回车即可登录


开始设置新密码


1.重新打开新的cmd窗口,启动mysql服务

net start mysql

2.登录mysql,由于上面密码已经清空了,所以密码空着不用数据,直接回车

mysql -uroot -p

3.进入mysql命令行模式后,再设置root新密码

alter user 'root'@'localhost' identified with mysql_native_password by '123456';

注:记得将其中的'123456'修改为自己的密码。另外,如果使用的是网络模式,则可能需要将其中的 'localhost' 换成 '%'

4.自此,mysql的密码已经重置修改成功了


mysql5.7与mysql8.0修改root密码的区别

MySQL 5.7 版本,由于在user表中没有password字段,所以使用下边的方式来修改root密码

update user set authentication_string = password('123456') where user = 'root';

在mysql 5.7.9以后废弃了password字段和password()函数;authentication_string:字段表示用户密码,而authentication_string字段下只能是mysql加密后的41位字符串密码。所以需要用一下方式来修改root密码:

ALTER user 'root'@'localhost' IDENTIFIED BY '123456';

MySql 从8.0开始修改密码有了变化,在user表加了字段authentication_string,修改密码前先检查authentication_string是否为空

如果不为空,需要先将密码清空,之后再设置新密码,建议在执行先,先刷新一下权限,避免出现其它错误

刷新权限

flush privileges;

清空密码

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

再设置新密码

alter user 'root'@'localhost' identified with mysql_native_password by '123456';

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值