首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Mysql alter语句

Mysql alter语句
EN

Stack Overflow用户
提问于 2012-04-22 19:33:56
回答 2查看 120关注 0票数 0

这是我尝试连接两个表的alter语句:

代码语言:javascript
复制
ALTER TABLE my_contacts 
  CHANGE `profession` `profession_id`  INT NOT NULL, 
  ADD CONSTRAINT professions_profession_id_fk 
  FOREIGN KEY (profession_id) REFERENCES professions (profession_id)

并且我有以下错误:

代码语言:javascript
复制
#1452 - Cannot add or update a child row: a foreign key constraint fails (`contacts`.<result 2 when explaining filename '#sql-1ca_73'>, CONSTRAINT `professions_profession_id_fk` FOREIGN KEY (`profession_id`) REFERENCES `professions` (`profession_id`))

有人能指导我这是什么吗?实际上,我自己也在学习如何编写sql,因为我一直在使用工具。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-04-22 19:39:30

您的外键约束失败了。

您尝试创建的外键强制my_contacts中的每个profession_id都出现在您的professions表中。现在,情况并非如此。您应该在my_contacts中查找专业中不存在profession_id的所有记录,并首先修复这些记录。

票数 1
EN

Stack Overflow用户

发布于 2012-04-22 19:35:56

这是一种关系冲突。一个更容易解决的方法是

  • 删除字段之间的关系Alter

tables

  • 再次添加关系时,请修复收到的错误。
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10267575

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档