前言
最近很多新入職的同事問這個問題,特別是通過 homebrew 自動安裝的 mysql ,其版本默認已經(jīng)是 8.0 了,由于增加了一些安全策略等限制,所以修改用戶密碼會稍微麻煩些,索性就把這個總結(jié)貼一下吧。
下面話不多說了,來一起看看詳細的介紹吧
步驟如下:
1、首先查看 root 用戶相關信息,在 mysql 數(shù)據(jù)庫的 user 表中:
select host, user, authentication_string, plugin from user;
host:允許用戶登錄的ip‘位置'%表示可以遠程;
user:當前數(shù)據(jù)庫的用戶名;
authentication_string:用戶密碼;在mysql 5.7.9以后廢棄了password字段和password()函數(shù);
plugin:密碼加密方式;
如果發(fā)現(xiàn) root 用戶的 authentication_string 字段下有內(nèi)容,先將其設置為空:
use mysql;
update user set authentication_string='' where user='root';
2、重啟 mysql 服務,mac 里直接命令把服務關閉:
或者把 mysql 進程 kill 掉。然后在啟動 mysql 服務:
3、用 root 用戶登錄,因為已經(jīng)把 authentication_string 設置為空,所以可以免密碼登錄:
mysql -u root -p
passwrod:
不需要輸入密碼,直接回車即可
4、進入 mysql 庫,使用 ALTER 修改 root 用戶密碼:
ALTER user 'root' IDENTIFIED BY '123456' ;
語句中的 root 需要跟你實際 user 表里 root 用戶存的是 root 還是 root@localhost 而定,由于我這里把密碼改成了 123456 這樣比較簡單的格式,可能 mysql 8 默認密碼策略不允許,非要改的話可以先修改一下密碼策略:
set global validate_password.length = 6 ;
set global validate_password.policy = 'LOW';
FLUSH PRIVILEGES;
這里把密碼長度由默認的8位改成了6位,并且密碼策略級別由 MEDIUM 改成了 LOW。如果要查看密碼校驗相關設置的話可以直接查詢系統(tǒng)變量:
SHOW VARIABLES LIKE 'validate_password.%';
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
您可能感興趣的文章:- MySQL8.0.23版本的root密碼重置最優(yōu)解法
- Linux mysql-5.6如何實現(xiàn)重置root密碼
- 重置mysql的root密碼最簡單的方法
- 解決重置Mysql root用戶賬號密碼問題
- mysql8.0.12如何重置root密碼
- MySQL/MariaDB的Root密碼重置教程
- Mac MySQL重置Root密碼的教程
- windows下重置mysql的root密碼方法介紹
- lnmp重置mysql數(shù)據(jù)庫root密碼的兩種方法
- 詳解如何在Linux中重置MySQL或者MariaDB的root密碼
- CentOS下重置MySQL的root密碼的教程
- MySQL root密碼的重置方法