我有Person和Dog两个类。一只狗属于一个人,一个人可以有不同的狗(所以是一对多)。
我有一个测试方法,可以从数据库中取出2个persond。如果一个人在数据库中不存在,我会创建它。然后我想救4条狗。
这就是测试:
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 ); 这是资源访问的代码:
public Dog CreateDog(Dog dog)
{
try
{
db.Dogs.AddObject(dog);
db.SaveChanges();
return dog;
}
catch(Exception ex)
{
return null
}
}当我保存第一条狗时,所有其他狗都会在数据库中创建。为什么会发生这种情况,我如何才能防止它的发生?我认为这可能与上下文有关,但我似乎无法解决这个问题。
发布于 2011-08-19 16:22:27
这是正确的行为。SaveChanges始终保存上下文当前跟踪的所有更改。这是无法避免的--它被称为工作单元。发生这种情况的原因是在新狗的初始化过程中分配了所有者。Person已经被上下文跟踪,因此将其分配给任何其他实体将立即开始跟踪该实体。
如果要按顺序保存更改,则必须以不同的方式进行保存:
Dog dog1 = new Dog(){name="Dog1"};
dog1 = dogResourceAccess.CreateDog(dog1);
dog1.owner = person1; // Attach the person after you added a new dog.https://stackoverflow.com/questions/7118459
复制相似问题