萬盛學電腦網

 萬盛學電腦網 >> 數據庫 >> mysql教程 >> MySQL執行GRANT命令時報錯ERROR 1045解決辦法

MySQL執行GRANT命令時報錯ERROR 1045解決辦法

GRANT命令是mysql中授權問題了,如果是我們在使用grant導致的ERROR 1045問題我們要如何來解決呢,今天小編來為各位介紹一篇關於MySQL執行GRANT命令時報錯ERROR 1045解決辦法吧。

在MySQL執行GRANT命令時出現如下錯誤內容。

mysql> grant all on *.* to ...
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

調查內容

mysql.user表

不小心把mysql.user表清除了的話,可以追加root用戶,但這次好像不是這個問題。

mysql> select user,host, password from mysql.user
+---------+-----------+-----------+
| user    | host      | password  |
+---------+-----------+-----------+
| root    | localhost | *XXX1     |
| root    | 127.0.0.1 | *XXX2     |
| zabbix  | localhost | *XXX3     |
+---------+-----------+-----------+
super用戶權限

查看用戶權限擁有super用戶權限。

mysql> show grants
GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP, RELOAD, SHUTDOWN, PROCESS, FILE, REFERENCES,
INDEX, ALTER, SHOW DATABASES, SUPER, CREATE TEMPORARY TABLES, LOCK TABLES, EXECUTE, REPLICATION SLAVE,
REPLICATION CLIENT, CREATE VIEW, SHOW VIEW, CREATE ROUTINE, ALTER ROUTINE, CREATE USER, EVENT, TRIGGER
ON *.* TO 'root'@'localhost' IDENTIFIED BY PASSWORD '*XXXX' WITH GRANT OPTION
查看MySQL版本

查看MySQL版本不知何時從5.1升級為5.5了,確認/var/log/yum.log發現yum安裝別的軟件的時候MySQL版本也同時被升級了。

對應內容

因為表的結構是5.1版本的因此無法在版本5.5追加用戶,執行mysql_upgrade之後,就可以正常的追加用戶了。

# mysql_upgrade -u root -p
Enter password:
Looking for 'mysql' as: mysql
Looking for 'mysqlcheck' as: mysqlcheck
Running 'mysqlcheck with default connection arguments
Running 'mysqlcheck with default connection arguments
mysql.columns_priv                                 OK
mysql.db                                           OK
mysql.event                                        OK
mysql.func                                         OK
...
執行GRANT命令成功!

mysql> grant all on *.* to ...
Query OK, 0 rows affected (0.00 sec)

結語

在升級MySQL後需要執行mysql_upgrade命令。mysql_upgrade會確認數據庫的表結構和最新MySQL Server的互換性。當表和現在的MySQL Server沒有互換性的時候,會確認該表並修復此表。並且mysql_upgrade命令會升級MySQL使用的表(即System Table),可使用版本升級後的新權限及新功能。

copyright © 萬盛學電腦網 all rights reserved