如何快速修改MySQL用戶的host屬性
當你遠程登錄MySQL時,使用的賬號要有特殊要求。
默認的賬號的host屬性都是localhost,意思是這個賬號只能本地使用,如果要使用某個賬號來遠程登錄,必須將賬號的host屬性值更改成%。
執(zhí)行的sql語句如下:
update user set host = '%' where user = 'root';
補充:mysql 修改root密碼 修改賬戶登錄host
1.忘了root密碼
遠程服務器起了一個mysql服務,里面有個hive賬戶,在遠程服務器能通過命令行用mysql -hlocalhost -uxxx -pxxx的方式登錄,但是用navicat客戶端,怎么也登錄不上,而且navicat顯示的還是我自己機器的ip地址。
初步懷疑,是mysql里的A賬戶密碼沒有設置正確。于是需要用root賬號對hive賬戶重新進行設置。
坑爹的是,mysql也不是我布的。而且測試環(huán)境,也不知道該找誰要密碼。那就使出終極武器吧:修改root密碼。
2.重置mysql root密碼。
首先注意的一點:mysql的root賬戶與服務器的root賬戶不是同一個概念,不要混為一談。
首先,停掉mysql服務:
sudo service mysql stop
如果有服務器的root賬戶,自然就不用sudo了,下面所有的操作也是一樣。上面的命令適用于Ubuntu和Debian。CentOS、Fedora和RHEL下使用mysqld替換mysql。下面所有的操作也是一樣。
然后,再以安全模式啟動mysql:
sudo mysqld_safe --skip-grant-tables --skip-networking &
這樣我們就可以直接用root登錄,無需密碼:
mysql -u root
這樣,我們就用root賬戶登錄了mysql。
然后,就可以重置root密碼了:
mysql> use mysql;
mysql> update user set password=PASSWORD("mynewpassword") where User='root';
mysql> flush privileges; 重置完畢以后,退出mysql。然后再將mysql服務啟動:
sudo service mysql restart
接下來,就是用root賬戶登錄了:
mysql -u root -pmynewpassword
3.修改A賬戶相關權限
用root賬號登錄mysql以后,接下來看看A賬號的相關信息:
mysql> use mysql; Database changed mysql> select User, Host from user where User='hive'; +------+--------------+ | User | Host | +------+--------------+ | hive | 127.0.0.1 | +------+--------------+
這一下就明白了。難怪navicat客戶端登不了。hive賬戶的host只有127.0.0.1,自然只能在本機登錄了。
mysql> update user set Host='%' where User='hive';
將hive賬戶設置為所有機器均可登錄,然后再刷新一下權限:
mysql> flush privileges;
再查看一把:
mysql> select User, Host from user where User='hive'; +------+------+ | User | Host | +------+------+ | hive | % | +------+------+
至此為止,大功告成!
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關文章
mysql利用group_concat()合并多行數據到一行
把查詢name字段得到的多行記錄進行合并,可以通過程序實現(xiàn),但也可直接在sql層完成,需要的朋友可以參考下2014-07-07
MySQL 8.0 之索引跳躍掃描(Index Skip Scan)
這篇文章主要介紹了MySQL 8.0 之索引跳躍掃描(Index Skip Scan)的相關資料,幫助大家學習MySQL8.0的新特性,感興趣的朋友可以了解下2020-10-10
阿里云centos7使用yum安裝mysql的正確姿勢(推薦)
這篇文章主要介紹了阿里云centos7使用yum安裝mysql的正確姿勢,需要的朋友可以參考下2017-07-07

