作業系統:WINDOWS-XP 系統
資料庫版本:mysql 5.x
提示:access denied for user 'root'@'localhost' using password yes/no
原來都好好的,今天開機上來提示上面的這個錯誤,重啟 MySQL 還是不可以。
注意我這裡的環境是 WINDOWS-XP 系統,LINUX 系統下的操作沒有驗證過,情況不清楚。
1. 管理員登陸系統,停止 MySQL 服務或者結束 MySQL 進程。
2. 啟動 WINDOWS 的命令列視窗(即通常的 DOS 視窗:運行cmd),切換到你的 “MySQL\bin” 目錄下。
例如我的是 “D:\Program Files\MySQL\MySQL Server 5.2\bin”,然後執行下面的粗體的命令:(注意你的 “my.ini” 位置)
Microsoft Windows XP [版本 5.1.2600]
(C) 著作權 1985-2001 Microsoft Corp.
C:\Documents and Settings\Administrator>cd D:\Program Files\MySQL\MySQL Server 5.2\bin
C:\Documents and Settings\Administrator>d:
D:\Program Files\MySQL\MySQL Server 5.2\bin>mysqld --defaults-file="D:\Program Files\MySQL\MySQL Server 5.2\my.ini" --console --skip-grant-tables
100608 9:04:12 InnoDB: Started; log sequence number 0 46409
100608 9:04:12 [Note] mysqld: ready for connections.
Version: '5.2.0-falcon-alpha-community' socket: '' port: 3306 MySQL Community
Server (GPL)
100608 9:06:57 [Warning] Found invalid password for user: 'root@localhost'; Ign
oring user
只要出現上面資訊,就說明 MySQL 已經起來了。
3. 不關閉此命令列視窗,重新開啟一個命令列視窗,同樣切到 “MySQL\bin” 目錄下,然後執行下面的粗體的命令:
Microsoft Windows XP [版本 5.1.2600]
(C) 著作權 1985-2001 Microsoft Corp.
C:\Documents and Settings\Administrator>cd D:\Program Files\MySQL\MySQL Server 5.2\bin
C:\Documents and Settings\Administrator>d:
D:\Program Files\MySQL\MySQL Server 5.2\bin>mysql -u root mysql
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.2.0-falcon-alpha-community MySQL Community Server (GPL)
Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
然後,就是重新設定密碼了!
mysql> UPDATE user SET Password=PASSWORD('root') where USER='root';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.00 sec)
mysql> quit
Bye
4. 好了到此步,可以關閉第一個 DOS 視窗了(關閉服務)。開啟系統服務控制視窗(控制台--管理工具--服務),啟動 MySQL 服務。
5. 在剩下的第二個 DOS 視窗中,用新的 ROOT 密碼串連 MySQL。
D:\Program Files\MySQL\MySQL Server 5.2\bin>mysql -u root -p
Enter password: ****
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.2.0-falcon-alpha-community-nt MySQL Community Server (GPL)
Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
mysql> quit
Bye
至此,系統復原 ROOT 使用者系統管理權限完成,就是管理員密碼的問題,奇怪,官方安裝的時候不給出解決方案,貌似已存在很久了。。。