Mysql Server 8.0.15 安装教程(踩坑教学,内有各种解决方法),发生系统错误5拒绝访问,发生系统错误2找不到文件,登录密码,用户没有权限等等

第一步:下载mysql server
下载地址:https://dev.mysql.com/downloads/mysql/

因为装的是windows版本,所以就拿windows举例子。

第二步:解压ZIP文件


第三步:配置Path环境变量

administrator变量配置中:

path中加入你安装的mysql根目录下的bin包文件地址

 


第四步:以管理员身份运行cmd
运行mysqld -install

第五步:尝试打开Mysql服务,会出现两种情况:

 

1


问题:没有在bin目录下安装,使用mysqld -remove删除服务再在bin目录下重新安装。

输入:mysqld -remove  

提示成功后再输入:mysqld -install

这里博主出现了很多次发生系统错误2的问题,这里建议大家重复几次mysqld -remove删除服务再在bin目录下重新安装;

还不行的话:就是服务的默认目录与sql文件的安装目录不一致

我们可以进入服务,看看服务的路径

导致这样的根本原因就是:

出现这种错误的原因是在注册系统服务的时候 没有进入到 %mysql 的解压目%\bin 目录下, 即使配置了环境变量,也要进入该目录下进行注册 ,否则注册的服务“可执行文件路径”会默认在C盘下。

开始...运行... regedit  注册表项:

HKEY_LOCAL_MACHINE -> SYSTEM -> CurrentControlSet -? services -> mysql -> ImagePath

 这样就能够解决,在注册表里面不需要保存,它是自动保存;

之后再试着连接mysql,还是不行的话,这里博主建议大家卸载mysql在重装吧!!!!

如何彻底删除卸载MySQL。。。

1》停止MySQL服务
开始-》所有应用-》Windows管理工具-》服务,将MySQL服务停止。
2》卸载mysql server
控制面板\所有控制面板项\程序和功能,将mysql server卸载掉。
3》将MySQL安装目录下的MySQL文件夹删除(我的安装目录是C:\Program Files (x86)\MySQL)
4》运行“regedit”文件,打开注册表。
删除HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Eventlog\Application\MySQL文件夹
删除HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Services\Eventlog\Application\MySQL文件夹。
删除HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Eventlog\Application\MySQL的文件夹。
如果没有相应的文件夹,就不用删除了。
5》删除C盘下的“C:\ProgramData\MySQL ”文件夹,如果删除不了则用360粉碎掉即可,
该programData文件默认是隐藏的,设置显示后即可见,或者直接复制 C:\ProgramData 到地址栏回车即可进入!
将整个MySQL文件夹删除掉。。。
6》开始-》所有应用-》Windows管理工具-》服务
如果已经将MySQL卸载,但通过“开始-》所有应用-》Windows管理工具-》服务”查看到MySQL服务仍然残留在
系统服务里。又不想改服务名,改怎么办呢。
只要在CMD里输入一条命令就可以将服务删除:
sc delete mysql //这里的mysql是你要删除的服务名
这样一来服务就被删除了。

然后,就可以重装MySQL数据库了!!!

 

2

如果出现的是发生系统错误5,拒绝访问, 如果已经成功连接就跳过这里!

用cmd启动MySQL   (net start mysql )时出现(发生系统错误 5。  拒绝访问)这样的错误是因为cmd 权限太低了需要提高cmd权限才行(即使管理员权限)

鼠标右键,以管理员的身份运行;

 

之后再试着连接mysql,还是拒绝访问,这里博主建议大家卸载mysql在重装吧!!!!

如何彻底删除卸载MySQL。。。

1》停止MySQL服务
开始-》所有应用-》Windows管理工具-》服务,将MySQL服务停止。
2》卸载mysql server
控制面板\所有控制面板项\程序和功能,将mysql server卸载掉。
3》将MySQL安装目录下的MySQL文件夹删除(我的安装目录是C:\Program Files (x86)\MySQL)
4》运行“regedit”文件,打开注册表。
删除HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Eventlog\Application\MySQL文件夹
删除HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Services\Eventlog\Application\MySQL文件夹。
删除HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Eventlog\Application\MySQL的文件夹。
如果没有相应的文件夹,就不用删除了。
5》删除C盘下的“C:\ProgramData\MySQL ”文件夹,如果删除不了则用360粉碎掉即可,
该programData文件默认是隐藏的,设置显示后即可见,或者直接复制 C:\ProgramData 到地址栏回车即可进入!
将整个MySQL文件夹删除掉。。。
6》开始-》所有应用-》Windows管理工具-》服务
如果已经将MySQL卸载,但通过“开始-》所有应用-》Windows管理工具-》服务”查看到MySQL服务仍然残留在
系统服务里。又不想改服务名,改怎么办呢。
只要在CMD里输入一条命令就可以将服务删除:
sc delete mysql //这里的mysql是你要删除的服务名
这样一来服务就被删除了。

然后,就可以重装MySQL数据库了!!!

 

 

再次尝试打开服务。

第六步:运行mysqld --initialize


文件夹里面出现了一个data文件夹,感觉越来越对了:)

再次启动服务。

哦哟~,可以了:)

第七步:登录Mysql
登录mysql。

然后发现。。。进不去!。

查看类似问题后发现:

在安装的过程里,将仅创建一个root账户——'root'@'localhost',同时将自动生成一个随机密码给它,并标记此密码已过期。MySQL管理员必须使用随机密码登陆root账户,并使用SET PASSWORD去设置一个新的密码。(随机密码可以在运行安装脚本的有效用户其主目录中的.mysql_secret文件中找到。)

然而这个mysql_secret并没有找到。。。但是这个默认随机密码估计是真的有。

重新初始化,删除了data文件夹,运行mysqld --initialize --console命令(可以输出中间过程)。

结果:

第二行出现了随机密码  rhXz%wnfa2yk

我们拿这个密码试试看登录。

终于进去了:)

这里没进去的同学,会出现ERROR 1045 (28000): Access denied for user 'xxx'@'localhost' (using password: YES)

或者ERROR 1045 (28000): Access denied for user 'xxx'@'localhost' (using password: NO)

密码错了? 

    算了,再敲一遍

      fuck,还是错了?

 

这里博主查询了很多资料,这里建议你多输几遍密码或者

在yunxing中输入server.msc,吧mysql的服务停止以后,把mysql根目录下的data文件夹删除,在重新运行mysqld --initialize --console命令(可以输出中间过程);这次要记住密码;还不对建议重复以上;

 

 

第八步:设置用户名和密码
先修改root用户的密码。

这里博主建议大家截图保存在你mysql的根目录下,免得下次又忘记root密码;

 

创建自己用的账户。

这里也建议大家截图保存自己的账号和密码;

 

尝试登录一下。

第九步:对用户进行授权


GRANT命令说明:

GRANT privileges ON databasename.tablename TO 'username'@'host'

privileges:用户的操作权限,如SELECT,INSERT,UPDATE等,如果要授予所的权限则使用ALL
databasename:数据库名
tablename:表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示,如*.*
 

 

这里用户授权会出现ERROR 1044(42000): Access denied for user 'xxx'@'localhost' to database ‘mytestsql’;错误

是因为你现在登录的是自己账户,你在创建自己账户的时候没有给自己的账户赋予权限;

你可以输入:show grants;

查看你现在登录账户拥有的权限:

 

应该使用mysql的默认用户名‘root’进行登陆:

        你要切换用户,重新打开新的cmd :,输入:mysql -hlocalhost -uroot -p

        其中-h表示服务器名,localhost表示本地;-u为数据库用户名,root是mysql默认用户名;-p为密码,如果设置了密码,可直接在-p后链接输入刚刚博主叫你们保存的root密码;

 

进入root用户以后给你自己的用户赋权;

然后切换自己的用户登录就可以;

这时,再查看权限:

用户具有所有权限,可以创建 database。

 

 

 

  • 7
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值