2

我有以下代码:

ALTER TABLE users MODIFY id int unsigned;

这会引发以下错误:

ERROR 1025 (HY000) at line 114: Error on rename of './mydb/#sql-146dd_1d' to './mydb/users' (errno: 150)

我相当确定这是因为外键问题,但我想找到有关该错误的更多详细信息。

我似乎记得我可以在 mySQL 命令行中输入一些内容,它会显示各种类型问题(包括外键问题)的最新错误列表以及有关确切原因的更多详细信息(例如所涉及的表)。有谁知道我在说什么?

4

2 回答 2

4

我认为您正在寻找的是提供最后一个外键错误的SHOW ENGINE INNODB STATUS 命令(我假设是 innodb 引擎)。

mysql> CREATE TABLE `T1`(`id` int(10) unsigned NOT NULL AUTO_INCREMENT,PRIMARY KEY (`id`)) ENGINE=InnoDB; 
mysql> CREATE TABLE `T2` (`id` int(10) unsigned NOT NULL AUTO_INCREMENT, `refer_id` int(10) unsigned NOT NULL, PRIMARY KEY (`id`), KEY `refer_id` (`refer_id`), CONSTRAINT `t2_id_to_t1_id` FOREIGN KEY (`refer_id`) REFERENCES `T1`.`id` ON DELETE CASCADE ON UPDATE CASCADE) ENGINE=InnoDB;
ERROR 1005 (HY000): Can't create table 'TEMP.T2' (errno: 150)

mysql>  SHOW ENGINE INNODB STATUS;
[...]
------------------------
LATEST FOREIGN KEY ERROR
------------------------
130506 15:50:41 Error in foreign key constraint of table TEMP/T2: FOREIGN KEY (`refer_id`) REFERENCES `T1`.`id` ON DELETE CASCADE ON UPDATE CASCADE) ENGINE=InnoDB: Cannot resolve table name close to: ON DELETE CASCADE ON UPDATE CASCADE) ENGINE=InnoDB
[...]

mysql> CREATE TABLE `T2` (`id` int(10) unsigned NOT NULL AUTO_INCREMENT, `refer_id` int(10) unsigned NOT NULL, PRIMARY KEY (`id`), KEY `refer_id` (`refer_id`), CONSTRAINT `t2_id_to_t1_id` FOREIGN KEY (`refer_id`) REFERENCES `T1`(`id`) ON DELETE CASCADE ON UPDATE CASCADE) ENGINE=InnoDB;
Query OK, 0 rows affected (0.04 sec)

我特意在表 T2 创建语句中插入了一个错误,以演示外键错误的输出(在本例中为架构解析)。

于 2013-05-06T19:59:00.320 回答
0

您可能正在寻找SHOW WARNINGS.

MySQL 文档

于 2013-05-06T19:40:40.507 回答