为什么向tblDomare表中添加外键会导致此错误?

ALTER TABLE语句与外键约束“FK__tblDomare__PersN__5F7E2DAC”冲突。数据库“almu0004”,表“dbo”发生冲突。tblBana”,列“BanNR”。

Code

CREATE TABLE tblDomare
(PersNR VARCHAR (15) NOT NULL,
fNamn VARCHAR (15) NOT NULL,
eNamn VARCHAR (20) NOT NULL,
Erfarenhet VARCHAR (5),
PRIMARY KEY (PersNR));

INSERT INTO tblDomare (PersNR,fNamn,eNamn,Erfarenhet)
Values (6811034679,'Bengt','Carlberg',10);

INSERT INTO tblDomare (PersNR,fNamn,eNamn,Erfarenhet)
Values (7606091347,'Josefin','Backman',4);

INSERT INTO tblDomare (PersNR,fNamn,eNamn,Erfarenhet)
Values (8508284163,'Johanna','Backman',1);

CREATE TABLE tblBana
(BanNR VARCHAR (15) NOT NULL,
PRIMARY KEY (BanNR));

INSERT INTO tblBana (BanNR)
Values (1);

INSERT INTO tblBana (BanNR)
Values (2);

INSERT INTO tblBana (BanNR)
Values (3);

ALTER TABLE tblDomare
ADD FOREIGN KEY (PersNR)
REFERENCES tblBana(BanNR);

当前回答

Smutje是正确的,Chad HedgeCock提供了一个伟大的外行例子。 我想以Chad的例子为基础,提供一种查找/删除这些记录的方法。 我们将客户作为父节点,订单作为子节点。CustomerId是公共字段。

select * from Order Child 
left join Customer Parent on Child.CustomerId = Parent.CustomerId
where Parent.CustomerId is null 

如果你正在阅读这篇文章……你会得到结果的。这些是孤儿。select * from Order Child 左连接客户父对子。CustomerId =父。CustomerId 父母的地方。CustomerId is null请注意右下角的行数。

去验证你需要的人,你要删除这些行!

begin tran 
delete Order
from Order Child 
left join Customer Parent on Child.CustomerId = Parent.CustomerId
where Parent.CustomerId is null 

运行第一个比特。 检查行数=您所期望的

提交tran

commit tran 

小心些而已。有人草率的编程让你陷入了困境。在你删除这些孤儿之前,一定要弄清楚原因。也许父母需要恢复原状。

其他回答

仅供参考,如果你做了所有的数据参考检查,没有发现坏数据……显然,在两个表和字段之间创建外键约束是不可能的,因为这些字段是两个表中的主键!别问我怎么知道的。

在向表中添加外键之前,请执行以下操作

确保表必须为空或列数据应该匹配。 确保它不是空的。 如果表中包含不去设计和更改,请手动进行。 表1添加外键(Column Name)引用 表1 alter column列名属性不为空

您已输入表(tbldomare)的数据与您已分配主键表的数据不匹配。在tbldomare之间写入并添加这个单词(使用nocheck),然后执行代码。

例如,您输入了一个表tbldomar此数据

INSERT INTO tblDomare (PersNR,fNamn,eNamn,Erfarenhet)
Values (6811034679,'Bengt','Carlberg',10);

你分配了一个外键表只接受1 2 3。

您有两个解决方案,一个是删除您已输入的数据表,然后执行代码。另一种方法是写这个单词(带nocheck),把它放在你的表名和add之间 像这样

ALTER TABLE  tblDomare with nocheck
ADD FOREIGN KEY (PersNR)
REFERENCES tblBana(BanNR);

这个问题对我很有用。它显示所有没有任何匹配的值

select FK_column from FK_table
WHERE FK_column NOT IN
(SELECT PK_column from PK_table)

或者你可以用这个

SELECT  fk_id FROM dbo.tableA
Except
SELECT fk_id From dbo.tableB