mysql的密码放在user权限表的authentication_string字段中。user表是mysql中最重要的一个权限表,用来记录允许连接到服务器的账号信息;修改用户密码时,实际就是修改user表中authentication_string字段的值,语法为“set password for 'username'@'hostname'=password ('新密码')”。
本教程操作环境:windows7系统、mysql8版本、dell g3电脑。
mysql的密码放在user权限表的authentication_string字段中。
mysql user权限表的用户列
mysql 在安装时会自动创建一个名为 mysql 的数据库,mysql 数据库中存储的都是用户权限表。用户登录以后,mysql 会根据这些权限表的内容为每个用户赋予相应的权限。
user 表是 mysql 中最重要的一个权限表,用来记录允许连接到服务器的账号信息。需要注意的是,在 user 表里启用的所有权限都是全局级的,适用于所有数据库。
user 表中的字段大致可以分为 4 类,分别是用户列、权限列、安全列和资源控制列。
其中用户列存储了用户连接 mysql 数据库时需要输入的信息。
需要注意的是 mysql 5.7 版本不再使用 password 来作为密码的字段,而改成了 authentication_string。
mysql 用户列如表 1 所示。
表 1:user 表的用户列字段名字段类型是否为空默认值说明
host char(60) no 无 主机名
user char(32) no 无 用户名
authentication_string text yes 无 密码
用户登录时,如果这 3 个字段同时匹配,mysql 数据库系统才会允许其登录。创建新用户时,也是设置这 3 个字段的值。修改用户密码时,实际就是修改 user 表的 authentication_string 字段的值。因此,这 3 个字段决定了用户能否登录。
使用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 -penter password: ******welcome to the mysql monitor. commands end with ; or \g.your mysql connection id is 15server 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 itsaffiliates. other names may be trademarks of their respectiveowners. 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)
由运行结果可以看出,修改密码成功。
【相关推荐:mysql视频教程】
以上就是mysql的密码放在哪里的详细内容。