IQueryable 和 IEnumerable(二)

63 篇文章 0 订阅
20 篇文章 0 订阅

IQueryable 和 IEnumerable的扩展方法

一 

我们从ef的DbSet<T>看起来,我们看到他继承了IQueryable<T> 和 IEnumerable<T>

 

写了个例子,分别传入Expression<Func<T,bool>>和Func<T,bool>

static void Main(string[] args)
        {
            Test<Users> ut = new Test<Users>();
            var q = ut.Find1(x => x.id == 1);
            var v = ut.Find2(x => x.id == 1);


            Console.ReadKey();
        }

        public class Test<T> where T:class
        {
            // EF
            Entities dbEF = new Entities();
            public virtual T Find1(Expression<Func<T, bool>> where1)
            {
                T _entity = dbEF.Set<T>().FirstOrDefault<T>(where1);
                return _entity;
            }

            public virtual T Find2(Func<T, bool> where2)
            {
                T _entity = dbEF.Set<T>().FirstOrDefault<T>(where2);
                return _entity;
            }
        }

查看运行结果:结果是一致的

 

我们看看他们的扩展实现:

Queryable

我们看到,其实通过Queryable扩展,我们传入了Expression<Func<T,bool>>

看一下sqlprofile

结果:查询时,通过Expression,我们直接组装成了带条件的sql语句进行查询。

 

Enumerable

我们看到,其实通过Enumerable扩展,我们传入了Func<T,bool>

看一下sqlprofile

结果:查询时,通过Func,我们直接查询了全表。

然后在全部结果加载到缓存后,我们才进行了id==1的筛选

 

所以结果很明显:

IQueryable 通过Expression拼接表达式树,然后组装sql语句进行滤查查询

IEnumerable 直接查询后,通过传入的Func方法,在缓存里进行过滤查询

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值