如何简单实现自定义LINQ提供器

今天就跟大家聊聊有关如何简单实现自定义LINQ提供器,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

创新互联公司是一家专业提供围场企业网站建设,专注与成都网站建设、网站制作H5开发、小程序制作等业务。10年已为围场众多企业、政府机构等服务。创新互联专业网站制作公司优惠进行中。

工欲善其事,必先利其器。这个道理不论是传统的制造业还是如今的软件开发业,都是放之于四海皆准的道理。就拿自定义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基类:

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

看完上述内容,你们对如何简单实现自定义LINQ提供器有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注创新互联行业资讯频道,感谢大家的支持。


当前名称:如何简单实现自定义LINQ提供器
当前地址:http://csdahua.cn/article/pisgsd.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流