MySQL – 错误 1045 – 访问被拒绝
- 2024-10-10 09:28:00
- admin 原创
- 74
问题描述:
当我尝试通过命令行访问 MySQL 时,我以某种方式遇到了这个错误:
[root@localhost ~]# mysql -u root -p
Enter password:
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
我曾尝试使用此 HowTo 重置密码,但没有成功。
我已经完全卸载了 mysql 并重新安装,但仍然要求输入密码。我不知道为什么会这样!
有人可以帮我获取 MySQL 的默认安装吗?
环境
已安装 Fedora Core 10、完全根访问权限、Apache 和 PHP
感谢您的帮助!
编辑
对于那些想省去几个小时“咳血”时间的人来说,卸载 MySQl 时请彻底删除所有残留内容。如果不这样做,安装将永远不会是全新安装。
解决方案 1:
如果您确实设置了 root 密码但刚刚丢失或忘记了它:
停止 MySQL
使用 skip-grant-tables 选项手动重新启动它:
mysqld_safe --skip-grant-tables
现在,打开一个新的终端窗口并运行 MySQL 客户端:
mysql -u root
使用此 MySQL 命令手动重置 root 密码:
UPDATE mysql.user SET Password=PASSWORD('password') WHERE User='root';
如果您使用的是 MySQL 5.7(在终端中使用 mysql --version 检查),则命令为:
UPDATE mysql.user SET authentication_string=PASSWORD('password') WHERE User='root';
使用此 MySQL 命令刷新权限:
FLUSH PRIVILEGES;
来自http://www.tech-faq.com/reset-mysql-password.shtml
(也许这不是你所需要的,Abs,但我想它对于将来偶然遇到这个问题的人来说可能会有用)
解决方案 2:
尝试不使用任何密码进行连接:
mysql -u root
我相信初始默认设置是 root 帐户没有密码(显然应该尽快更改)。
解决方案 3:
使用此命令检查可能的输出
mysql> select user,host,password from mysql.user;
输出
mysql> select user,host,password from mysql.user;
+-------+-----------------------+-------------------------------------------+
| user | host | password |
+-------+-----------------------+-------------------------------------------+
| root | localhost | *8232A1298A49F710DBEE0B330C42EEC825D4190A |
| root | localhost.localdomain | *8232A1298A49F710DBEE0B330C42EEC825D4190A |
| root | 127.0.0.1 | *8232A1298A49F710DBEE0B330C42EEC825D4190A |
| admin | localhost | *2470C0C06DEE42FD1618BB99005ADCA2EC9D1E19 |
| admin | % | |
+-------+-----------------------+-------------------------------------------+
5 rows in set (0.00 sec)
在此情况下,尽管您已授予权限,但用户 admin 将不被允许从另一台主机登录。原因是用户 admin 没有任何密码可识别。
再次使用 GRANT 命令授予用户 admin 密码
mysql> GRANT ALL PRIVILEGES ON *.* TO 'admin'@'%' IDENTIFIED by 'password'
然后检查 GRANT LIST 输出将像他的
mysql> select user,host,password from mysql.user;
+-------+-----------------------+-------------------------------------------+
| user | host | password |
+-------+-----------------------+-------------------------------------------+
| root | localhost | *8232A1298A49F710DBEE0B330C42EEC825D4190A |
| root | localhost.localdomain | *8232A1298A49F710DBEE0B330C42EEC825D4190A |
| root | 127.0.0.1 | *8232A1298A49F710DBEE0B330C42EEC825D4190A |
| admin | localhost | *2470C0C06DEE42FD1618BB99005ADCA2EC9D1E19 |
| admin | % | *2470C0C06DEE42FD1618BB99005ADCA2EC9D1E19 |
+-------+-----------------------+-------------------------------------------+
5 rows in set (0.00 sec)
如果所需用户(例如用户“admin”)需要被允许登录,则使用一次 GRANT 命令并执行该命令。
现在应该允许用户登录。
解决方案 4:
当前 root 密码必须为空。然后在“新 root 密码”下输入您的密码并确认。
解决方案 5:
进入 mysql 控制台
输入使用mysql;
UPDATE mysql.user SET Password=PASSWORD ('') WHERE User='root' FLUSH PRIVILEGES;退出 PASSWORD ('')必须为空
然后转到 wamp/apps/phpmyadmin../config.inc.php
查找 $cfg '服务器'['密码']='root';
将 ['密码'] 替换为 ['您的旧密码']
保存文件
重新启动所有服务并转到 localhost/phpmyadmin
解决方案 6:
我遇到了同样的错误,但这是因为password_expired
设置为Y
。您可以按照与当前接受的答案相同的方法解决该问题,但改为执行 MySQL 查询:
UPDATE mysql.user SET password_expired = 'N' WHERE User='root';
解决方案 7:
我无法连接到 MySql 管理员。我通过创建另一个用户并分配所有权限来解决这个问题。
我使用该新用户登录并且一切正常。
- 2024年20款好用的项目管理软件推荐,项目管理提效的20个工具和技巧
- 2024年开源项目管理软件有哪些?推荐5款好用的项目管理工具
- 项目管理软件有哪些?推荐7款超好用的项目管理工具
- 项目管理软件哪个最好用?盘点推荐5款好用的项目管理工具
- 项目管理软件有哪些最好用?推荐6款好用的项目管理工具
- 项目管理软件有哪些,盘点推荐国内外超好用的7款项目管理工具
- 2024项目管理软件排行榜(10类常用的项目管理工具全推荐)
- 项目管理软件排行榜:2024年项目经理必备5款开源项目管理软件汇总
- 2024年常用的项目管理软件有哪些?推荐这10款国内外好用的项目管理工具
- 项目管理必备:盘点2024年13款好用的项目管理软件