首先,将您登录的用户标识为:
select user(); select current_user();
第一个命令的结果是您尝试登录时的身份,第二个命令是您实际连接时的身份。确认您
root@localhost以mysql 身份登录。
Grant_priv到
root@localhost。这是您可以检查的方式。
mysql> SELECT host,user,password,Grant_priv,Super_priv FROM mysql.user;+-----------+------------------+-------------------------------------------+------------+------------+| host | user | password | Grant_priv | Super_priv |+-----------+------------------+-------------------------------------------+------------+------------+| localhost | root | ***************************************** | N | Y || localhost | debian-sys-maint | ***************************************** | Y | Y || localhost | staging | ***************************************** | N | N |+-----------+------------------+-------------------------------------------+------------+------------+
您可以看到,对于root @ localhost,Grant_priv设置为N。必须为Y。下面是解决方法:
UPDATE mysql.user SET Grant_priv='Y', Super_priv='Y' WHERe User='root';FLUSH PRIVILEGES;GRANT ALL ON *.* TO 'root'@'localhost';
我重新登录,一切正常。



