解決mysql“Access denied for user \'root\'@\'IP位址\'
在MYSQL 中,用遠端軟體登陸伺服器,有時出現:Access denied for user \'root\'@\'localhost\'
出現這種問題,主要的原因就是權限配置的時候 沒有配置正确。
解決方法如下:
當用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身份登入啦!
