mysql8 修改root 账号密码

本文介绍了如何在MySQL中成功地为用户 'user' 设置密码,通过ALTER USER语句实现,适合数据库管理员快速操作。

亲测有效

mysql> alter user user() identified by 'xxx'
    -> ;
Query OK, 0 rows affected (0.01 sec)

mysql>

MySQL 8.0 中修改 `root` 用户密码的方法与早期版本有所不同,主要原因是 MySQL 8.0 引入了新的默认认证插件 `caching_sha2_password`,并且不再推荐使用 `password()` 函数来设置密码。以下是适用于 MySQL 8.0 的修改 `root` 用户密码的几种方法。 ### 使用 `ALTER USER` 命令修改密码 `ALTER USER` 是 MySQL 8.0 推荐的方式,用于修改用户密码。执行该命令前,需要确保当前用户具有足够的权限(如 `SUPER` 权限)。 ```sql ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_password'; ``` 该命令会直接修改 `root` 用户的密码为 `new_password`,并自动使用当前用户的认证插件进行加密处理。如果需要确保兼容性,可先检查 `root` 用户使用的认证插件: ```sql SELECT User, Host, plugin FROM mysql.user WHERE User = 'root'; ``` 如果插件为 `caching_sha2_password`,则新密码将使用该插件进行加密;如果希望使用 `mysql_native_password` 插件,可先修改插件类型[^2]。 ### 使用 `SET PASSWORD` 命令修改密码 `SET PASSWORD` 是另一种修改密码的方式,适用于当前登录的用户或指定用户: ```sql SET PASSWORD FOR 'root'@'localhost' = 'new_password'; ``` 此命令同样会根据当前用户的认证插件对密码进行加密处理,无需手动调用 `PASSWORD()` 函数[^1]。 ### 忘记密码时的恢复方法 如果忘记了 `root` 用户的密码,可以通过跳过权限验证的方式进入 MySQL 并重置密码。具体步骤如下: 1. 在配置文件 `mysqld.cnf` 中添加 `skip-grant-tables` 以跳过权限检查: ```bash sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf ``` 在 `[mysqld]` 段中添加: ```ini skip-grant-tables ``` 2. 重启 MySQL 服务: ```bash sudo service mysql restart ``` 3. 登录 MySQL修改密码: ```sql USE mysql; UPDATE user SET authentication_string = '' WHERE User = 'root'; UPDATE user SET plugin = 'mysql_native_password' WHERE User = 'root'; FLUSH PRIVILEGES; ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_password'; ``` 4. 重启 MySQL 服务以恢复正常运行: ```bash sudo service mysql restart ``` 此方法适用于紧急恢复场景,但不建议在生产环境中长期使用。 ### 注意事项 - 修改密码后,建议检查用户的认证插件是否与客户端兼容,特别是使用旧版本客户端连接时。 - 在生产环境中,应避免使用 `skip-grant-tables` 等方式修改密码,以防止安全风险。 - 所有密码修改操作完成后,应立即执行 `FLUSH PRIVILEGES;` 以确保更改生效。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值