无法解析接近的表名
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;
另一答案
当父表被分区时,也会出现此错误。从父表中删除分区允许创建外部约束而没有任何问题。
以上是关于无法解析接近的表名的主要内容,如果未能解决你的问题,请参考以下文章