Posiblemente una precaución de seguridad. Puede intentar agregar una nueva cuenta de administrador:
mysql> CREATE USER 'monty'@'localhost' IDENTIFIED BY 'some_pass';
mysql> GRANT ALL PRIVILEGES ON *.* TO 'monty'@'localhost'
-> WITH GRANT OPTION;
mysql> CREATE USER 'monty'@'%' IDENTIFIED BY 'some_pass';
mysql> GRANT ALL PRIVILEGES ON *.* TO 'monty'@'%'
-> WITH GRANT OPTION;
Aunque, como Pascal y otros han señalado, no es una gran idea tener un usuario con este tipo de acceso abierto a cualquier IP. Si necesita un usuario administrativo, use root y déjelo en localhost. Para cualquier otra acción, especifique exactamente los privilegios que necesita y limite la accesibilidad del usuario como Pascal ha sugerido a continuación.
Editar:
De las preguntas frecuentes de MySQL:
Si no puede entender por qué se le niega el acceso, elimine de la tabla de usuario todas las entradas que tengan valores de Host que contengan comodines (entradas que contengan caracteres '%' o '_'). Un error muy común es insertar una nueva entrada con Host = '%' y User = 'some_user', pensando que esto le permite especificar localhost para conectarse desde la misma máquina. La razón por la que esto no funciona es que los privilegios predeterminados incluyen una entrada con Host = 'localhost' y User = ''. Debido a que esa entrada tiene un valor de Host 'localhost' que es más específico que '%', se usa con preferencia a la nueva entrada cuando se conecta desde localhost. El procedimiento correcto es insertar una segunda entrada con Host = 'localhost' y User = 'some_user', o para eliminar la entrada con Host = 'localhost' y Usuario = ''. Después de eliminar la entrada, recuerde emitir una instrucción FLUSH PRIVILEGES para volver a cargar las tablas de concesión. Consulte también la Sección 5.4.4, “Control de acceso, Etapa 1: Verificación de la conexión”.