MySQL登陸時出現 Access denied for user 'root'@'xxx.xxx.xxx.xxx' (using password: YES) 的緣由及解決辦法

場景一:調試web程序訪問數據庫的時候出現mysql

場景二:MySQL登錄的時候,區分本地localhost登錄,以及遠程登錄。即便本地可以登錄,若是不受權也沒法遠程登錄web

分析緣由:(區分)當本地出現這樣的狀況,就是密碼錯誤,找到正確的密碼或者修改密碼;當遠程登錄的時候,首先肯定登錄密碼是否正確,第二肯定是否遠程受權。針對以上兩種狀況,給出解決方案。sql

狀況一解決方案:修改本地數據庫密碼

方法1: 用SET PASSWORD命令 
首先登陸MySQL。 
格式:mysql> set password for 用戶名@localhost = password('新密碼'); 
例子:mysql> set password for root@localhost = password('123'); 

方法2:用mysqladmin 
格式:mysqladmin -u用戶名 -p舊密碼 password 新密碼 
例子:mysqladmin -uroot -p123456 password 123 

方法3:用UPDATE直接編輯user表 
首先登陸MySQL。 
mysql> use mysql; 
mysql> update user set password=password('123') where user='root' and host='localhost'; 
mysql> flush privileges; 

方法4:在忘記root密碼的時候,能夠這樣 
以windows爲例: 
1. 關閉正在運行的MySQL服務。 
2. 打開DOS窗口,轉到mysql\bin目錄。 
3. 輸入mysqld --skip-grant-tables 回車。--skip-grant-tables 的意思是啓動MySQL服務的時候跳過權限表認證。 
4. 再開一個DOS窗口(由於剛纔那個DOS窗口已經不能動了),轉到mysql\bin目錄。 
5. 輸入mysql回車,若是成功,將出現MySQL提示符 >。 
6. 鏈接權限數據庫: use mysql; 。 
6. 改密碼:update user set password=password("123") where user="root";(別忘了最後加分號) 。 
7. 刷新權限(必須步驟):flush privileges; 。 
8. 退出 quit。 
9. 註銷系統,再進入,使用用戶名root和剛纔設置的新密碼123登陸。數據庫

狀況二解決方案 :遠程受權

1. 先用localhost登陸(進入MySQL)      mysql -u root -p
Enter password:  (輸入密碼)
2. 執行受權命令
mysql> grant all privileges on *.* to root@'%' identified by '123';  (注意語句後面的「;」)
Query OK, 0 rows affected (0.07 sec)
3. 退出再試:  mysql> quit
四、再試登陸:    mysql -u root -h 192.168.194.142 -p
  Enter password: 
 結果顯示:Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 3
表示成功


下面詳細說說如何給用戶受權。
 
mysql> grant 權限1,權限2, ... 權限n on 數據庫名稱.表名稱 to 用戶名@用戶地址 identified by '鏈接口令';

權限1,權限2,... 權限n 表明 select、insert、update、delete、create、drop、index、alter、grant、references、reload、shutdown、process、file 等14個權限。
當權限1,權限2,... 權限n 被 all privileges 或者 all 代替時,表示賦予用戶所有權限。
當 數據庫名稱.表名稱 被 *.* 代替時,表示賦予用戶操做服務器上全部數據庫全部表的權限。
用戶地址能夠是localhost,也能夠是IP地址、機器名和域名。也能夠用 '%' 表示從任何地址鏈接。
'鏈接口令' 不能爲空,不然建立失敗。

舉幾個例子:
mysql> grant select,insert,update,delete,create,drop on vtdc.employee to joe@10.163.225.87 identified by ‘123′;
給來自10.163.225.87的用戶joe分配可對數據庫vtdc的employee表進行select,insert,update,delete,create,drop等操做的權限,並設定口令爲123。

mysql> grant all privileges on vtdc.* to joe@10.163.225.87 identified by ‘123′;
給來自10.163.225.87的用戶joe分配可對數據庫vtdc全部表進行全部操做的權限,並設定口令爲123。

mysql> grant all privileges on *.* to joe@10.163.225.87 identified by ‘123′;
給來自10.163.225.87的用戶joe分配可對全部數據庫的全部表進行全部操做的權限,並設定口令爲123。

mysql> grant all privileges on *.* to joe@localhost identified by ‘123′;
給本機用戶joe分配可對全部數據庫的全部表進行全部操做的權限,並設定口令爲123。案:遠程受權windows

相關文章
相關標籤/搜索