2016年1月

Mysql table doesn't exist

前段时间,在用着数据库的时候,突然就提示数据库不存在(Errno 1146 Table doesn't exist)。
然而怎么重启,数据表就是存在啊! 真是奇怪。
当初遇到这个问题是在公司,所以我赶紧换Linux系统继续开发。
之后也因为各种事情,以及尝试了一些小方法之后也没有解决,就这么忘记了。

过了两个月,我在做学校作业的时候又遇到了这个问题。
重新导了一遍数据库未果,于是又切换Linux继续工作。

就在今天,又遇到了这个问题。
我就下定决心解决。
在查阅了一些资料后,得到如下方法:

  1. 备份
  2. alter table tbl_name discard tablespace 删除表空间。
    但是,我在执行这句的时候,也报了这个错。

于是我直接重命名了ibd文件的后缀。(划掉)
于是我用drop table tbl_name删除了表。
虽然删除的时候也会报table doesn't exist 的错,但是用show tables这个命令查看表时,那个表却不见了。

  1. 从备份的数据库创建具有相同表结构的表。(还好我在服务器上也有这个库……)
  2. 把新生成的tbl_name.ibd文件用备份的同名ibd文件覆盖。此时,可能ibd文件会处于被占用状态。
    就解决了。

问题是解决了,但是还是不知道为什么引发了这个问题。
后续我会关注这个问题,留意这个问题是在什么情况下产生的。

2017-04-26 更新
今天在写代码的时候,突然发现删不了数据库。
搜索一番发现也没什么有效的解决方案。
看log后发现,它报的是“Too many open files”。
然后想起来我用Sequel Pro开了5个标签,我关掉一些标签之后,就正常了……