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

來源:互聯網
上載者:User

在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),可使用版本升級後的新許可權及新功能。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.