MySQL - SET PASSWORD 语句
MySQL 设置密码语句
您可以使用 MySQL 设置密码语句为现有用户设置密码。使用此功能,您可以:
- 为用户帐户设置特定密码。
- 设置随机密码。
- 用新密码替换当前密码。
- 保留当前密码作为辅助密码。
语法
以下是 MySQL SET PASSWORD 语句的语法:
SET PASSWORD [FOR user_name] new_password [REPLACE 'current_password_string'] [RETAIN CURRENT PASSWORD]
其中,user_name 是您需要更改密码的用户的名称。
示例
假设我们已经使用 CREATE USER 语句创建了一个名为 sample 的用户(无密码),如下所示 -
CREATE USER 'tp'@'localhost';
要以上述创建的用户身份登录,请打开命令提示符,浏览 MySQL 安装文件夹的 bin 文件夹,然后执行命令 mysql -u user_name -p as -
MySQL_Installation_Directorybin>mysql -u tp Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 35 Server version: 8.0.22 MySQL Community Server - GPL Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. MySQL SET PASSWORD Statement
现在您可以为当前用户帐户设置密码,如下所示 -
SET PASSWORD ='mypassword123';
为特定用户设置密码
您可以使用 SET PASSWORD 语句中的 FOR 子句为特定用户设置/分配密码 -
SET PASSWORD FOR user_name password_string
示例
假设我们已经使用 CREATE USER 语句创建了一个名为 test 的用户。
CREATE USER 'test'@'localhost';
以下查询为上面创建的用户分配密码 -
SET PASSWORD FOR 'test'@'localhost' = 'mypassword';
替换现有密码
您可以使用 REPLACE 子句和 SET PASSWORD 语句替换现有密码。
SET PASSWORD = new_password REPLACE old_password;
示例
假设我们使用 CREATE USER 语句创建了一个名为 test 的用户及其密码。
CREATE USER test@localhost IDENTIFIED BY 'test12345';
以上面创建的用户身份登录。(打开命令提示符,浏览 MySQL 安装文件夹的 bin 文件夹并执行以下查询)-
MySQL_Installation_Directorybin>mysql -u tp -p *********
以下查询将替换上述创建用户的密码 -
SET PASSWORD = 'newpassword' REPLACE 'test12345';
您只能对当前用户使用 REPLACE 语句
分配随机密码
您可以使用 RANDOM 子句和 SET PASSWORD 语句分配随机密码。
SET PASSWORD TO RANDOM;
示例
假设我们使用如下所示的 CREATE USER 语句创建了一个名为 sample 的用户(无密码)-
CREATE USER 'tp'@'localhost';
以下查询为上述创建的用户设置一个随机密码 -
SET PASSWORD FOR 'tp'@'localhost' TO RANDOM;
输出
以下是上述程序的输出 -
user | host | generated password |
---|---|---|
tp | localhost | hTWnSP:h0eAe(ywVJArm |