翼度科技»论坛 编程开发 mysql 查看内容

mysql5.0升级8.0完成后,服务器重启引发"#1449 - The user specified as a d

6

主题

6

帖子

18

积分

新手上路

Rank: 1

积分
18
遇到的问题:

问题一:ERROR 1449 (HY000): The user specified as a definer ('mysql.infoschema'@'localhost') does not exist

异常原因:未知


  • 解决办法:
  验证指定的用户('mysql.infoschema'@'localhost')是否存在于mysql数据库中
  1.   SELECT User FROM mysql.user WHERE User = 'mysql.infoschema' AND Host = 'localhost';
复制代码
如果用户不存在,可以使用以下命令创建该用户
  1.   CREATE USER 'mysql.infoschema'@'localhost';
复制代码
  1. 如果用户已经存在,但没有必要的权限,则可以使用grant语句授予所需的权限
复制代码
  1.   GRANT ALL PRIVILEGES ON *.* TO 'mysql.infoschema'@'localhost';
复制代码
  1. 如果SQL语句要求对特定表具有SELECT权限,则可以使用以下命令
复制代码
  1.   GRANT SELECT ON database_name.table_name TO 'mysql.infoschema'@'localhost';
复制代码
问题二:执行CREATE USER 'mysql.infoschema'@'localhost';时出现 ERROR 1726 (HY000): Storage engine 'MyISAM' does not support system tables. [mysql.db]

异常原因:"mysql.db"系统表的存储引擎和mysql指定的存储引擎不一致;


  • 解决办法:
              查询mysql指定的存储引擎是InnoDB还是MyISAM,具体查询方式根据自己的环境查询,我的环境是docker-compose创建docker镜像的方式部署,通过yaml文件将my.cnf文件挂载进去,具体在my.cnf的default-storage-engine=INNODB字段;
    执行以下sql切换表的存储引擎,或者在my.cnf文件里更改存储引擎为你表相应的存储引擎.
    1.         # 查询db表的存储引擎是什么
    2.                 SHOW TABLE STATUS LIKE 'db';
    3.   # 切换其他相关表的存储引擎
    4.           alter table mysql.user ENGINE=InnoDB;
    5.                 alter table mysql.db ENGINE=InnoDB;
    6.                 alter table mysql.tables_priv ENGINE=InnoDB;
    7.                 alter table mysql.columns_priv ENGINE=InnoDB;
    8.                 alter table mysql.procs_priv ENGINE=InnoDB;
    9.                 alter table mysql.proxies_priv ENGINE=InnoDB;
    复制代码
    切换引擎时可能会导致数据库重,所以以上每个引擎请单独执行。
问题三: 执行完成后再次运行"CREATE USER 'mysql.infoschema'@'localhost';"创建用户时,出现user表数据宽度不一样的问题。

异常原因:user表切换引擎导致表结构更改,无法完整创建用户


  • 解决办法:
             找一个干净的相同版本的mysql,从里面将user表里的数据转换成sql语句(备份),再删除有问题数据库的user表,执行sql(恢复).
问题四: 执行完成后mysql连接会断开,报密码错误。

异常原因:由于user表时copy过来的,密码本身是被特定算法加密的,user表中的加密后的密钥还原回来后并不是原密码,无法将密码正确存储与还原,导致密码错误。


  • 解决办法:
    在my.cnf文件里面加入skip_grant_tables跳过密码验证。
问题五:加入后无效或无法跳过密码验证

异常原因:未知


  • 解决办法:
    将原设备的mysq的data数据文件copy到另外一台真实的设备,并且在真机原生安装mysql,将数据库映射到原data数据,通过真机自身的命令行使用--skip_grant_tables执行启动,跳过密码登陆,再将数据全量备份,重置原设备的数据库,再重新将原数据导回,问题解决。

来源:https://www.cnblogs.com/zhuifonzhouzhou/p/17853433.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

举报 回复 使用道具