Linq 查询 与方法调用

通常,使用linq查询时需要一个实现IQueryable<T> 的查询对象

public class DataA<T> : IQueryable<T> {....}

之后通过

var q = from c in new DataA<int> where c > 0 select new { a = c.ToString };

进行查询,使用IQueryProvider 收集用户输入的表达式进行处理。

但是查询本身实际上只关注查询对象上有无可用的 linqmethod(Select,Where.....).

如下,定义一个泛型对象

public class Data<T> { public Data<TResult> Select< TResult>( Expression<Func<T, TResult>> selector) { return new Data<TResult>; } public Data<T> Where ( Expression<Func<T,bool>> f) { return this; } }

只要保证Data上拥有与linq方法相同的实例方法,(Select,Where...),

我们依然可以使用相同的 linq 语法进行查询:

var q = from c in new DataA<int> where c > 0 select new { a = c.ToString };

结论: linq 查询语法与查询对象的类型无关,只会检查查询对象上有无名称、方法签名一致的方法(实例方法或扩展方法)。

IQueryable,IQueryProvider 在linq查询中不是必须的。

顺便说一下 ,个人认为, orm中最好不要使用IQueryable 这些,容易造成方法污染, 而且linq查询语法是固定的,无法扩展或限制。

Orm中最好直接使用 各种查询方法,更加灵活一些。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值