Mysql如何修改用户密码

本文详细介绍了四种重置MySQL数据库root密码的方法,包括使用SETPASSWORD命令、mysqladmin工具、直接更新user表以及在忘记密码时的特殊处理流程。每种方法都提供了具体的操作步骤和示例。

原文链接:https://www.cnblogs.com/qianzf/p/7089197.html?tdsourcetag=s_pcqq_aiomsg

方法1: 用SET PASSWORD命令
首先登录MySQL。
格式:mysql> set password for 用户名@localhost = password(‘新密码’);
例子:mysql> set password for root@localhost = password(‘123’);

方法2:用mysqladmin
格式:mysqladmin -u用户名 -p旧密码 password 新密码
例子:mysqladmin -uroot -p123456 password 123

方法3:用UPDATE直接编辑user表
首先登录MySQL。
mysql> use mysql;
mysql> update user set password=password(‘123’) where user=‘root’ and host=‘localhost’;
mysql> flush privileges;

方法4:在忘记root密码的时候,可以这样
以windows为例:

  1. 关闭正在运行的MySQL服务。
  2. 打开DOS窗口,转到mysql\bin目录。
  3. 输入mysqld --skip-grant-tables 回车。–skip-grant-tables 的意思是启动MySQL服务的时候跳过权限表认证。
  4. 再开一个DOS窗口(因为刚才那个DOS窗口已经不能动了),转到mysql\bin目录。
  5. 输入mysql回车,如果成功,将出现MySQL提示符 >。
  6. 连接权限数据库: use mysql; 。
  7. 改密码:update user set password=password(“123”) where user=“root”;(别忘了最后加分号) 。
  8. 刷新权限(必须步骤):flush privileges; 。
  9. 退出 quit。
  10. 注销系统,再进入,使用用户名root和刚才设置的新密码123登录。
MySQL提供了多种修改用户密码的方法,以下为详细介绍: 1. **使用UPDATE语句**:使用UPDATE语句更新mysql数据库的user表,执行后还需执行FLUSH PRIVILEGES语句从授权表重新加载权限。例如,要更改从localhost主机连接的dbadmin用户密码为newpasswd,可执行相应语句。不过在MySQL8.0版本中,user表取消了password字段,使用authentication_string字段表示用户密码,且该字段下只能是mysql加密后的41位字符串密码。具体操作示例为: ```sql UPDATE mysql.user SET authentication_string = PASSWORD('newpasswd') WHERE user = 'dbadmin' AND host = 'localhost'; FLUSH PRIVILEGES; ``` 2. **使用ALTER USER语句(适用于MySQL8.0及以上版本)**:可直接使用ALTER USER语句修改用户密码,之后使用FLUSH PRIVILEGES刷新权限。示例如下: ```sql ALTER USER 'username'@'hostname' IDENTIFIED BY 'password'; FLUSH PRIVILEGES; ``` 3. **使用SET PASSWORD语句**:登录MySQL后,使用SET PASSWORD语句为指定用户设置新密码。示例: ```sql SET PASSWORD FOR root@localhost = PASSWORD('123'); ``` 4. **使用mysqladmin工具**:使用mysqladmin命令修改密码,需要提供用户名、旧密码密码。示例: ```bash mysqladmin -uroot -p123456 password 123 ``` 5. **忘记root密码时的修改方法(以Windows为例)**: - 关闭正在运行的MySQL服务。 - 打开DOS窗口,转到mysql\bin目录。 - 输入`mysqld --skip-grant-tables`回车,此参数表示启动MySQL服务时跳过权限表认证。 - 再开一个DOS窗口,转到mysql\bin目录。 - 输入`mysql`回车,若成功将出现MySQL提示符`>`。 - 连接权限数据库:`USE mysql;` - 改密码:`UPDATE user SET authentication_string = PASSWORD('123') WHERE user = 'root';` - 刷新权限(必须步骤):`FLUSH PRIVILEGES;` - 退出`quit`。 - 注销系统,再进入,使用用户名root刚才设置的新密码123登录。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值