实体框架 - 使用分离实体问题

时间:2009-01-20 20:44:04

标签: c# entity-framework

好的,所以在这个例子中我有一个名为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的调用只是在模板上调用detach以及可能已经加载的任何子实体的扩展。

这是单元测试。

[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”尚不存在。我开始怀疑在分离的环境中这种东西是否可行。

更新

好的,我将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 个答案:

答案 0 :(得分:8)

将代码更改为此允许对象状态管理器跟踪更改并允许添加模板。

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);
        }
    }