參考地址:https://www.cnblogs.com/yang82/p/7794712.html
mysql中修改用戶密碼的方式:
最簡單的方法就是借助第三方工具Navicat for MySQL來修改,方法如下:
1、登錄mysql到指定庫,如:登錄到test庫(還未實踐)
2、然后點擊上方“用戶”按鈕。
3、選擇要更改的用戶名,然后點擊上方的“編輯用戶”按鈕。
4、出現如圖界面,輸入新密碼,並確認新密碼,點擊“保存”按鈕即可。
第二種方式:
方法1: 用SET PASSWORD命令
首先登錄MySQL。
mysql -uroot -p
格式: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中的user表沒有password字段)
首先登錄MySQL。
mysql> use mysql;
mysql> update user set password=password('123') where user='root' and host='localhost';
mysql> flush privileges;
方法4:在忘記root密碼的時候,可以這樣
以windows為例:
1. 關閉正在運行的MySQL服務。 (net stop mysql)
2. 打開DOS窗口,轉到mysql\bin目錄(也可在環境變量PATH中設置有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";(別忘了最后加分號)
8. 刷新權限(必須步驟):flush privileges; (因為我的數據庫不能使用update來修改密碼,而且因為使用了mysqld --skip-grant-tables,所有也不能使用第一或第二種來進行)
9. 退出 quit。
10. 注銷系統,再進入,使用用戶名root和剛才設置的新密碼123登錄。
下面我將對第三種方式進行演示
前提:我已經在系統變量PATH中添加了路徑:
1.net stop mysql(關閉mysql服務)
2.mysqld --skip-grant-tables(啟動MySQL服務的時候跳過權限表認證)【注意輸入此命令之后命令行就無法操作了,此時可以再打開一個新的命令行。注意:在輸入此命令之前先在任務管理器中結束mysqld.exe進程,確保mysql服務器端已結束運行。】
3.重新以管理員身份打開另外一個cmd
4.然后輸入mysql
5.輸入flush privileges(刷新權限)
6.按第一個方法來修改密碼 set password for root@localhost = password('123456')
7.退出后再登錄 mysql -uroot -p123456,可成功登錄
8.