首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >EF保存多个实体之一时出现问题

EF保存多个实体之一时出现问题
EN

Stack Overflow用户
提问于 2011-08-19 15:48:00
回答 1查看 81关注 0票数 0

我有Person和Dog两个类。一只狗属于一个人,一个人可以有不同的狗(所以是一对多)。

我有一个测试方法,可以从数据库中取出2个persond。如果一个人在数据库中不存在,我会创建它。然后我想救4条狗。

这就是测试:

代码语言:javascript
复制
Person person1= personResourceAccess.GetPersonByName("Person1");
        if(person1==null)
        {
            Person person = new Person()
                            {
                                Name = "Person1"
                            };
            person1= personResourceAccess.CreatePerson(person);
        }
Person person2= personResourceAccess.GetPersonByName("Person2");
            if(person2==null)
            {
                Person person = new Person()
                                {
                                    Name = "Person2"
                                };
                person2= personResourceAccess.CreatePerson(person);
            }
Dog dog1 = new Dog(){name="Dog1", owner = person1};
Dog dog2 = new Dog(){name="Dog2", owner = person1};
Dog dog3 = new Dog(){name="Dog3", owner = person1};
Dog dog4 = new Dog(){name="Dog4", owner = person2};

dog1 = dogResourceAccess.CreateDog(dog1);
dog2 = dogResourceAccess.CreateDog(dog2);
dog3 = dogResourceAccess.CreateDog(dog3 );
dog4 = dogResourceAccess.CreateDog(dog4 ); 

这是资源访问的代码:

代码语言:javascript
复制
public Dog CreateDog(Dog dog)
    {
        try
        {
            db.Dogs.AddObject(dog);
            db.SaveChanges();
            return dog;
        }
        catch(Exception ex)
        {
            return null
        }
    }

当我保存第一条狗时,所有其他狗都会在数据库中创建。为什么会发生这种情况,我如何才能防止它的发生?我认为这可能与上下文有关,但我似乎无法解决这个问题。

EN

回答 1

Stack Overflow用户

发布于 2011-08-19 16:22:27

这是正确的行为。SaveChanges始终保存上下文当前跟踪的所有更改。这是无法避免的--它被称为工作单元。发生这种情况的原因是在新狗的初始化过程中分配了所有者。Person已经被上下文跟踪,因此将其分配给任何其他实体将立即开始跟踪该实体。

如果要按顺序保存更改,则必须以不同的方式进行保存:

代码语言:javascript
复制
Dog dog1 = new Dog(){name="Dog1"};
dog1 = dogResourceAccess.CreateDog(dog1);
dog1.owner = person1; // Attach the person after you added a new dog.
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7118459

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档