Entity Framework Error: un objeto con un valor EntityKey nulo no se puede adjuntar a un contexto de objeto
En mi aplicación tengo el siguiente 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 llama a un método en un objeto dataManager que utiliza 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;
}
}
La inserción en este código funciona bien. Pero cuando intento realizar una actualización, aparece un error que dice: "Un objeto con un valor EntityKey nulo no se puede adjuntar a un contexto de objeto".
Se produce en esta línea de código: entidades.Attach (userInfo);
Lo que estoy tratando de lograr es evitar hacer un viaje de ida y vuelta a la base de datos solo para seleccionar el registro en el que luego haré cambios y actualizaré, haciendo así dos viajes de ida y vuelta a la base de datos.
Alguna idea de lo que va mal o cómo podría lograr esto mejor?
Gracias