WEB开发网
开发学院数据库MSSQL Server LINQ to SQL公共基类 阅读

LINQ to SQL公共基类

 2008-09-04 10:02:00 来源:WEB开发网   
核心提示: 例如,我们根据另外一个DataContext中已修改的实体更新记录:public void Update(TEntity changedEntity){InitDataContext();try{m_context.GetTable<TEntity>().Attach(chan

例如,我们根据另外一个DataContext中已修改的实体更新记录:

  public void Update(TEntity changedEntity)
  {
  InitDataContext();
  try
  {
  m_context.GetTable<TEntity>().Attach(changedEntity, true);
  m_context.SubmitChanges();
  }
  catch (ChangeConflictException)
  {
  m_context.ChangeConflicts.ResolveAll(RefreshMode.KeepCurrentValues);
  m_context.SubmitChanges();
  }   
  }

这样的实现看起来很美,却远远不够。我们不能附加一个修改过的实体,除非该实体所对应的表中具有TimeStamp列(或者主键字段的IsVersion为true)。因此,我们需要在数据库中添加列,使其类型为Timestamp,或者在LINQ to SQL设计器中将ID属性的IsVersion属性设置为true。我的建议是为所有数据表创建一个TimeStamp列,它可以提高系统的性能,因为在处理并发的时候,系统只需要检查主键和TimeStamp是否有变化,而不需要检查所有的字段。

事实上,我们也可以通过泛型传递原始的实体值,这种方法就不需要为每个表添加TimeStamp列,方法是使用Action<T> 委托,代码段如下所示:

  public void Update(TEntity originalEntity, Action<TEntity> update)
  {
  InitDataContext();
  try
  {
  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

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