2022年

2022年发布的文章
  • MySQL root修改普通用户密码

    在 MySQL 中,root 用户拥有很高的权限,不仅可以修改自己的密码,还可以修改其他用户的密码。本节主要介绍 root 用户修改普通用户密码的几种方法。

    使用SET语句修改普通用户的密码

    在 MySQL 中,只有 root 用户可以通过更新 MySQL 数据库来更改密码。使用 root 用户登录到 MySQL 服务器后,可以使用 SET 语句来修改普通用户密码。语法格式如下:

    SET PASSWORD FOR 'username'@'hostname' = PASSWORD ('newpwd');

    其中,username 参数是普通用户的用户名,hostname 参数是普通用户的主机名,newpwd 是要更改的新密码。

    注意:新密码必须使用 PASSWORD() 函数来加密,如果不使用 PASSWORD() 加密,也会执行成功,但是用户会无法登录。

    如果是普通用户修改密码,可省略 FOR 子句来更改自己的密码。语法格式如下:

    SET PASSWORD = PASSWORD('newpwd');

    示例 1

    首先创建一个没有密码的 testuser 用户,SQL 语句和运行结果如下:

    mysql> CREATE USER 'testuser'@'localhost';
    Query OK, 0 rows affected (0.14 sec)

    root 用户登录 MySQL 服务器后,再使用 SET 语句将 testuser 用户的密码修改为“newpwd”,SQL 语句和运行结果如下:

    mysql> SET PASSWORD FOR 'testuser'@'localhost' = PASSWORD("newpwd");
    Query OK, 0 rows affected, 1 warning (0.01 sec)

    由运行结果可以看出,SET 语句执行成功,testuser 用户的密码被成功设置为“newpwd”。

    下面验证 testuser 用户密码是否修改成功。退出 MySQL 服务器,使用 testuser 用户登录,输入密码“newpwd”,SQL 语句和运行结果如下:

    C:\Users\leovo>mysql -utestuser -p
    Enter password: ******
    Welcome to the MySQL monitor.  Commands end with ; or \g.
    Your MySQL connection id is 15
    Server version: 5.7.29-log 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.

    由运行结果可以看出,testuser 用户登录成功,修改密码成功。

    示例 2

    使用 testuser 用户登录 MySQL 服务器,再使用 SET 语句将密码更改为“newpwd1”,SQL 语句和运行结果如下所示:

    mysql> SET PASSWORD = PASSWORD('newpwd1');
    Query OK, 0 rows affected, 1 warning (0.00 sec)

    由运行结果可以看出,修改密码成功。

    使用UPDATE语句修改普通用户的密码

    使用 root 用户登录 MySQL 服务器后,可以使用 UPDATE 语句修改 MySQL 数据库的 user 表的 authentication_string 字段,从而修改普通用户的密码。UPDATA 语句的语法如下:

    UPDATE MySQL.user SET authentication_string = PASSWORD("newpwd") WHERE User = "username" AND Host = "hostname";

    其中,username 参数是普通用户的用户名,hostname 参数是普通用户的主机名,newpwd 是要更改的新密码。

    注意,执行 UPDATE 语句后,需要执行 FLUSH PRIVILEGES 语句重新加载用户权限。

    示例 3

    使用 root 用户登录 MySQL 服务器,再使用 UPDATE 语句将 testuser 用户的密码修改为“newpwd2”的 SQL 语句和运行结果如下:

    mysql> UPDATE MySQL.user SET authentication_string = PASSWORD ("newpwd2")
        -> WHERE User = "testuser" AND Host = "localhost";
    Query OK, 1 row affected, 1 warning (0.07 sec)
    Rows matched: 1  Changed: 1  Warnings: 1
    mysql> FLUSH PRIVILEGES;
    Query OK, 0 rows affected (0.03 sec)

    由运行结果可以看出,密码修改成功。testuser 的密码被修改成了 newpwd2。使用 FLUSH PRIVILEGES 重新加载权限后,就可以使用新的密码登录 testuser 用户了。

    使用 GRANT 语句修改普通用户密码

    除了前面介绍的方法,还可以在全局级别使用 GRANT USAGE 语句指定某个账户的密码而不影响账户当前的权限。需要注意的是,使用 GRANT 语句修改密码,必须拥有 GRANT 权限。一般情况下最好使用该方法来指定或修改密码。语法格式如下:

    GRANT USAGE ON *.* TO 'user'@’hostname’ IDENTIFIED BY 'newpwd';

    其中,username 参数是普通用户的用户名,hostname 参数是普通用户的主机名,newpwd 是要更改的新密码。

    示例 4

    使用 root 用户登录 MySQL 服务器,再使用 GRANT 语句将 testuser 用户的密码修改为“newpwd3”,SQL 语句和运行结果如下:

    mysql> GRANT USAGE ON *.* TO 'testuser'@'localhost' IDENTIFIED BY 'newpwd3';
    Query OK, 0 rows affected, 1 warning (0.05 sec)

    由运行结果可以看出,密码修改成功。

更多...

加载中...