- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我不确定是什么时候,但我读了一篇关于此的文章,其中指出 Skip(1).Any()
的用法优于 Count()
使用 Entity Framework 时的同情心(我可能记错了)。在看到生成的 T-SQL 代码后,我不确定这一点。
这是第一个选项:
int userConnectionCount = _dbContext.HubConnections.Count(conn => conn.UserId == user.Id);
bool isAtSingleConnection = (userConnectionCount == 1);
这会生成以下合理的 T-SQL 代码:
SELECT
[GroupBy1].[A1] AS [C1]
FROM ( SELECT
COUNT(1) AS [A1]
FROM [dbo].[HubConnections] AS [Extent1]
WHERE [Extent1].[UserId] = @p__linq__0
) AS [GroupBy1]
这是另一个选项,据我所知这是建议的查询:
bool isAtSingleConnection = !_dbContext
.HubConnections.OrderBy(conn => conn.Id)
.Skip(1).Any(conn => conn.UserId == user.Id);
这是为上述 LINQ 查询生成的 T-SQL:
SELECT
CASE WHEN ( EXISTS (SELECT
1 AS [C1]
FROM ( SELECT [Extent1].[Id] AS [Id], [Extent1].[UserId] AS [UserId]
FROM ( SELECT [Extent1].[Id] AS [Id], [Extent1].[UserId] AS [UserId], row_number() OVER (ORDER BY [Extent1].[Id] ASC) AS [row_number]
FROM [dbo].[HubConnections] AS [Extent1]
) AS [Extent1]
WHERE [Extent1].[row_number] > 1
) AS [Skip1]
WHERE [Skip1].[UserId] = @p__linq__0
)) THEN cast(1 as bit) WHEN ( NOT EXISTS (SELECT
1 AS [C1]
FROM ( SELECT [Extent2].[Id] AS [Id], [Extent2].[UserId] AS [UserId]
FROM ( SELECT [Extent2].[Id] AS [Id], [Extent2].[UserId] AS [UserId], row_number() OVER (ORDER BY [Extent2].[Id] ASC) AS [row_number]
FROM [dbo].[HubConnections] AS [Extent2]
) AS [Extent2]
WHERE [Extent2].[row_number] > 1
) AS [Skip2]
WHERE [Skip2].[UserId] = @p__linq__0
)) THEN cast(0 as bit) END AS [C1]
FROM ( SELECT 1 AS X ) AS [SingleRowTable1];
这里哪一个是正确的方法?这两者之间有很大的性能差异吗?
最佳答案
查询性能取决于很多因素,例如存在的索引、实际数据、关于存在数据的统计信息的陈旧程度等。SQL 查询计划优化器会查看这些不同的指标以提出高效的查询计划。因此,任何说查询 1 总是比查询 2 或相反的直接答案都是不正确的。
就是说,我在下面的回答试图解释文章的立场,以及 Skip(1).Any()
如何(稍微)比 Count() > 1
。第二个查询虽然更大而且几乎不可读,但看起来可以以高效的方式进行解释。同样,这取决于上述事项。这个想法是,在 Count()
的情况下,数据库必须查看更多的行数才能计算出结果。在计数情况下,假设存在所需的索引(Id 上的聚簇索引以使第二种情况下的 OrderBy 有效),数据库必须经过计数行数。在第二种情况下,它必须经过最多两行才能得出答案。
让我们的分析更加科学,看看我的上述理论是否站得住脚。为此,我正在创建一个虚拟客户数据库。客户类型如下所示,
public class Customer
{
public int ID { get; set; }
public string Name { get; set; }
public int Age { get; set; }
}
我正在使用这段代码为数据库添加大约 10 万行随机行(我真的必须证明这一点),
for (int j = 0; j < 100; j++)
{
using (CustomersContext db = new CustomersContext())
{
Random r = new Random();
for (int i = 0; i < 1000; i++)
{
Customer c = new Customer
{
Name = Guid.NewGuid().ToString(),
Age = r.Next(0, 100)
};
db.Customers.Add(c);
}
db.SaveChanges();
}
}
示例代码 here .
现在,我要使用的查询如下,
db.Customers.Where(c => c.Age == 26).Count() > 1; // scenario 1
db.Customers.Where(c => c.Age == 26).OrderBy(c => c.ID).Skip(1).Any() // scenario 2
我已经启动了 SQL 探查器来捕获查询计划。捕获的计划如下所示,
查看上图中方案 1 的估计成本和实际行数。
在下图中查看方案 2 的估计成本和实际行数。
根据最初的猜测,与 Count 情况相比,Skip 和 any 情况下的估计成本和行数要少。
除了所有这些分析,正如许多其他人之前评论的那样,这些不是您应该尝试在代码中进行的性能优化。诸如此类的事情会以非常小的(我会说不存在的)性能优势损害可读性。我做这个分析只是为了好玩,绝不会以此作为选择场景 2 的基础。我会测量并查看执行 Count()
是否真的会伤害更改代码以使用 跳过()。任何()
。
关于c# - Count 或 Skip(1).Any() 我想知道是否有超过 1 条记录的地方 - Entity Framework ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16193331/
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
操作无法完成。 Places API 库中发生内部错误。如果您认为此错误代表错误,请使用我们社区和支持页面 (https://developers.google.com/places/support)
我正在尝试在我的项目中使用 google places,我将其设置在 fragment 中而不是 Activity 中,我的自动完成 fragment 在 fragment 中。但是,当我尝试搜索它时
我的目的是使用R来查询google api。 我有一个地址和名称列表(属于商店、餐馆等),我需要为每个地址和名称存储: “纬度”、“经度”、“业务类型” 我的想法是使用 google place ap
我正在寻找设置一个自动完成的谷歌地方小部件。 我有一个带有“searchFieldText”id 的输入类型文本。 这是我的 JS 代码: var inputsec = document.getEle
是否可以使用图形 API(或地址/ zip )按纬度/经度和半径获取地点?我在文档中的任何地方都看不到它 最佳答案 搜索 URL 的以下格式将返回某个位置附近的地点列表: https://graph.
我正在探索 Google API,主要是 Places API。由于对 Google Places API 的请求数限制为 100,000,因此我正在寻找方法来最大限度地减少发送到 API 的请求数。
伙计们,我在我的应用程序中有一个功能,可以使用 GetFiles 在特定目录中搜索特定文件。方法 System.IO.Directory.GetFiles(string path, string
我已经在 Laravel 5.3 上使用 where 查询成功创建了许多函数,但是这次发生了一些奇怪的事情。 public function show($id){ $artikel = Art
我正在为我的 iPhone 应用程序使用 Facebook 图形 API 来获取附近地点的列表,我使用带有一些参数的“搜索”请求。我得到的响应是一个包含以下信息的地点列表:“纬度”、“经度”、“名称”
我有一个 Android 应用程序,我在其中使用 Google map 显示附近的地方,如加油站、药店等。我正在使用 map 和地点 API。 https://maps.googleapis.com/
我是一名优秀的程序员,十分优秀!