Entity Framework - работа с отделенными объектами - PullRequest
7 голосов
/ 20 января 2009

Хорошо, поэтому в этом примере у меня есть родительская сущность с именем 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);
        }
    }

Таким образом, для всех существующих дочерних объектов, которые добавляются клиентом к новому родителю, такая работа должна быть выполнена над ними, когда они будут готовы к сохранению. Есть ли более чистый способ сделать это? Может быть, что-то более общее?

1 Ответ

8 голосов
/ 21 января 2009

Изменение кода на это позволяет менеджеру состояния объекта отслеживать изменения и разрешать добавление шаблона.

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);
        }
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...