Erro do Framework de Entidade: Um objeto com um valor EntityKey nulo não pode ser anexado a um contexto de objeto
Na minha aplicação, tenho o seguinte código ...
public Boolean SaveUserInformation(UserInfoDTO UserInformation)
{
return dataManager.SaveUserInfo(new UserInfo()
{
UserInfoID = UserInformation.UserInfoID.HasValue ? UserInformation.UserInfoID.Value : 0,
UserID = UserInformation.UserID,
ProxyUsername = UserInformation.ProxyUsername,
Email = UserInformation.Email,
Status = UserInformation.Status
});
}
Este código chama um método em um objeto dataManager que utiliza o Entity Framework ...
public Boolean SaveUserInfo(UserInfo userInfo)
{
try
{
//Validate data prior to database update
if (userInfo.UserID == null) { throw new Exception("UserInfoDomainModel object passed to PriorityOne.Data.DataManager.SaveUserInfo with UserID property set to NULL."); }
if (userInfo.ProxyUsername == null) { throw new Exception("UserInfoDomainModel object passed to PriorityOne.Data.DataManager.SaveUserInfo with ProxyUsername property set to NULL."); }
if (userInfo.Email == null) { throw new Exception("UserInfoDomainModel object passed to PriorityOne.Data.DataManager.SaveUserInfo with Email property set to NULL."); }
if (userInfo.UserInfoID == 0)
{
//Perform Insert
using (PriorityOneEntities entities = new PriorityOneEntities())
{
entities.UserInfoes.AddObject(userInfo);
entities.SaveChanges();
}
}
else
{
//Perform Update
using (PriorityOneEntities entities = new PriorityOneEntities())
{
entities.Attach(userInfo);
entities.SaveChanges();
}
}
return true;
}
catch (Exception ex)
{
//TODO: Log Error
return false;
}
}
A inserção neste código funciona muito bem. Mas quando tento executar uma atualização, recebo um erro dizendo: "Um objeto com um valor EntityKey nulo não pode ser anexado a um contexto de objeto."
Ocorre nesta linha de código: entity.Attach (userInfo);
O que estou tentando realizar é evitar fazer uma viagem de ida e volta ao banco de dados apenas para selecionar o registro no qual mais tarde farei alterações e atualizações, fazendo assim duas viagens de ida e volta ao banco de dado
Alguma idéia do que está errado, ou como eu poderia conseguir isso melhor?
Obrigado