解决mysql报错You must reset your password using ALTER USER statement before executing this statement问题

 更新时间:2024年11月21日 15:47:40   作者:蜗牛去旅行吧  
文章介绍了在Linux系统中解决MySQL 5.7及以上版本root用户密码过期无法登录的问题方法,以及如何处理系统权限表mysql.user结构错误的问题

mysql报错You must reset your password using ALTER USER statement before executing this statement

在 linux 中安装好 MySQL 并完成初始化配置后,使用默认生成的 root 用户密码登录 MySQL 时,可能会出现无法执行任何语句的情况

提示:

「You must reset your password using ALTER USER statement before executing this statement」

这是因为 MySQL 5.7 版本后,用户表的密码字段由 password 改为了 authentication_string,同时增加了一个 password_expired 字段来标识密码是否过期。

对于 root 用户密码过期的情况

通过以下步骤来修改root用户的密码

1. 停止所有的 MySQL 进程。使用命令 `service mysql stop` 或 `killall mysql` 

2. 使用无验证模式启动 MySQL。执行命令 `mysqld_safe --skip-grant-tables`

3. 使用 MySQL 客户端登录无需密码。此时可以执行任何语句。

4. 检查用户表,使用 `select * from mysql.user;`来查看用户详情。

5. 修改 root 用户的密码到期标识和密码。

6. 使用语句:

`update mysql.user set authentication_string=password('yourpassword'), password_expired='N' where user='root';` 

执行 `flush privileges;`刷新 privileges 表。

查看结果

select authentication_string,password_expired from user where user='root';

8. 重新使用正常模式启动 MySQL 服务。执行 `service mysql start`

9. 使用新设置的 root 密码登录 MySQL 客户端进行操作。

以上步骤可以很方便地解决 MySQL 中 root 密码过期无法登录的问题。

重置密码后需要更新整个项目中的连接配置,以确保正常访问数据库。

也可以调整my.cnf

#设置密码过期时间为120天,设为0表示不过期
#default_password_lifetime = 120
default_password_lifetime = 0
#修改密码强度策略,0为低策略
#validate_password_policy=0
#修改密码长度
#validate_password_length=5
#跳过密码校验,无密码登录
#skip-grant-tables

其他报错处理:

ERROR 1805 (HY000): Column count of mysql.user is wrong. Expected 45, found 46. The table is probably corrupted

这个错误表示MySQL的系统权限表mysql.user结构与MySQL服务器预期的不匹配,可能是由于不兼容的升级或错误的操作导致该系统表被破坏。

解决方案有以下几种

1.尝试用mysqld自带的修复模式先修复表结构:

mysqld --defaults-file=/etc/my.cnf --skip-grant-tables --user=mysql --skip-networking --safe-mode &

进入安全模式后,执行:

mysql> USE mysql;
mysql> REPAIR TABLE user;

如果能顺利修复,则重启正常模式的mysqld服务器并登录检查。

2.如果上述修复没有效果

可以尝试重建mysql.user表:

mysqldump --add-drop-table --no-data mysql user > user.sql

退出,删除mysql.user表:

DROP TABLE mysql.user;

然后重建:

SOURCE user.sql;

3.如果以上两种方式仍然无法修复

则可以尝试重新初始化MySQL数据目录:

mysqld --defaults-file=/etc/my.cnf --initialize-insecure

这将移除所有数据重新初始化,之后需要重新导入数据。

4.最后的紧急情况下可以选择完全卸载重装MySQL服务器。

在修复过程中务必对现有数据做好备份。

修复表结构本质上是对表重建,如果有数据损坏可能导致部分数据丢失。

如果不行的话,可以考虑用之前的备份重建。

产生这个错误一般是由于MySQL版本升级,权限表结构发生变化,手动操作错误等导致。

我们需要格外小心谨慎操作系统权限表。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • mysql日志文件在哪 如何修改MySQL日志文件位置

    mysql日志文件在哪 如何修改MySQL日志文件位置

    MySQL日志文件相信大家都有很多的了解,MySQL日志文件一般在:/var/log/mysqld.log,下面介绍如何修改MySQL日志文件位置,需要的朋友可以参考下
    2012-12-12
  • 微信昵称带符号导致插入MySQL数据库时出错的解决方案

    微信昵称带符号导致插入MySQL数据库时出错的解决方案

    Mysql的utf8编码最多3个字节,而Emoji表情或者某些特殊字符是4个字节,所以会导致带有表情的昵称插入数据库时出错,下面给大家分享下解决方案,需要的朋友参考下吧
    2016-12-12
  • MySQL的prepare使用及遇到bug解析过程

    MySQL的prepare使用及遇到bug解析过程

    在一次开发中使用 MySQL PREPARE 以后,从 prepare 直接取 name 赋值给 lex->prepared_stmt_name 然后给 EXECUTE 用,发现有一定概率找不到 prepare stmt 的 name,于是开始动手调查问题发生的原因,本文给大家分享mysql prepare使用及问题解决,感兴趣的朋友一起看看吧
    2022-05-05
  • 详解MySQL数据库、表与完整性约束的定义(Create)

    详解MySQL数据库、表与完整性约束的定义(Create)

    这篇文章主要介绍了MySQL数据库、表与完整性约束的定义(Create),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2025-04-04
  • MySQL外键设置的方法实例

    MySQL外键设置的方法实例

    这篇文章主要介绍了MySQL外键设置的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • MySQL跨表查询与跨表更新

    MySQL跨表查询与跨表更新

    本文主要给大家讲解的是MySQL中如何使用跨表更新的方法和示例,非常的实用,有需要的小伙伴可以查看查看
    2020-02-02
  • MySQL配置文件my.cnf与my.ini的区别

    MySQL配置文件my.cnf与my.ini的区别

    在使用MySQL时,我们需要对其进行配置,以满足我们的需求,本文主要介绍了MySQL配置文件my.cnf与my.ini的区别,具有一定的参考价值,感兴趣的可以了解一下
    2024-03-03
  • 浅谈MySQL触发器的原理以及使用

    浅谈MySQL触发器的原理以及使用

    这篇文章主要介绍了浅谈MySQL触发器的原理以及使用,触发器的执行不需要使用 CALL 语句来调用,也不需要手工启动,只要一个预定义的事件发生就会被 MySQL自动调用,需要的朋友可以参考下
    2023-05-05
  • C# Mysql 查询 Rownum的解决方法

    C# Mysql 查询 Rownum的解决方法

    C# Mysql 查询 Rownum的解决方法,需要的朋友可以参考一下
    2013-03-03
  • MySQL插入json问题

    MySQL插入json问题

    今天小编就为大家分享一篇关于MySQL插入json问题,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-10-10

最新评论