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

当前回答

在我们这边,情况是这样的:

我们在数据库中有一个包含记录的现有表。 然后我引入一个非空的外键 执行更新后,我得到这个错误。

我怎么解决你的问题?

解决方案:我只是删除了表的所有记录,然后尝试更新数据库,它是成功的。

其他回答

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

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

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

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

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

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

您已输入表(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);

尝试删除tblDomare中的当前数据。PersNR。因为tblDomare中的值。PersNR与tblbanana . bannr中的值不匹配。