首页 > 解决方案 > 用户 'root'@'localhost' 拒绝访问数据库 'drupal'

问题描述

我正在使用尚未配置自己的 MySQL 服务器,并且在涉及 SQL 时我有点菜鸟。

我创建了一个这样的数据库:

root@localhost:~# mysqladmin -u root -p create drupal

然后尝试授予这样的权限:

root@localhost:~# mysql -u root -p

MariaDB [(none)]> GRANT ALL PRIVILEGES ON drupal.* TO root IDENTIFIED BY ...;

但是得到这个错误:

ERROR 1044 (42000): Access denied for user 'root'@'localhost' to database 'drupal'

[更新] 所有形式的 GRANT 命令都出现此错误。

但根据 SHOW GRANTS 我应该有特权:

MariaDB [(none)]> SHOW GRANTS;
+--------------------------------------------------------------------------- 
-------------------------------------------+
| Grants for root@localhost                                                                                            
|
+--------------------------------------------------------------------------- 
------------------------------------------+
| GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' IDENTIFIED BY PASSWORD 
'*...' |
+--------------------------------------------------------------------------- 
-------------------------------------------+
1 row in set (0.00 sec)

MySQL 版本为:mysql Ver 15.1 Distrib 10.1.26-MariaDB On Debian 9.5

标签: mysql

解决方案


问题是 root 用户没有授予权限。

SELECT host,user,password,Grant_priv,Super_priv FROM mysql.user;

我用这个命令修复了它:

UPDATE mysql.user SET Grant_priv='Y', Super_priv='Y' WHERE User='root';
FLUSH PRIVILEGES;
GRANT ALL ON *.* TO 'root'@'localhost';

您必须注销并重新登录才能正常工作。


推荐阅读