技术开发 频道

LINQ to SQL公共基类

  【IT168 技术文档】备注:本文的源代码例子,使用的数据库为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>();
}
0
相关文章