程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 解決mysql"Access denied for userroot@IP地址&quo

解決mysql"Access denied for userroot@IP地址&quo

編輯:MySQL綜合教程


解決mysql"Access denied for user'root'@'IP地址'"問題   在MYSQL 中,用遠程軟件登陸服務器,有時出現:Access denied for user 'root'@'localhost'  www.2cto.com     出現這種問題,主要的原因就是權限配置的時候 沒有配置正確。   解決方法如下:   當用Linux/unix的tty 登陸進MYSQL 時, mysql -u root -p 會提示你輸入密碼,輸入正確的密碼後正常登陸。   然後在提示符下,打命令:show grants; 會出現root如下的權限表示:GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' IDENTIFIED BY PASSWORD '565491d704013245' WITH GRANT OPTION   此時,注意看那個“@”後面的,是localhost 意思是本機登陸,,此時,如果你用遠程登陸軟件來登陸的話,會出現錯誤提示:Access denied for user 'root'@'IP地址'。。IP地址那塊是你遠程機器的IP地址。也就是服務器在告訴你,當你用“IP地址”登陸時,是拒絕的,因為,MYSQL權限設置裡並沒有給你對應你IP地址登陸的權限。因為剛才的SHOW GRANTS;命令結果已經告訴你了,僅限本機登陸。   那解決方法如下:此時,你可以嘗試用空密碼連接,是可以連接進入的。或者你在服務器的tty 或者pts操作台中進入服務器後執行如下的命令:   grant all privileges on *.* to 'root'@'%' with grant option;   意思是讓root在所有機器都可以登陸到MYSQL服務器(擁有所有權限)。當執行完這條命令後,用客戶端登陸,此時,是需要輸入口令了。   GRANT ALL PRIVILEGES   1。 改表法。可能是你的帳號不允許從遠程登陸,只能在localhost。這個時候只要在localhost的那台電腦,登入mysql後,更改 "mysql" 數據庫裡的 "user" 表裡的 "host" 項,從"localhost"改稱"%"   Sql代碼   1. mysql -u root -pvmwaremysql>use mysql; 2. mysql>update user set host = '%' where user = 'root'; 3. mysql>select host, user from user;   2. 授權法。例如,你想myuser使用mypassword從任何主機連接到mysql服務器的話。   Sql代碼   1. GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'%' IDENTIFIED BY 'mypassword' WITH   GRANT OPTION; 2.FLUSH   PRIVILEGES;    如果你想允許用戶myuser從ip為192.168.1.6的主機連接到mysql服務器,並使用mypassword作為密碼   Sql代碼   1. GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'192.168.1.3' IDENTIFIED BY 2. 'mypassword' WITH GRANT OPTION; 3. FLUSH   PRIVILEGES;   GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'192.168.1.3' IDENTIFIED BY 'mypassword' WITH GRANT OPTION; FLUSH   PRIVILEGES;   如果你想允許用戶myuser從ip為192.168.1.6的主機連接到mysql服務器的dk數據庫,並使用mypassword作為密碼   Sql代碼   1. GRANT ALL PRIVILEGES ON dk.* TO 'myuser'@'192.168.1.3' IDENTIFIED BY 2. 'mypassword' WITH GRANT OPTION; 3. FLUSH   PRIVILEGES;   GRANT ALL PRIVILEGES ON dk.* TO 'myuser'@'192.168.1.3' IDENTIFIED BY 'mypassword' WITH GRANT OPTION; FLUSH   PRIVILEGES;   注意授權後必須FLUSH PRIVILEGES;否則無法立即生效。   另外一種方法.   在安裝mysql的機器上運行: 1、d:\mysql\bin\>mysql -h localhost -u root //這樣應該可以進入MySQL服務器 2、mysql>GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION //賦予任何主機訪問數據的權限 3、mysql>FLUSH PRIVILEGES //修改生效 4、mysql>EXIT //退出MySQL服務器 這樣就可以在其它任何的主機上以root身份登錄啦!  

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved