Ben*_*enV 9 mysql mysql-workbench
我正在尝试将模式更改从 MySQL Workbench 同步到我的数据库。尝试创建外键时出现以下错误:
Executing SQL script in server
ERROR: Error 1005: Can't create table 'tomato.#sql-2730_1b8' (errno: 121)
Run Code Online (Sandbox Code Playgroud)
这是它试图执行的语句:
ALTER TABLE `tomato`.`ing_allergy_ingredient`
ADD CONSTRAINT `fk_ai_allergy`
FOREIGN KEY (`allergy_id` )
REFERENCES `tomato`.`ing_allergy` (`allergy_id` )
ON DELETE NO ACTION
ON UPDATE NO ACTION
Run Code Online (Sandbox Code Playgroud)
任何想法这个错误意味着什么?
Am1*_*3zA 11
如果您尝试使用已在其他地方使用的名称添加约束,您将收到此消息。
根据这篇文章,您可以像这样检查您的约束:
如果您尝试创建的表包含外键约束,并且您为该约束提供了自己的名称,请记住它在数据库中必须是唯一的。运行此查询以查看该名称是否在某处使用:
SELECT
constraint_name,
table_name
FROM
information_schema.table_constraints
WHERE
constraint_type = 'FOREIGN KEY'
AND table_schema = DATABASE()
ORDER BY
constraint_name;
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
13569 次 |
| 最近记录: |