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

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


当前回答

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

其他回答

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

你需要发布你的声明以得到更多的澄清。但是…

该错误意味着您正在插入数据的表与另一个表有外键关系。在插入数据之前,外键字段中的值必须首先存在于另一个表中。

当我的插入值字段包含肉眼不明显的制表符和空格时,我遇到了这个问题。我已经在Excel中创建了我的值列表,复制并粘贴到SQL中,并运行查询来查找FK字段中的不匹配项。

匹配查询没有检测到FK字段中有制表符和空格,但INSERT确实识别了它们,并继续生成错误。

通过复制一条记录中FK字段的内容并将其粘贴到插入查询中,我再次进行了测试。当该记录也失败时,我仔细查看了数据,最终发现了制表符/空格。

一旦我清理了删除的制表符/空格,我的问题就解决了。希望这能帮助到一些人!

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

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