gpt4 book ai didi

mysql - "id_"和 "id"和 "id"是什么导致错误 1005 : Can't create table 'xxx.xxx' (errno: 121)

转载 作者:行者123 更新时间:2023-11-29 00:57:56 25 4
gpt4 key购买 nike

我是 MySQL 的新手,正在创建一个复杂的 EER 图。创建后,我“正向工程师...”模型并遇到了可怕的错误:错误 1005:无法创建表“xxx.xxx”(错误号:121)。我创建了另一个具有 1:M 关系的两个表的简化模型,但使用“id_”作为主键和外键名称。那奏效了。

i.e.
TABLE_A
id_TABLE_A INT

TABLE_B
id_TABLE_B INT
id_TABLE_A INT

其中,TABLE_A[1]--<[M]TABLE_B是一对多关系,TABLE_B.id_TABLE_A是外键

查看我的复杂 EER 图,我注意到我使用了不带下划线的“id”作为主键和外键名称。我在“id”之后插入了下划线,并且 Forward Engineer'd 模型并且它没有错误地工作。因此,这里有两个简单的示例模型,一个带有“id_”,另一个带有“id”。 “id_”不会导致错误 1005 而“id”会导致错误 1005。有人知道为什么 MySQL 会发生这种异常吗?

============================================= ================================好模型:

SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0;
SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0;
SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='TRADITIONAL';

CREATE SCHEMA IF NOT EXISTS `mydb` DEFAULT CHARACTER SET latin1 COLLATE latin1_swedish_ci ;
USE `mydb` ;

DROP TABLE IF EXISTS `mydb`.`TABLE_A` ;

CREATE TABLE IF NOT EXISTS `mydb`.`TABLE_A` (
`id_TABLE_A` INT NOT NULL AUTO_INCREMENT ,
PRIMARY KEY (`id_TABLE_A`) ,
UNIQUE INDEX `id_TABLE_A_UNIQUE` (`id_TABLE_A` ASC) )
ENGINE = InnoDB;


DROP TABLE IF EXISTS `mydb`.`TABLE_B` ;

CREATE TABLE IF NOT EXISTS `mydb`.`TABLE_B` (
`id_TABLE_B` INT NOT NULL AUTO_INCREMENT ,
`id_TABLE_A` INT NOT NULL ,
PRIMARY KEY (`id_TABLE_B`) ,
UNIQUE INDEX `id_TABLE_B_UNIQUE` (`id_TABLE_B` ASC) ,
INDEX `id_TABLE_A` (`id_TABLE_A` ASC) ,
CONSTRAINT `id_TABLE_A`
FOREIGN KEY (`id_TABLE_A` )
REFERENCES `mydb`.`TABLE_A` (`id_TABLE_A` )
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB;


SET SQL_MODE=@OLD_SQL_MODE;
SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;

结果:

Build is successful.

============================================= ================================

不良模型:

SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0;
SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0;
SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='TRADITIONAL';

CREATE SCHEMA IF NOT EXISTS `mydb` DEFAULT CHARACTER SET latin1 COLLATE latin1_swedish_ci ;
USE `mydb` ;


DROP TABLE IF EXISTS `mydb`.`TABLE_A` ;

CREATE TABLE IF NOT EXISTS `mydb`.`TABLE_A` (
`idTABLE_A` INT NOT NULL AUTO_INCREMENT ,
PRIMARY KEY (`idTABLE_A`) ,
UNIQUE INDEX `idTABLE_A_UNIQUE` (`idTABLE_A` ASC) )
ENGINE = InnoDB;


DROP TABLE IF EXISTS `mydb`.`TABLE_B` ;

CREATE TABLE IF NOT EXISTS `mydb`.`TABLE_B` (
`idTABLE_B` INT NOT NULL AUTO_INCREMENT ,
`idTABLE_A` INT NOT NULL ,
PRIMARY KEY (`idTABLE_B`) ,
UNIQUE INDEX `idTABLE_B_UNIQUE` (`idTABLE_B` ASC) ,
INDEX `idTABLE_A` (`idTABLE_A` ASC) ,
CONSTRAINT `idTABLE_A`
FOREIGN KEY (`idTABLE_A` )
REFERENCES `mydb`.`TABLE_A` (`idTABLE_A` )
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB;


SET SQL_MODE=@OLD_SQL_MODE;
SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;

结果:

Executing SQL script in server
ERROR: Error 1005: Can't create table 'mydb.table_b' (errno: 121)

CREATE TABLE IF NOT EXISTS `mydb`.`TABLE_B` (
`idTABLE_B` INT NOT NULL AUTO_INCREMENT ,
`idTABLE_A` INT NOT NULL ,
PRIMARY KEY (`idTABLE_B`) ,
UNIQUE INDEX `idTABLE_B_UNIQUE` (`idTABLE_B` ASC) ,
INDEX `idTABLE_A` (`idTABLE_A` ASC) ,
CONSTRAINT `idTABLE_A`
FOREIGN KEY (`idTABLE_A` )
REFERENCES `mydb`.`TABLE_A` (`idTABLE_A` )
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB

SQL script execution finished: statements: 8 succeeded, 1 failed

最佳答案

如果您的约束名称与另一个名称冲突,通常会发生这种情况。请参阅 http://dev.mysql.com/doc/refman/5.0/en/innodb-error-codes.html 的评论和 http://forums.mysql.com/read.php?22,33999,76181#msg-76181

但是这里...一个 MySQL 错误?

关于mysql - "id_"和 "id"和 "id"是什么导致错误 1005 : Can't create table 'xxx.xxx' (errno: 121),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5110198/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com