mysql 无法执行select查询

MySQL InnoDB 查询异常解决
本文探讨了MySQL中使用InnoDB存储引擎时遇到的查询异常问题。当尝试从特定数据库查询时,出现错误提示,而这些数据库并非系统自带的mysql或information_schema。经过排查发现,这主要是因为InnoDB表与数据库的.frm文件信息不匹配导致。通过检查information_schema表可定位问题所在,并给出了解决方案。

场景:mysql无法执行select命令查询,对于已存在的数据库,除了mysql、information_schema数据库,其它诸如nova、keystone、cinder等数据库都有此现象。

日志报如下错误:

此时执行:

>create database db;
>create table person (id int,name varchar(25))
>use db;
>select * from person;
>drop database db;

是没有问题的。

查看官网:http://dev.mysql.com/doc/refman/5.6/en/innodb-troubleshooting-datadict.html

解释说这是由于InnoDB表与各个数据库的.frm文件信息不对称造成的。进入数据库查看

>use information_schema;

可以发现这张表没有与之对应的信息,因此报错。

问题找到了。

转载于:https://www.cnblogs.com/wtfbk/p/5228918.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值