gpt4 book ai didi

c# - 在单个执行点运行多个 IQueryable

转载 作者:行者123 更新时间:2023-11-30 17:36:48 24 4
gpt4 key购买 nike

我有一个方法,当传递一个参数时返回一个 IQueryable。总之,这个方法用于生成 13 个独立的 IQueryable。

我需要的最终结果是在 IQueryables 中获得 13 个不同的记录集计数,但是为了使它比我当前的实现更有效,即:

var foo = iQueryableObject.Count();
var bar = iSecondQueryableObject.Count();

我想在单个执行点运行 SQL 服务器上的所有计数,所以理论上是这样的:

var foobar = new IQueryable<object>[]
{
iQueryableObject.DeferredExecutionCount(),
iSecondQueryableObject.DeferredExecutionCount()
}.ToList();

有人对我如何实现这一点有任何想法吗?

最佳答案

您必须针对实际数据库进行尝试,但您可以使用 GroupByUnion(或 Concat)来实现此目的。

考虑以下 POCO(您的 EF 实体):

class Thing
{
public string One { get; set;}
}

class Thang
{
public string Two { get; set;}
}

现在你的查询:

var foo= Things
.Where(t => t.One == "One") //or whatever your filtering condition
.GroupBy(t => t.One)
.Select(t => new {Key = "FirstQuery", Count = t.Count()});

var bar = Thangs
.Where(t => t.Two == "Two")
.GroupBy(t => t.Two)
.Select(t => new {Key = "SecondQuery", Count = t.Count()});

var deferredCounts = foo.Concat(bar).ToList();

关于c# - 在单个执行点运行多个 IQueryable,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38970186/

24 4 0