我得到以下错误。你能帮帮我吗?

信号547,16级,状态0,1号线 INSERT语句与外键约束“FK_Sup_Item_Sup_Item_Cat”冲突。数据库“dev_bo”,表“dbo.Sup_Item_Cat”发生冲突。声明已终止。

代码:

insert into sup_item (supplier_id, sup_item_id, name, sup_item_cat_id, 
                      status_code, last_modified_user_id, last_modified_timestamp, client_id)   
values (10162425, 10, 'jaiso', '123123',
        'a', '12', '2010-12-12', '1062425')

最后一列client_id导致了错误。我试着把已经存在的值放在dbo中。将Sup_Item_Cat放入列,对应于sup_item..但没有快乐:-(


当前回答

在我看来,问题不在于client_id。看起来问题更像是第四列sup_item_cat_id

我会逃跑

sp_helpconstraint sup_item

并注意为外键FK_Sup_Item_Sup_Item_Cat返回的constraint_keys列,以确认哪一列是实际问题,但我非常确定这不是您试图解决的问题。此外,123123看起来也很可疑。

其他回答

在我的例子中,我以错误的顺序将值插入到子表中:

对于有2列的表:columnn1和column2,当我错误地输入时,我得到了这个错误:

INSERT INTO Table VALUES('column2_value', 'column1_value');

当我使用下面的格式时,错误得到了解决

INSERT INTO Table (column2, column1) VALUES('column2_value', 'column1_value');

父表数据缺失会导致这个问题。 在您的问题中,“dbo”中的数据不可用。“Sup_Item_Cat”导致该问题

您正在尝试在外键列中插入具有外表中不存在的值的记录。

例如:如果您有Books和Authors表,其中Books在Authors表上有外键约束,并且您试图插入没有作者记录的图书记录。

我自己也有这个问题,关于试图填充外键字段时收到的错误消息。我来到这一页,希望能找到答案。本页上选中的答案确实是正确的,不幸的是,我觉得这个答案对于不熟悉SQL的人来说有点不完整。我很擅长写代码,但SQL查询和构建数据库表对我来说都是新的。

尽管选中的答案是正确的:

迈克·M写道: “FK的工作方式是它不能在那一列中有值 也不是在引用表的主键列中。”

这个答案中缺少的是;

必须首先构建包含主键的表。

另一种说法是;

必须将数据插入到包含主表的父表中 键,然后再尝试将数据插入到包含 外键。

简而言之,许多教程似乎忽略了这个事实,所以如果您自己尝试,并且没有意识到有一个操作顺序,那么您就会得到这个错误。添加主键数据后,子表中的外键数据自然必须与父表中的主键字段一致,否则仍然会得到此错误。

如果有人读到这里。我希望这能让你的答案更清楚。我知道你们中的一些人可能会觉得这类事情很简单,打开一本书就能回答这个问题,但事实是,不是每个人都以同样的方式学习。

如果FK列表应该包含FK值作为主键值,则将插入数据。