Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

LINQ to SQL ForeignKeyReferenceAlreadyHasValueException error

Tags:

c#

linq-to-sql

This error is being generated when I try to change a foreign key. I know this is a very common error I’ve found tons of information about it and tried to implement the fixes I’ve found but I still get this error when trying to update Keys. Reference Thread

Originally I was just directly assigning the value and not trying to map the entities.

ticket.assigned_to_group = assigned_to

I’ve since changed to try and map the entities which I believe the correct answer; however I still get the error.

ticket.assigned_to_group = db.sub_units.Single(f => f.id == assigned_to).id;

Any idea why this would not work. Also if I have a table with multiple foreign keys, do I really need to do a new query for each key or is there a better way?

like image 775
Tim Avatar asked Feb 24 '10 18:02

Tim


1 Answers

I think you are trying to assign an ID when you need to assign the entity. (I'm not 100% sure this is what you are doing)

// Don't assign just the id
Person.ParentId = parentId;

// Assign the entity
Person.Parent = db.Parents.Single(x.Id == parentId);
like image 105
Jon Erickson Avatar answered Oct 12 '22 14:10

Jon Erickson