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

文/朱永光  出处/InfoQ

随着.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基类也是一个不小的弱点。

 感谢原创者的辛勤劳动,希望对您有所帮助,转载请注明原出处。
 您可能对 [Linq] 的这些文章也感兴趣:

PLINQ改名为Parallel Extensions发布
LINQ to SQL活学活用(2):躲起来别让我看见
深入浅出学Linq:Linq to SQL Table<TEntity>的获取过程
使用linq to xml 快速创建RSS
LINQ体验(2)——C# 3.0新语言特性和改进(上篇)
LINQ体验(15)——LINQ to SQL语句之用户定义函数
一个linq to sql的泛化模板
Linq to SQL Dynamic
使用 Linq 在不同类型之间转换
透过LINQSQO看LINQ内部机理