MySQL和其他數據庫一樣,出於對安全的考慮,對不同的用戶授予不同的權限。下文介紹的是一些MySQL修改密碼的方法,供您參考。
首先要說明一點的是:一般情況下,MySQL修改密碼是需要有mysql裡的root權限的,這樣一般用戶是無法實現MySQL修改密碼的,除非請求管理員幫助修改。
MySQL修改密碼的方法:
方法一
使用phpMyAdmin (圖形化管理MySql數據庫的工具),這是最簡單的,直接用SQL語句修改mysql數據庫庫的user表,不過別忘了使用PASSWORD函數,插入 用戶用Insert命令,修改用戶用Update命令,刪除用Delete命令。在本節後面有數據表user字段的詳細介紹。
方法二
使用mysqladmin。輸入mysqladmin -u root -p oldpassword newpasswd執行這個命令後,需要輸入root的原密碼,這樣root的密碼將改為newpasswd。同樣,把命令裡的 root改為你的用戶名,你就可以改你自己的密碼了。 當然如果你的mysqladmin連接不上mysql server,或者你沒有辦法執行mysqladmin,那麼這種方法就是無效的,而且mysqladmin無法把密碼清空。下面的方法都在mysql提示符下使用,且必須有mysql的root權限。
方法三
mysql> INSERT INTO mysql.user (Host,User,Password) VALUES (\'%\',\'system\', PASSWORD(\'manager\'));
mysql> FLUSH PRIVILEGES確切地說這是在增加一個用戶,用戶名為system,密碼為manager。注意要使用PASSWORD函數,然後還要使用FLUSH PRIVILEGES來執行確認。
方法四
和方法三一樣,只是使用了REPLACE語句mysql> REPLACE INTO mysql.user (Host,User,Password)
VALUES(\'%\',\'system\',PASSWORD(\'manager\'));
mysql> FLUSH PRIVILEGES
方法五
使用SET PASSWORD語句mysql> SET PASSWORD FOR system@\"%\" = PASSWORD(\'manager\');你也必須使用PASSWORD()函數,但是不需要使用FLUSH PRIVILEGES來執行確認。
方法六
使用GRANT ... IDENTIFIED BY語句,來進行授權。mysql> GRANT USAGE ON *.* TO system@\"%\" IDENTIFIED BY \'manager\';這裡PASSWORD()函數是不必要的,也不需要使用FLUSH PRIVILEGES來執行確認。注:PASSWORD()函數作用是為口令字加密,在程序中MySql自動解釋。
以上就是MySQL修改密碼的方法介紹。
linux下的常用mysql命令
九種常用mysql命令
Mysql User表權限字段說明全介紹
MySQL自增字段的常用語句
Mysql設置字符編碼的方法