Клонирование сущности Linq в Sql - отсоединение контекста данных

У меня есть требование клонировать объект Linq to SQL. В общих чертах:

Customer origCustomer = db.Customers.SingleOrDefault(c => c.CustomerId == 5);
Customer newCustomer = CloneUtils.Clone(origCustomer);
newCustomer.CustomerId = 0;  // Clear key
db.Customers.InsertOnSubmit(newCustomer);
db.SubmitChanges();   // throws an error

где CloneUtils.Clone () - это простой универсальный метод, который использует отражение для копирования копий данных из исходной сущности в новую сущность.

Моя проблема заключается в том, что когда я пытаюсь добавить новую сущность обратно в базу данных, я получаю следующую ошибку:

Была сделана попытка Присоединить или Добавить сущность, которая не является новой, возможно, была загружен из другого DataContext. Это не поддерживается.

Кажется, я не могу найти простой / общий способ отделения клонированной сущности от контекста данных. Или, может быть, я могу настроить свой метод клонирования, чтобы «пропускать» поля, связанные с контекстом?

Может ли кто-нибудь указать мне в правильном направлении?

Спасибо.

Для полноты, вот метод, к которому я пришел, следуя совету Маркуса:

public static T ShallowClone<T>(T srcObject) where T : class, new()
{
   // Get the object type
   Type objectType = typeof(T);

   // Get the public properties of the object
   PropertyInfo[] propInfo = srcObject.GetType()
      .GetProperties(
         System.Reflection.BindingFlags.Instance |
         System.Reflection.BindingFlags.Public
      );

   // Create a new  object
   T newObject = new T();

   // Loop through all the properties and copy the information 
   // from the source object to the new instance
   foreach (PropertyInfo p in propInfo)
   {
      Type t = p.PropertyType;
      if ((t.IsValueType || t == typeof(string)) && (p.CanRead) && (p.CanWrite))
      {
         p.SetValue(newObject, p.GetValue(srcObject, null), null);
      }
   }

   // Return the cloned object.
   return newObject;
}
7
задан Neilski 14 January 2012 в 08:48
поделиться