修改mysql数据库密码(两种方式已知密码或者忘记密码)

知道密码,修改mysql数据库密码

  1. 使用 set password 命令修改密码;
set password for root@localhost = password('新密码')

在这里插入图片描述

  1. 用mysqladmin 命令修改密码;
    mysqladmin -u用户名 -p旧密码 password 新密码
    命令在命令行中运行:
mysqladmin -uroot -p123 password 123456

在这里插入图片描述
验证:
在这里插入图片描述

  1. 直接修改mysql数据库中的user表的authentication_string列,因为用户信息存储在user表中;
mysql> use mysql
mysql> update user set authentication_string=password('新密码') where user='用户名' and host='localhost';
# 刷新用户权限
mysql> flush privileges;

在这里插入图片描述
重新登录界面:
在这里插入图片描述
注意:如果mysql版本为5.7以下,数据库user表中密码字段是password,所以将
authentication_string改为password
我的数据库版本为5.7,使用password报错。
在这里插入图片描述

忘记root密码,修改mysql数据库密码

  • windows系统下
  1. 关闭电脑上的mysql服务
    在这里插入图片描述
  2. 用键盘输入win+R,打开DOS窗口,使用cd命令跳转到mysql\bin目录;
    在这里插入图片描述
  3. 在DOS命令行输入mysqld --skip-grant-tables 回车。其中**–skip-grant-tables** 是启动MySQL服务的时候跳过权限表认证,即不用输入密码进入mysql;
    在这里插入图片描述
  4. 重新再打开一个DOS窗口(因为刚才那个DOS窗口已经不能动了)注意不能关闭,使用cd命令跳转到mysql\bin目录,输入mysql回车,如果成功,将出现MySQL提示符 >;
    在这里插入图片描述
  5. 连接系统自带权限数据库mysql,并且修改数据库中user表的authentication_string列;
mysql> use mysql
Database changed
mysql> update user set authentication_string=password('123456') where user='root
' and host='localhost';
Query OK, 1 row affected, 1 warning (0.02 sec)
Rows matched: 1  Changed: 1  Warnings: 1

mysql> flush privileges;
Query OK, 0 rows affected (0.16 sec)
  1. 退出mysql,重新打开mysql服务,使用用户名root和刚才设置的新密码123456登录,验证。
    在这里插入图片描述
    在这里插入图片描述
    注意:验证的时候不要忘记重新启动服务。
<think>嗯,用户想了解如何为本地MySQL数据库设置密码。首先,我需要回忆一下相关的知识,然后结合提供的引用内容来组织答案。 根据引用[1],提到在命令行使用mysqladmin命令来更改密码,例如在DOS或Linux的MySQL的bin目录下执行命令。但用户可能需要先有权限才能这样做。另外,引用[2]和[3]、[4]、[5]提到当忘记密码时,需要停止MySQL服务,进入安全模式或者修改配置文件跳过权限验证,然后更新密码字段。不过用户的问题是关于设置密码,而不是重置,但可能需要涵盖初始设置和修改两种情况。 首先,我应该分步骤说明不同情况下的密码设置方法。比如初始安装后的密码设置,以及修改现有密码的方法。同时,需要注意不同MySQL版本的差异,比如在5.7及以上版本中,password字段改为authentication_string,这会影响SQL语句的写法,如引用[4]和[5]所述。 然后,是否需要包括忘记密码的情况?用户的问题可能隐含了忘记密码后的处理,但主要问题是如何设置密码。不过可能需要简要提到,或者放在相关问题的部分。 接下来,考虑操作系统的不同,比如Windows和Mac的步骤是否不同。例如,引用[2]是针对Mac的步骤,停止服务的方法可能与Windows不同。需要分开说明。 另外,命令行方法和使用SQL语句直接修改的方法都需要涵盖。比如使用mysqladmin命令是一种方式,而进入MySQL后使用ALTER USER或UPDATE语句是另一种方式,尤其是在忘记密码的情况下需要后一种方法。 可能的结构: 1. 初始安装后设置密码 2. 已知密码修改密码 3. 忘记密码时的重置方法 需要确保每个步骤清晰,命令正确,并注明版本差异,比如MySQL 5.7前后的不同处理方式。 还要检查引用是否正确。例如,引用[3]提到将authentication_string设置为空,但设置密码时应该使用更安全的方法,比如ALTER USER或者带加密的UPDATE语句。 最后,生成相关问题,比如如何加强密码安全、忘记密码怎么办、不同版本的差异等,根据用户提供的示例问题结构来设计。</think>### 如何为本地 MySQL 数据库设置密码? #### 1. **已知当前密码修改密码** - **方法一:使用 `mysqladmin` 命令** 在命令行中执行以下命令(需替换 `新密码` 为实际密码): ```bash mysqladmin -u root -p password 新密码 ``` 输入原密码后完成修改。此方法适用于所有操作系统[^1]。 - **方法二:通过 SQL 语句修改** 登录 MySQL 后执行: ```sql ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码'; ``` 适用于 MySQL 5.7 及以上版本(注意字段名为 `authentication_string`)[^4][^5]。 --- #### 2. **首次安装或未设置密码** - **Windows 系统** 1. 安装 MySQL 后,在命令行中初始化密码: ```bash mysqld --initialize --console ``` 生成的临时密码会显示在输出中,首次登录后需立即修改。 - **Mac/Linux 系统** 1. 停止 MySQL 服务: ```bash sudo systemctl stop mysql ``` 2. 启动无密码安全模式: ```bash mysqld_safe --skip-grant-tables & ``` 3. 登录并修改密码(参考步骤 1 的 SQL 语句)[^2][^3]。 --- #### 3. **忘记密码时重置** 1. **停止 MySQL 服务** - Windows:通过服务管理器停止 - Mac/Linux: ```bash sudo systemctl stop mysql ``` 2. **启动无权限验证模式** ```bash mysqld_safe --skip-grant-tables & ``` 3. **登录并清空密码字段** ```sql UPDATE mysql.user SET authentication_string='' WHERE user='root'; FLUSH PRIVILEGES; ``` 4. **重启服务并设置新密码** 重新登录后使用 `ALTER USER` 语句设置密码[^3][^4]。 --- ### 注意事项 - **MySQL 版本差异**:5.7 及以上版本使用 `authentication_string` 字段代替 `password`,操作时需注意语法[^4]。 - **密码复杂度**:建议使用包含大小写字母、数字和符号的组合。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值