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

LINQ to SQL公共基类

 2008-09-04 10:02:00 来源:WEB开发网   
核心提示:备注:本文的源代码例子,使用的数据库为SQL Server 2005下的Northwind示范数据库,LINQ to SQL公共基类,同时为相关表建立了TimeStamp列,LINQ是Visual Studio 2008中提供的一系列新特性,我们可以实现Where方法,通过传递一个Lambda表达式找到我们希望获得的结

备注:本文的源代码例子,使用的数据库为SQL Server 2005下的Northwind示范数据库,同时为相关表建立了TimeStamp列。

LINQ是Visual Studio 2008中提供的一系列新特性,用以扩展C#或者Visual Basic语言,提供了强有力的查询能力。作为LINQ的组成部分,LINQ to SQL提供了将关系数据作为对象处理的运行时架构。从某种程度上说,它相当于是微软提供的类似于NHibernate和Castle之类的ORM工具或框架。当我们需要对数据库进行访问时,LINQ to SQL常常会成为我们的首选。

在LINQ to SQL中,关系数据库数据模型中的所有变量都是强类型的,它提供了编译时验证以及智能感知等优点。我们可以使用查询表达式(包括查询语法和方法语法)从数据库中获取数据。

然而,强类型并不利于对数据操作进行抽象,因此,开发人员就不得不为每个实体对象定义特定的类,从而导致大量的重复代码。如果我们可以实现一个共同的基类,封装公共的数据操作,例如Select、Where、Add、Update和Delete,这对于开发N层应用程序而言,是非常有用的。

所幸,利用泛型可以帮助我们实现这一目标。方法是调用DataContext的GetTable<T>()方法。例如,我们可以实现Where方法,通过传递一个Lambda表达式找到我们希望获得的结果:

  public IList<TEntity> Where(Func<TEntity, bool> predicate)
  {
  InitDataContext();
  return m_context.GetTable<TEntity>().Where(predicate).ToList<TEntity>();
  }

这很简单,我们甚至可以利用动态查询,暴露一些方法去接收条件表达式:

  public static class DynamicQueryable
  {
  public static IQueryable<T> Where<T>(this IQueryable<T> source, string predicate, params object[] values)
  {
  return (IQueryable<T>)Where((IQueryable)source, predicate, values);
  }
  public static IQueryable Where(this IQueryable source, string predicate, params object[] values)
  {
  if (source == null) throw new ArgumentNullException("source");
  if (predicate == null) throw new ArgumentNullException("predicate");
  LambdaExpression lambda = DynamicExpression.ParseLambda(source.ElementType, typeof(bool), predicate, values);
  return source.Provider.CreateQuery(
  Expression.Call(
  typeof(Queryable), "Where",       
  new Type[] { source.ElementType },
  source.Expression, Expression.Quote(lambda)));
  }
  }
  public IList<TEntity> Where(string predicate, params object[] values)
  {
  InitDataContext();
  return m_context.GetTable<TEntity>().Where(predicate, values).ToList<TEntity>();
  }

1 2 3 4 5 6  下一页

Tags:LINQ to SQL

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