jjzjj

IQueryable

全部标签

C#、Linq2Sql : Is it possible to concatenate two queryables into one?

我有一个可查询的,我在其中使用了各种Where和WhereBetween将集合缩小到特定集合的语句。现在我需要添加一种Where||WhereBetween。换句话说,我不能像到目前为止那样将它们链接在一起,因为那样可以用作And。那么,我该怎么做呢?我看到两种可能性:创建两个可查询对象,一个使用Where,另一个使用WhereBetween。然后连接它们。不知道这是否可能?此外,虽然不是我的特殊情况,但你很可能会得到重复项......以某种方式将Where表达式和在WhereBetween中创建的表达式与某种Or合并。第一个,如前所述,我什至不确定是否可能。如果是的话,我不太确定这是

c# - 如何针对集合调用 Expression<Func<Entity, bool>>

我有一个从存储库模式定义存储库的接口(interface):interfaceIRepository{ListGetAllCustomers(Expression>expression);}我已经在EntityFramework上实现了它:classEntityFrameworkRepository{publicListGetAllCustomers(Expression>expression){returnDBContext.Customers.Where(expression).ToList();}}这似乎工作得很好,它允许我做类似的事情:varcustomers=entityFr

c# - 在 Entity Framework 中组合表达式而不是使用多个查询

我有以下通用查询(可能已经应用了选择):IQueryablequeryable=DBSet.AsQueryable();然后是Provider类,如下所示:publicclassProvider{publicExpression>Condition{get;set;}[...]}Condition可以按以下方式为每个实例定义:Condition=entity=>entity.Id==3;现在我想选择所有Provider实例,这些实例的Condition至少被DBSet的一个实体满足:Listproviders=[...];varmatchingProviders=providers.W

c# - 从 IQueryable<T> 中删除 OrderBy

我有一个分页API,可以返回用户请求的行,但一次只能返回这么多行,而不是整个集合。API按设计工作,但我必须计算可用记录的总数(用于正确的页面计算)。在API中,我使用Linq2Sql,并且在最终发出请求之前我使用IQueryable进行了大量工作。当我去获取计数时,我调用类似:totalRecordCount=queryable.Count();生成的SQL仍然很有趣,但它也添加了一个不必要的OrderBy,这使得查询非常昂贵。execsp_executesqlN'SELECTCOUNT(*)AS[value]FROM(SELECTTOP(1)NULLAS[EMPTY]FROM[db

c# - IQueryable<T> 按 ID 列表过滤

假设我们有一个IQueryable.Where子句可以按单个ID值过滤,但我如何返回IQueryable基于ID列表?[TestMethod]publicvoidTestIQueryableWithList(){intID1=1;ListIDs=newList{1,3,4,8};using(vardb=newSellooEntities()){//worksfineassinglevaluevariq=db.tblSearches.Where(x=>x.seaUserId==ID1);//howcanidoittocheckforalltheIDs??foreach(intIDinID

c# - 在 EF Core 2.0 中动态访问表

我正在使用System.Linq.Dynamic.Core将lambda表达式动态添加到EF中的查询。我还希望能够按名称选择表格。我找到了这个答案:https://stackoverflow.com/a/28101268/657477但它在asp.netcore2.0中不起作用。我不能使用DbSet我必须使用DbSet它在错误消息中说。我希望能够做到db.GetTable("Namespace.MyTable").Where(...)我该怎么做? 最佳答案 首先你需要从名称中获取实体的类型(如果你有类型,直接使用它)。您可以为此使用

c# - AutoMapper 无法将 TestDbAsyncEnumerable 转换为 IQueryable

我已经实现了来自https://msdn.microsoft.com/en-us/library/dn314429(v=vs.113).aspx的TestDbAsync伪造并且我希望能够在调用AsyncEF方法(ToListAsync、CountAsync等)之前使用AutoMapper投影到不同的类型。我在ProjectionExpression.To中得到一个转换异常抛出异常的示例代码。_userRepository.GetAll().OrderBy(x=>x.Id).ProjectTo.ToListAsync();这在非测试场景中工作正常,但是当我使用TestDbAsyncEnu

c# - 如果我在未定义为任务的 IQueryable 上使用 await + ToListAsync() 是否正确

我正在使用带有EF-6的asp.netMVC-5,我不确定使用await+ToListAsync是否有效。例如,我有以下返回IQueryable的存储库方法:-publicIQueryablegetAllScanEmailTo(){returnt.TSets.Where(a=>a.Name.StartsWith("ScanEmail"));}我这样调用它:-varemailsTo=awaitrepository.getAllScanEmailTo().ToListAsync();一开始,我以为我会得到一个错误,因为我正在使用“等待”一个未定义为任务的方法,但上面的方法运行良好,所以有人

c# - 为 EntitySet<T>、IQueryable<T> 和 IEnumerable<T> 创建可重用谓词

在我的LINQtoSQL设置中,我有各种表,这些表映射到基本上支持相同接口(interface)以支持版本控制的类,即publicinterfaceIValid{int?validTo{get;}intvalidFrom{get;}}LINQtoSQL类派生自此接口(interface),如下所示:publicpartialclassrepresentationRevision:IValid{}现在我想定义一种DRY(不要重复自己)过滤方式EntitySet,IEnumerable和IQueryable以便生成的列表对特定修订版有效。我试过这样做:publicstaticclassEx

c# - 访问 IQueryable 后面的 DataContext

是否可以访问IQueryable后面的DataContext对象?如果是,怎么做到的? 最佳答案 DataContext特定于LINQtoSQL,所以您大概是在谈论LINQtoSQL查询?如果是这样,则没有安全的方法来执行此操作-您必须诉诸黑客,例如使用反射来检索底层DataQuery对象的私有(private)“上下文”字段:staticDataContextGetContext(IQueryableq){if(!q.GetType().FullName.StartsWith("System.Data.Linq.DataQuery