薛定谔的 MySQL 表:存在与不存在的故事
遇到 MySQL 报告表存在但拒绝创建的悖论是令人困惑的问题。本文旨在揭开薛定谔表困境背后的谜团。
正如原始查询中所述,执行 CREATE TABLE 会导致“表已存在”错误,而 DROP TABLE 返回“未知表”。这种巨大的困境困扰着用户,给他们留下了一个无法创建或删除的无形表。
在大多数情况下,罪魁祸首在于孤立表文件的存在。 MySQL 以两种类型的文件管理数据:.frm 用于表定义,.MYI 和 .MYD (MYISAM) 或 .ibd (InnoDB) 用于表数据。当其中一个文件丢失时,该表将成为半成形的幻影,从而导致 MySQL 响应不一致。
要解决此薛定谔表难题,请手动从数据目录中找到并删除孤立的文件。如果使用 InnoDB,请确保 .frm 和 .ibd 文件都存在,而 MYISAM 表需要完整的 .frm、.MYI 和 .MYD 文件三重奏。
一旦删除孤立文件,悖论就消失了,并且可以按预期创建或删除该表。这样,难以捉摸的薛定谔表就得到了解决,这表明在 MySQL 领域,存在与不存在有时会以令人困惑的方式交织在一起。
以上是我的表存在,但不存在:如何解决这个 MySQL 悖论?的详细内容。更多信息请关注PHP中文网其他相关文章!