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

当前回答

我也有同样的问题。 我的问题是在列(迁移文件)中有nullable: true:

AddColumn("dbo.table", "column", c => c.Int(nullable: true));
        

可能的解决方式:

将可空的“false”更改为“true”。(不推荐) 改变属性类型从int到int?(推荐)

如果需要,稍后在添加列>后更改,然后在以前的记录中删除字段数据

如果你已经将一个现有属性从nullable更改为nonnullable: 3)在数据库记录中填写列数据

其他回答

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

我也犯了这个错误 正如Smutje所提到的,确保你的基本外键表的外键列中没有一个值不在你的参考表中,即(你的基本外键表中的每个值(外键列的值)也必须在你的参考表列中) 最好先清空基本外键表,然后再设置外键

当你在表B中定义一个外键引用表a的主键时,这意味着当一个值在B中,它必须在a中。这是为了防止对表的不一致修改。

在你的例子中,你的表包含:

带主键的tblDomare (PersNR):

PersNR     |fNamn     |eNamn      |Erfarenhet
-----------|----------|-----------|----------
6811034679 |'Bengt'   |'Carlberg' |10
7606091347 |'Josefin' |'Backman'  |4
8508284163 |'Johanna' |'Backman'  |1
---------------------------------------------

tblBana:

BanNR
-----
1
2
3
-----

这句话:

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

表示tblDomare中任何具有键PersNR的行必须在表tblBana中有对应的键BanNR。您的错误是因为您在tblDomare中插入了行,而tblBana中没有对应的行。

解决问题的2个方法:

在tblBana中添加BanNR (6811034679, 7606091347, 8508284163) 或者删除tblDomare中所有在tblBana中没有对应的行(但是你的表将是空的)

一般建议:在填充表之前应该有外键约束。外键的作用是防止表的用户在表中填充不一致的内容。

您应该看到表的行上是否有任何数据。如果“是”,那么您应该截断表(s),否则您可以使它们在tblDomare中具有相同数量的数据。PersNR to tblBana。BanNR和反之亦然。

或者你可以用这个

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