如何更简单实现自定义LINQ提供器
创始人
2024-06-06 21:21:32
0

工欲善其事,必先利其器。这个道理不论是传统的制造业还是如今的软件开发业,都是放之于四海皆准的道理。就拿自定义LINQ提供器来说吧,如今的发展也是如新月异。

随着.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基类:

  1. class Book : QueryObjectBase    
  2.     {    
  3.         [LinqVisible, Identity]    
  4.         public int? Id { getset; }    
  5.         [LinqVisible]    
  6.         public string Author { getset; }      
  7.         [LinqVisible]    
  8.         public string Title { getset; }      
  9.         [LinqVisible]    
  10.         public string ISBN { getset; }      
  11.         [LinqVisible]    
  12.         public DateTime? LastUpdated {getset;}      
  13.         public override bool IsNew      
  14.         {    
  15.             get    
  16.             {    
  17.                 return Id == null;    
  18.             }    
  19.         }    
  20.     } 

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

  1. public class SqlQuery : Query where T : QueryObjectBase    
  2. {    
  3. ....    
  4. ....    

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

  1. if (bucket.ItemsToTake != null)    
  2. {    
  3. // 1.Build Select statement using WITH      
  4. }    
  5. else   
  6. {    
  7. // 2.General select statement followed by order by , if any      
  8. }    
  9. // 3. Run query and fill IModify collection. 
使用LinqExtender虽然可以帮助开发人员轻松的实现自己的自定义LINQ提供器,但是它还不那么成熟和完备,如目前的1.3版本缺乏对Group和Join等子句的支持;同时要求实体类继承于QueryObjectBase基类也是一个不小的弱点。

【编辑推荐】

  1. LINQ——语言级集成查询入门指南
  2. LINQ查询的目的与实现手段
  3. LINQ查询表达式深入剖析
  4. 实例二:绑定到LINQ查询的结果
  5. LINQ的演变及其对C#设计的影响

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...