1. 程式人生 > >mysql5.7忘記密碼時,修改root密碼

mysql5.7忘記密碼時,修改root密碼

忘記 strong localhost tab 正在 nbsp 啟動mysql log quit

(1).由於MySQL5.7在安裝完後,第一次啟動時,會在root目錄下生產一個隨機的密碼,文件名為 .mysql_secret
所以,登錄時需要用隨機密碼登錄,然後通過以下命令修改密碼
“SET PASSWORD = PASSWORD(‘new password’);”

(2). 在忘記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;  (別忘了最後加分號) 。
    7. 改密碼:update user set password=password("123") where user="root"; (別忘了最後加分號) 。 
    如果修改密碼出現 
    **mysql修改密碼錯誤 ERROR 1054 (42S22)**
    則使用 mysql>update mysql.user set authentication_string=password(‘123456‘) where user=‘root‘ and Host =‘localhost‘;

或者 update mysql.user set password=PASSWORD(‘123456’) where User=’root’;

    8. mysql>flush privileges;   #更新權限
    9. 退出 quit。 
    10. 註銷系統,再進入,
    輸入 mysql -u root -p
    使用用戶名root和剛才設置的新密碼123456登錄。 

(3). 知道root密碼的時候

方法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;

mysql5.7忘記密碼時,修改root密碼