MySQL登錄時(shí)出現(xiàn) Access denied for user ‘root‘@‘xxx.xxx.xxx.xxx‘ (using password: YES) 的原因及解決辦法
場(chǎng)景一:調(diào)試web程序訪問(wèn)數(shù)據(jù)庫(kù)的時(shí)候出現(xiàn)
場(chǎng)景二:MySQL登陸的時(shí)候,區(qū)分本地localhost登陸,以及遠(yuǎn)程登陸。即使本地能夠登陸,如果不授權(quán)也無(wú)法遠(yuǎn)程登陸
分析原因:(區(qū)分)當(dāng)本地出現(xiàn)這樣的情況,就是密碼錯(cuò)誤,找到正確的密碼或者修改密碼;當(dāng)遠(yuǎn)程登陸的時(shí)候,首先確定登陸密碼是否正確,第二確定是否遠(yuǎn)程授權(quán)。針對(duì)以上兩種情況,給出解決方案。
情況一解決方案:修改本地?cái)?shù)據(jù)庫(kù)密碼
方法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密碼的時(shí)候,可以這樣
以windows為例:關(guān)閉正在運(yùn)行的MySQL服務(wù)。
打開(kāi)DOS窗口,轉(zhuǎn)到mysql\bin目錄。
輸入mysqld --skip-grant-tables 回車。--skip-grant-tables 的意思是啟動(dòng)MySQL服務(wù)的時(shí)候跳過(guò)權(quán)限表認(rèn)證。
再開(kāi)一個(gè)DOS窗口(因?yàn)閯偛拍莻€(gè)DOS窗口已經(jīng)不能動(dòng)了),轉(zhuǎn)到mysql\bin目錄。
輸入mysql回車,如果成功,將出現(xiàn)MySQL提示符 >。
連接權(quán)限數(shù)據(jù)庫(kù): use mysql; 。
改密碼:update user set password=password("123") where user="root";(別忘了最后加分號(hào)) 。
刷新權(quán)限(必須步驟):flush privileges;
退出 quit。
注銷系統(tǒng),再進(jìn)入,使用用戶名root和剛才設(shè)置的新密碼123登錄。
情況二解決方案 :遠(yuǎn)程授權(quán)
1. 先用localhost登錄(進(jìn)入MySQL) mysql -u root -p
Enter password: (輸入密碼)
2. 執(zhí)行授權(quán)命令
mysql> grant all privileges on . to root@'%' identified by '123'; (注意語(yǔ)句后面的“;”)
Query OK, 0 rows affected (0.07 sec)
3. 退出再試: mysql> quit
4、再試登錄: mysql -u root -h 192.168.194.142 -p
Enter password:
結(jié)果顯示:Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 3
表示成功
下面詳細(xì)說(shuō)說(shuō)如何給用戶授權(quán)
mysql> grant 權(quán)限1,權(quán)限2, ... 權(quán)限n on 數(shù)據(jù)庫(kù)名稱.表名稱 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個(gè)權(quán)限。
當(dāng)權(quán)限1,權(quán)限2,... 權(quán)限n 被 all privileges 或者 all 代替時(shí),表示賦予用戶全部權(quán)限。
當(dāng) 數(shù)據(jù)庫(kù)名稱.表名稱 被 . 代替時(shí),表示賦予用戶操作服務(wù)器上所有數(shù)據(jù)庫(kù)所有表的權(quán)限。
用戶地址可以是localhost,也可以是IP地址、機(jī)器名和域名。也可以用 '%' 表示從任何地址連接。
'連接口令' 不能為空,否則創(chuàng)建失敗。
舉幾個(gè)例子:
mysql> grant select,insert,update,delete,create,drop on vtdc.employee to joe@10.163.225.87 identified by ‘123′;
給來(lái)自10.163.225.87的用戶joe分配可對(duì)數(shù)據(jù)庫(kù)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′;
給來(lái)自10.163.225.87的用戶joe分配可對(duì)數(shù)據(jù)庫(kù)vtdc所有表進(jìn)行所有操作的權(quán)限,并設(shè)定口令為123。
mysql> grant all privileges on . to joe@10.163.225.87 identified by ‘123′;
給來(lái)自10.163.225.87的用戶joe分配可對(duì)所有數(shù)據(jù)庫(kù)的所有表進(jìn)行所有操作的權(quán)限,并設(shè)定口令為123。
mysql> grant all privileges on . to joe@localhost identified by ‘123′;
給本機(jī)用戶joe分配可對(duì)所有數(shù)據(jù)庫(kù)的所有表進(jìn)行所有操作的權(quán)限,并設(shè)定口令為123。案:遠(yuǎn)程授權(quán)
到此這篇關(guān)于MySQL登錄時(shí)出現(xiàn) Access denied for user ‘root‘@‘xxx.xxx.xxx.xxx‘ (using password: YES) 的原因及解決辦法的文章就介紹到這了,更多相關(guān)MySQL Access denied for user內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用phpMyAdmin批量修改Mysql數(shù)據(jù)表前綴的方法
這篇文章主要介紹了使用phpMyAdmin批量修改Mysql數(shù)據(jù)表前綴的方法,需要的朋友可以參考下2015-09-09MySQL悲觀鎖與樂(lè)觀鎖的實(shí)現(xiàn)方案
我們知道Mysql并發(fā)事務(wù)會(huì)引起更新丟失問(wèn)題,解決辦法是鎖,所以本文將對(duì)鎖(樂(lè)觀鎖、悲觀鎖)進(jìn)行分析,這篇文章主要給大家介紹了關(guān)于MySQL悲觀鎖與樂(lè)觀鎖方案的相關(guān)資料,需要的朋友可以參考下2021-11-11MySQL 數(shù)據(jù)庫(kù) ALTER命令講解
MySQL 為關(guān)系型數(shù)據(jù)庫(kù)(Relational Database Management System)。本文重點(diǎn)給大家介紹mysql數(shù)據(jù)庫(kù)alert命令講解,本文介紹的非常詳細(xì),具有參考借鑒價(jià)值,感興趣的朋友一起學(xué)習(xí)吧2016-05-05詳解遠(yuǎn)程連接Mysql數(shù)據(jù)庫(kù)的問(wèn)題(ERROR 2003 (HY000))
本篇文章是對(duì)遠(yuǎn)程連接Mysql數(shù)據(jù)庫(kù)的問(wèn)題進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06MySQL中表復(fù)制:create table like 與 create table as select
這篇文章主要介紹了MySQL中表復(fù)制:create table like 與 create table as select,需要的朋友可以參考下2014-12-12MySQL之Innodb_buffer_pool_size設(shè)置方式
這篇文章主要介紹了MySQL之Innodb_buffer_pool_size設(shè)置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08mysql查詢本周內(nèi)每天統(tǒng)計(jì)量按天展示的示例代碼
本文主要介紹了mysql查詢本周內(nèi)每天統(tǒng)計(jì)量按天展示的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05