Хорошо, поэтому в этом примере у меня есть родительская сущность с именем Template. Шаблон всегда имеет тип. Тип FK, который, скорее всего, уже существует. Проблема возникает при создании нового шаблона и добавлении к нему типа. Как только тип добавлен, и вы идете, чтобы добавить шаблон, вы получите ошибку. Какую ошибку вы получите, зависит от подхода. Кто-нибудь знает, как работать с такой ситуацией?
public static void AddTemplate(Template template)
{
using (TheEntities context = new TheEntities())
{
//if (template.TemplateType.EntityKey != null)
//{
// context.Attach(template.TemplateType);
//}
context.AddToTemplates(template);
context.SaveChanges();
context.RemoveTracking(template);
}
}
Я пытался и попытаться присоединить существующий ключ, и нет. Вызов в нижней части RemoveTracking - это просто расширение для вызова отсоединения для шаблона и любых дочерних объектов, которые могли быть загружены.
Вот модульный тест.
[TestMethod]
public void CanAddAndDeleteATemplate()
{
Template template = new Template();
template.Name = "Test";
template.Description = "Test";
TemplateType type = TemplateManager.FindTemplateTypeByName("Round");
if (type == null)
{
type = new TemplateType();
type.Name = "Round";
}
template.TemplateType = type;
TemplateManager.AddTemplate(template);
template = TemplateManager.FindTemplateByID(template.TemplateID);
Assert.IsNotNull(template);
TemplateManager.DeleteTemplate(template);
template = TemplateManager.FindTemplateByID(template.TemplateID);
Assert.IsNull(template);
}
Модульный тест работает отлично, предполагая, что Тип шаблона "Round" еще не существует. Я начинаю задаваться вопросом, возможны ли подобные вещи в обособленном окружении.
UPDATE
Хорошо, я изменил свой код для AddTemplate на этот, и теперь он работает ..
public static void AddTemplate(Template template)
{
using (TheEntities context = new TheEntities())
{
if (template.TemplateType.EntityKey != null)
{
TemplateType type = template.TemplateType;
template.TemplateType = null;
context.AttachTo("TemplateTypes", type);
template.TemplateType = type;
}
context.AddToTemplates(template);
context.SaveChanges();
context.RemoveTracking(template);
}
}
Таким образом, для всех существующих дочерних объектов, которые добавляются клиентом к новому родителю, такая работа должна быть выполнена над ними, когда они будут готовы к сохранению. Есть ли более чистый способ сделать это? Может быть, что-то более общее?