Search code examples
c#entity-frameworkasp.net-coreentity-framework-coreaspnetboilerplate

The instance of entity type 'xTestType' cannot be tracked because another instance of this type with the same key is already being tracked?


I'm trying to delete multiple rows from a table. But it gives the following error after the first iteration. I can see primary key Id as 0 on all the xTestType object. that might be the issue. Why is it always giving Id 0.

foreach (var temp in oldxDetails.TestTypes)
{
  if (deleteTestTypes.Contains(input.Id))
  {
    var xTestType = new xTestType
    {
      xId = xId,
      TestTypeMasterId = temp.Id
    };

    await _xTestRepository.DeleteAsync(xTestType);
  }
}

Exception:

The instance of entity type 'xTestType' cannot be tracked because another instance of this type with the same key is already being tracked. When adding new entities, for most key types a unique temporary key value will be created if no key is set (i.e. if the key property is assigned the default value for its type). If you are explicitly setting key values for new entities, ensure they do not collide with existing entities or temporary values generated for other new entities. When attaching existing entities, ensure that only one entity instance with a given key value is attached to the context.


Solution

  • The issue exists because the entity framework is tracking xTestType when you fetched all of them. There are two approaches to handle the situation.

    Approach 1:

    DbContext.Entry(xTestTypeOld).State = EntityState.Deleted;  // where xTestTypeOldis record from which you are taking xId
    

    Approach 2 :

    DbContext.Entry(xTestTypeOld).State = EntityState.Detached;
    DbContext.Entry(xTestType).State = EntityState.Deleted;
    

    I would say the first approach is the best one.