What instantiate-able types implementing IQueryabl

2019-02-16 04:08发布

Within the context of C# on .Net 4.0, are there any built-in objects that implement IQueryable<T>?

3条回答
走好不送
2楼-- · 2019-02-16 04:36

Well, your question is kinda weird... but I believe that if you look at an interface in Reflector, it will give you a list of implementers in the loaded assemblies.

As a disclaimer I have not used Reflector since it went pay-for-play so I might be wrong.

查看更多
Root(大扎)
3楼-- · 2019-02-16 04:50

IQueryable objects are produced by Queryable Providers (ex. LINQ to SQL, LINQ to Entities/Entity Framework, etc). Virtually nothing you can instantiate with new in the basic .NET Framework implements IQueryable.

IQueryable is an interface designed to be used to create Queryable providers, which allow the LINQ library to be leveraged against an external data store by building a parse-able expression tree. By nature, Queryables require a context - information regarding what exactly you're querying. Using new to create any IQueryable type, regardless of whether it's possible, doesn't get you very far.

That being said, any IEnumerable can be converted into an IQueryable by using the AsQueryable() extension method. This creates a superficially-similar, but functionally very different construct behind the scenes as when using LINQ methods against a plain IEnumerable object. This is probably the most plentiful source of queryables you have access to without setting up an actual IQueryable provider. This changeover is very useful for unit-testing LINQ-based algorithms as you don't need the actual data store, just a list of in-memory data that can imitate it.

查看更多
虎瘦雄心在
4楼-- · 2019-02-16 04:50

EntityCollection does, as does EnumerableQuery.

Not that I think either of these is going to get you anywhere. To help, we need to know what you are really trying to solve. If you are writing a LINQ provider, you should read this: http://msdn.microsoft.com/en-us/library/bb546158.aspx.

They recommend writing your own implementation.

查看更多
登录 后发表回答