WEB开发网      濠靛倻鏅悵顖涚附閽樺鐎诲ù婊庡亾缁辨帗鎷呴悩鍨暠濞戞挴鍋撳ù鐘烘閸ㄥ孩绂嶉锝喰﹂柟瀛樺灣濠婃垿鎯冮崟顏嗩伇濞寸姾妫勬慨鈺呭礉濞戝磭骞㈤悹鍥у槻閸ㄥ孩绂嶉敓锟� ---闁挎洩鎷�
开发学院数据库MSSQL Server LINQ to SQL公共基类 阅读

LINQ to SQL公共基类

 2008-09-04 10:02:00 来源:WEB开发网 闁靛棴鎷�闁告垵绻愰惃顒傗偓娑欍仦缂嶏拷濠⒀呭仜閵囧洨鈧稒銇炵紞锟�闁靛棴鎷�  闁稿繗娅曢弫鐐次涘▎鎰泚闁告娲ㄥ▓鎴濐嚗椤旂厧瑙�
核心提示: 好办法,但还不是最好,LINQ to SQL公共基类(5),首先,采用这种方法,因此我通过反射调用了该字段的Clear方法,清除集合中的所有元素,我们需要为每个数据实体都定义Detach方法,这过于繁琐

好办法,但还不是最好。首先,采用这种方法,我们需要为每个数据实体都定义Detach方法,这过于繁琐。其次,我们不能用这种方法对该逻辑进行抽象。由于在基类中,我们并不知道TEntity的具体类型。此时,我们应该使用反射技术,以下是我的实现:

  private void Detach(TEntity entity)
  {
  foreach (FieldInfo fi in entity.GetType().GetFields(BindingFlags.NonPublic |BindingFlags.Instance))
  {
  if (fi.FieldType.ToString().Contains("EntityRef"))
  {
  var value = fi.GetValue(entity);
  if (value != null)
  {
  fi.SetValue(entity, null);
  }
  }
  if (fi.FieldType.ToString().Contains("EntitySet"))
  {
  var value = fi.GetValue(entity);
  if (value != null)
  {
  MethodInfo mi = value.GetType().GetMethod("Clear");
  if (mi != null)
  {
  mi.Invoke(value, null);
  }
  fi.SetValue(entity, value);
  }
  }
  }
  }

针对EntityRef<T> 字段,可以通过调用FieldInfo的SetValue方法将值赋为null,以此来移除关联。但是,对于EntitySet则不能用同样的方法,因为该字段为集合。如果设置为null,会抛出异常。因此我通过反射调用了该字段的Clear方法,清除集合中的所有元素。最后,我实现的Update方法如下所示:

  public void Update(TEntity originalEntity, Action<TEntity> update, bool hasRelationship)
  {
  InitDataContext();
  try
  {
  if (hasRelationship)
  {
   //Remove the relationship between the entitis
   Detach(originalEntity);
  }
  m_context.GetTable<TEntity>().Attach(originalEntity);
  update(originalEntity);
  m_context.SubmitChanges();
  }
  catch (ChangeConflictException)
  {
  m_context.ChangeConflicts.ResolveAll(RefreshMode.KeepCurrentValues);
  m_context.SubmitChanges();
  }   
  }

上一页  1 2 3 4 5 6 7 8  下一页

Tags:LINQ to SQL

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接