1. 程式人生 > >mysql5.7及mysql 8.0版本修改root密碼方式

mysql5.7及mysql 8.0版本修改root密碼方式

mysql5.7版本:

方法1: 用SET PASSWORD命令   

格式:mysql> set password for 使用者名稱@localhost = password('新密碼');  

例子:mysql> set password for [email protected] = password('123');  

 

mysql5.7和mysql8.0以上都可以用

方法2:用mysqladmin   

格式:mysqladmin -u使用者名稱 -p password 新密碼  

例子:mysqladmin -uroot -p password 123  

mysql5.7版本

方法3:用UPDATE直接編輯user表   

mysql> use mysql;  

mysql> update user set password=password('123') where user='root' and host='localhost';  

mysql> flush privileges;  

 

mysql 5.7和mysql8.0及以上

方法4:使用alter,使用這個有一個坑,很多部落格說可以使用下面的方式修改,但是一直不成功:

alter user 'root'@'localhost' IDENTIFIED BY 'liuhehe';
報錯:
ERROR 1396 (HY000): Operation ALTER USER failed for 'root'@'localhost'

後來到user表中檢視到user='root'的記錄,發現host列的值是'%',將上面的sql修改成

mysql> alter user 'root'@'%' IDENTIFIED BY 'liuhehe';
Query OK, 0 rows affected (0.03 sec)
執行成功!!

下面的方法,僅用於mysql5.7版本

方法4:忘記root密碼時

以windows為例:   

1. 關閉正在執行的MySQL服務。  

2. 開啟DOS視窗,轉到mysql\bin目錄。  

3. 輸入mysqld --skip-grant-tables 回車。--skip-grant-tables 的意思是啟動MySQL服務的時候跳過許可權表認證。  

4. 再開一個DOS視窗(因為剛才那個DOS視窗已經不能動了),轉到mysql\bin目錄。  

5. 輸入mysql回車,如果成功,將出現MySQL提示符 >。  

6. 連線許可權資料庫: use mysql; 。  

6. 改密碼:update user set password=password("123") where user="root";(別忘了最後加分號) 。  

7. 重新整理許可權(必須步驟):flush privileges; 。  

8. 退出 quit。  

9. 登出系統,再進入,使用使用者名稱root和剛才設定的新密碼123登入。

注意:5.7版本下的mysql資料庫下已經沒有password這個欄位了,password欄位改成了

authentication_string。
 

講真的,mysql8的版本跟之前版本,差距真的大,用之前的命令,各種提示提示語法錯誤。。我自找的,唉!