为什么向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);

当前回答

我在项目中遇到了一些问题。

在子表中,没有任何Id等于1和11的记录

我插入了DEAL_ITEM_THIRD_PARTY_PO表,它的Id等于1和11,然后我可以创建FK

其他回答

在我的场景中,使用EF,在尝试在现有数据上创建这个新的外键时,我错误地尝试在创建外键后填充数据(使链接)。

修复方法是在创建外键之前填充数据,因为外键会检查所有数据,看看链接是否确实有效。所以如果你还没有填充它,它是不可能工作的。

从表中删除所有现有数据,然后在表之间建立关系。

或者你可以用这个

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

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

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

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