【问题标题】:Entity Framework - Working with Detached entities issue实体框架 - 处理分离的实体问题
【发布时间】:2010-10-02 13:23:25
【问题描述】:

好的,所以在本例中,我有一个名为 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);
    }

假设“圆形”模板类型尚不存在,单元测试可以完美运行。我开始怀疑这种东西在独立的环境中是否可行。

更新

好的,我将 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);
        }
    }

因此,对于由客户端添加到新父级的所有现有子实体,当它们准备好被持久化时,必须对其进行此类工作。有没有更清洁的方法来做到这一点?也许更通用一点?

【问题讨论】:

  • 您用于创建模板对象的代码会有所帮助,同时您遇到的错误也会有所帮助。我不认为你所得到的有什么问题,所以错误一定在你发布的代码之外。
  • 创建模板的代码在单元测试代码的底部。类信息自 EF 生成以来没有变化。
  • 你会注意到有一些代码被注释掉了。当使用注释掉的代码运行时,错误将显示:无法将对象添加到 ObjectStateManager,因为它已经有一个 EntityKey。使用 ObjectContext.Attach 附加具有现有键的对象..
  • 如果您取消注释代码并附加它想要附加的实体,您会得到:ObjectStateManager 中已经存在具有相同键的对象。现有对象处于未更改状态。只有处于添加状态的对象才能再次添加到 ObjectStateManager..
  • 对不起,我没有尽快回复你。这个问题现在更有意义了。您可以将您使用的代码发布到 FindTemplateByID 吗?

标签: c# entity-framework


【解决方案1】:

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

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

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-03-09
    • 2011-04-13
    • 1970-01-01
    相关资源
    最近更新 更多