2

パスワードをリセットするためのMysqlデータベースの簡単なクエリはどのように見えるでしょうか

私のサンプルコードがありますが、動作せず、動作させる方法がわかりません

SELECT `User`, `Host`, Length(`Password`) FROM mysql.user
UPDATE mysql.user SET Password = PASSWORD('password') WHERE user = 'username';

そしてそれはうまくいきません。

4

2 に答える 2

3

選択する必要はありません。更新のみ。

update mysql.user set password=PASSWORD("NEW-PASSWORD-HERE") where User='USER';

問題は、select ステートメントの後にセミコロンがないことが原因である可能性があります。

于 2012-05-22T17:18:58.573 に答える
3

これを試して:

SET PASSWORD FOR 'USER'@'HOST' = PASSWORD('PASSWORD');

または、テーブルを直接更新する場合は、特権をフラッシュすることを忘れないでください。

UPDATE mysql.user SET Password = PASSWORD('PASSWORD') 
 WHERE user = 'USERNAME' AND Host='HOST';
FLUSH PRIVILEGES;

最後に、GRANT を使用する 3 番目の方法があります。

GRANT USAGE ON *.* TO 'USER'@'HOST' IDENTIFIED BY 'PASSWORD';

参考:MySQL 5.7 マニュアル

于 2013-07-30T16:35:49.790 に答える