提示:1045 access denied for user \'root\'@\'localhost\' using password yes
方法一:
# /etc/init.d/mysql stop
# mysqld_safe --user=mysql --skip-grant-tables --skip-networking &
# mysql -u root mysql
mysql> UPDATE user SET Password=PASSWORD(\'newpassword\') where USER=\'root\';
mysql> FLUSH PRIVILEGES;
mysql> quit
# /etc/init.d/mysql restart
# mysql -uroot -p
Enter password: <輸入新設的密碼newpassword>
mysql>
方法二:
直接使用/etc/mysql/debian.cnf檔案中[client]節提供的使用者名和密碼:
# mysql -udebian-sys-maint -p
Enter password: <輸入[client]節的密碼>
mysql> UPDATE user SET Password=PASSWORD(’newpassword’) where USER=’root’;
mysql> FLUSH PRIVILEGES;
mysql> quit
# mysql -uroot -p
Enter password: <輸入新設的密碼newpassword>
mysql>
另一個方法
Windows:
1. 管理者登陸系統,停止mysql服務或者結束mysqld-nt程序
2. 進入指令行,來到mysql的安裝目錄.假設安裝目錄為 d:\mysql\ , CMD進入指令行
3. 運作 d:\mysql\bin\mysqld --skip-grant-tables 啟動mysql,關閉權限的檢查
4. 運作 d:\mysql\bin\mysqladmin -u root flush-privileges password "newpassword" 重設root密碼
5. 重新啟動mysql服務
第4步也可以直接修改mysql表,所用到的SQL語句同linux部分,這裡就不再重複了.