
image.png
MySQL登錄時出現(xiàn) Access denied for user 'root'@'xxx.xxx.xxx.xxx' (using password: YES) 的原因及解決辦法。
【解決辦法】
- 先用localhost登錄
mysql -u root -pxxx - 執(zhí)行授權(quán)命令
mysql> use mysql;
mysql> grant all privileges on *.* to root@'%' identified by '123';
Query OK, 0 rows affected (0.07 sec)
mysql> FLUSH PRIVILEGES;
mysql> quit
成功啦!
下面詳細(xì)說說如何給用戶授權(quán)。
mysql> grant 權(quán)限1,權(quán)限2, ... 權(quán)限n on 數(shù)據(jù)庫名稱.表名稱 to 用戶名@用戶地址 identified by '連接口令';
權(quán)限1,權(quán)限2,... 權(quán)限n 代表 select、insert、update、delete、create、drop、index、alter、grant、references、reload、shutdown、process、file 等14個權(quán)限。
當(dāng)權(quán)限1,權(quán)限2,... 權(quán)限n 被 all privileges 或者 all 代替時,表示賦予用戶全部權(quán)限。
當(dāng) 數(shù)據(jù)庫名稱.表名稱 被 . 代替時,表示賦予用戶操作服務(wù)器上所有數(shù)據(jù)庫所有表的權(quán)限。
用戶地址可以是localhost,也可以是IP地址、機(jī)器名和域名。也可以用 '%' 表示從任何地址連接。
'連接口令' 不能為空,否則創(chuàng)建失敗。
舉幾個例子:
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分配可對數(shù)據(jù)庫vtdc的employee表進(jìn)行select,insert,update,delete,create,drop等操作的權(quán)限,并設(shè)定口令為123。
mysql> grant all privileges on vtdc.* to joe@10.163.225.87 identified by ‘123′;
給來自10.163.225.87的用戶joe分配可對數(shù)據(jù)庫vtdc所有表進(jìn)行所有操作的權(quán)限,并設(shè)定口令為123。
mysql> grant all privileges on *.* to joe@10.163.225.87 identified by ‘123′;
給來自10.163.225.87的用戶joe分配可對所有數(shù)據(jù)庫的所有表進(jìn)行所有操作的權(quán)限,并設(shè)定口令為123。
mysql> grant all privileges on *.* to joe@localhost identified by ‘123′;
給本機(jī)用戶joe分配可對所有數(shù)據(jù)庫的所有表進(jìn)行所有操作的權(quán)限,并設(shè)定口令為123。