无法解析接近的表名

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了无法解析接近的表名相关的知识,希望对你有一定的参考价值。

我想创建一个对外表的引用。但我收到以下错误:

查询:

CREATE TABLE category_ids (id INT, post_id INT,
                    INDEX par_ind (post_id),
                    FOREIGN KEY (post_id) REFERENCES post(id)
                      ON DELETE CASCADE
) ENGINE=INNODB;

SHOW ENGINE INNODB状态 G:

------------------------
LATEST FOREIGN KEY ERROR
------------------------
2013-08-23 00:11:06 7f6f49e7b700 Error in foreign key constraint of table fun/category_ids:
FOREIGN KEY (post_id) REFERENCES post(id)
                      ON DELETE CASCADE
) ENGINE=INNODB:
Cannot resolve table name close to:
(id)
                      ON DELETE CASCADE
) ENGINE=INNODB

发表表结构

    mysql> describe post;
    +-------------+-----------------------+------+-----+---------------------+----------------+
    | Field       | Type                  | Null | Key | Default             | Extra          |
    +-------------+-----------------------+------+-----+---------------------+----------------+
    | id          | int(11)               | NO   | PRI | NULL                | auto_increment |
...
    +-------------+-----------------------+------+-----+---------------------+----------------+
    22 rows in set (0.00 sec)
答案

只有InnoDB支持外键,MyISAM不支持。即使它会,你也不能在不同类型的表之间建立关系。

因此,您需要将表post转换为InnoDB。 ALTER TABLE post ENGINE = InnoDB;

另一答案

对我来说,这适用于此。

CREATE TABLE category_ids (id INT, post_id INT references post(id),
                INDEX par_ind (post_id)
) ENGINE=INNODB;
另一答案

当父表被分区时,也会出现此错误。从父表中删除分区允许创建外部约束而没有任何问题。

以上是关于无法解析接近的表名的主要内容,如果未能解决你的问题,请参考以下文章

WebStorm 中未解析的表名

EF6 自定义迁移表名

解析sql中的表名

无法解析片段中的 findViewById [重复]

如何将 JSON 解析数据插入 MYSQL

如何动态替换sql中的表名