惊讶的是实体框架正确保存分离的实体
我有一个实体类Timecard
,我从这个方法得到这个实体:
public Timecard GetTimeCardForPerson(long timecardId)
{
return timecardContext.First(item => item.TimeCardId = timeCardId);
}
TimecardContext: DbContext
的类型是TimecardContext: DbContext
。
我后来对Timecard
实体进行了更改, Timecard
实体具有一个属性:
public virtual ICollection<TimecardRow> TimeCardRows { get; set; }
它在Timecard's
构造函数中被初始化为一个HashSet
如下所示:
this.TimeCardRows = new HashSet<TimecardRow>();
我添加一个子TimecardRow
,然后调用另一个方法,这是它的确切实现,并将它从GetTimeCardForPerson
返回的同一个GetTimeCardForPerson
实例传递给它:
public void SaveTimecard(Timecard timeCard)
{
timecardContext.Entry(timeCard).State = timeCard.TimecardId == 0
? EntityState.Added
: EntityState.Unchanged;
timecardContext.SaveChanges();
}
中通过Timecard timeCard
参数不附接到timecardContext
并具有TimecardId> 0。
我感到奇怪的是我的新TimecardRow
作为入门(timeCard.State)设置为成功保存EntityState.Unchanged
。
EntityState.Unchanged告诉我的timecardContext没有什么可以改变,不是吗? 但都是一样的,在TimecardRow
我添加插入数据库时SaveTimecard
方法被调用。
EntityState.Unchanged通知上下文Timecard实体没有任何更改。
TimecardRow是一个单独的实体,EF将单独跟踪,所以对SaveChanges的调用将插入该实体。
以上假定Timecard在传递给Save方法时已经连接(如果它是从GetTimeCardForPerson方法返回的同一个实例)。
如果在Save方法中使用Id检查来处理分离和连接的实体,除非它的id为0,否则最好是保持独立状态?
链接地址: http://www.djcxy.com/p/5741.html上一篇: Surprised that Entity Framework is saving a detached Entity correctly