使用 LinqExtender 轻松实现自定义 LINQ 提供器

  • 朱永光

2008 年 3 月 3 日

话题:.NETDevOps语言 & 开发架构

随着.NET 3.5 的正式发布,LINQ 提供器的实现如雨后春笋般不断涌现。而要开发自己的 LINQ 提供器还是需要花费一定的精力的,但 Mehfuz Hossain 通过他的开源项目——LinqExtender,让大家可以轻松的开发自己的自定义 LINQ 提供器。

Mehfuz Hossain 在他的LinqExtender 介绍文章中,对 LinqExtender 作了这样的介绍:

LinqExtender 暴露了如下这样一个模型,让开发人员当创建一个自定义提供器的只用关注于应用程序逻辑,而不是查询的内部机理。它位于 LINQ 框架和自定义提供器之间。

LinqExtender 帮助我们完成了大量表达式解析和处理的工作,这样,我们无需借助 Reflection 这样的函数库就能实现自己的自定义 LINQ 提供器。LinqExtender 主要提供了 2 个基类来帮助开发自定义 LINQ 提供器:QueryObjectBase 和 Query

Mehfuz Hossain 为了介绍 LinqExtender 的用法,还给出了一个简单自定义 LINQ 提供器实现——OpenLinqToSql。OpenLinqToSql 的基本实现如下:

实体类需要继承于 QueryObjectBase 基类:

class Book : QueryObjectBase  

    {  

        [LinqVisible, Identity]  

        public int? Id { get; set; }  

        [LinqVisible]  

        public string Author { get; set; }   

        [LinqVisible]  

        public string Title { get; set; }   

        [LinqVisible]  

        public string ISBN { get; set; }   

        [LinqVisible]  

        public DateTime? LastUpdated {get; set;}   

        public override bool IsNew   

        {  

            get  

            {  

                return Id == null;  

            }  

        }  

    }

自定义 LINQ 提供器的核心类,需要继承于 Query基类:

public class SqlQuery : Query where T : QueryObjectBase  

{  

....  

....  

}

要实现对 SQL 的处理需要按照如下的逻辑进行编码:

if (bucket.ItemsToTake != null)  

{  

// 1.Build Select statement using WITH   

}  

else

{  

// 2.General select statement followed by order by , if any   

}  

// 3. Run query and fill IModify collection.

LinqExtender 及其 OpenLinqToSql 的源代码可以在这里下载到。另外,除了 OpenLinqToSql 这个简单示例外,Mehfuz Hossain 还基于 LinqExtender 开发了一个更酷的示例——LINQ to Flickr

使用 LinqExtender 虽然可以帮助开发人员轻松的实现自己的自定义 LINQ 提供器,但是它还不那么成熟和完备,如目前的 1.3 版本缺乏对 Group 和 Join 等子句的支持;同时要求实体类继承于 QueryObjectBase 基类也是一个不小的弱点。

.NETDevOps语言 & 开发架构