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

信号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..但没有快乐:-(


当前回答

我也得到了同样的错误在我的SQL代码,这个解决方案为我工作,


检查主表中的数据可能是您正在输入的列值不在主键列中。

其他回答

这个问题是可重复的和间歇性的,我使用mybatis。 我确信我有正确的DB配置(PK, FK,自动增量等) 我确信我有正确的插入顺序(父记录先),在调试中,我可以看到父记录插入各自的PK,就在下一个语句失败后插入子记录与正确的FK。

这个问题是通过重新播种身份来解决的

DBCC CHECKIDENT ('schema.customer', RESEED, 0);
DBCC CHECKIDENT ('schema.account', RESEED, 0);

和之前失败的代码一模一样。 我想有人给我解释一下是什么导致了这个问题。

仔细检查为之定义外键的关系中的字段。在定义关系时,SQL Server Management Studio可能没有选择所需的字段。这在过去让我很痛苦。

运行sp_helpconstraint 注意为外键返回的constraint_keys列

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

我会逃跑

sp_helpconstraint sup_item

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

当我使用代码优先迁移来为MVC 5应用程序构建数据库时,我也遇到了同样的问题。我最终发现我的configuration.cs文件中的种子方法导致了这个问题。我的seed方法是在创建带有匹配主键的表项之前,为包含外键的表创建一个表项。