1. 程式人生 > >mysql 1045 access denied for user 解決方法

mysql 1045 access denied for user 解決方法

提示: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> 

內容來自: 指令碼之家 www.jb51.net 

另一個方法
Windows:

1. 管理員登陸系統,停止mysql服務或者結束mysqld-nt程序
2. 進入命令列,來到mysql的安裝目錄.假設安裝目錄為 d:\mysql\ , CMD進入命令列
3. 執行 d:\mysql\bin\mysqld-nt --skip-grant-tables 啟動mysql,關閉許可權的檢查
4. 執行 d:\mysql\bin\mysqladmin -u root flush-privileges password "newpassword" 重設root密碼

5. 重新啟動mysql服務

第4步也可以直接修改mysql表,所用到的SQL語句同linux部分,這裡就不再重複了.