Использование EF5 с общим шаблоном репозитория и ninject для ограничения зависимостей и проблемы при попытке обновления объекта в базе данных с использованием сохраненных procs с моим edmx.
Мое обновление в DbContextRepository.cs:
public override void Update(T entity)
{
if (entity == null)
throw new ArgumentException("Cannot add a null entity.");
var entry = _context.Entry<T>(entity);
if (entry.State == EntityState.Detached)
{
_context.Set<T>().Attach(entity);
entry.State = EntityState.Modified;
}
}
Из моего AddressService.cs, который возвращается в мой репозиторий, я:
public int Save(vw_address address)
{
if (address.address_pk == 0)
{
_repo.Insert(address);
}
else
{
_repo.Update(address);
}
_repo.SaveChanges();
return address.address_pk;
}
Когда он попадает в Attach и EntityState.Modified, он заражается ошибкой:
Объект с тем же ключом уже существует в ObjectStateManager. ObjectStateManager не может отслеживать несколько объектов с одним и тем же ключом.
Я просмотрел множество предложений в стеке и в Интернете и не придумываю ничего, что разрешает его. Любые работы будут оценены.
Спасибо!