c# - Linq 到 SQL : Simple group by generating many SQL queries

标签 c# mysql linq linq-to-sql

这是 C#/Linq:

Fbc_tickets.GroupBy(t => t.Fbt_household_id)

LinqPad 告诉我这正在被翻译成 (MySQL):

SELECT t0.fbt_household_id
FROM fbc_ticket AS t0
GROUP BY t0.fbt_household_id

SELECT t0.fbc_ticket_id, t0.fbt_client_id, ...
FROM fbc_ticket AS t0
WHERE ((t0.fbt_household_id IS NULL AND @n0 IS NULL) OR (t0.fbt_household_id = @n0))
-- n0 = [1]

SELECT t0.fbc_ticket_id, t0.fbt_client_id, ...
FROM fbc_ticket AS t0
WHERE ((t0.fbt_household_id IS NULL AND @n0 IS NULL) OR (t0.fbt_household_id = @n0))
-- n0 = [2]

...

为什么它会生成所有这些查询?我希望有更类似于的东西

SELECT * FROM fbc_ticket GROUP BY fbt_household_id

就是这样......

fbt_household_id 是一个无符号整数且不可为空。

最佳答案

我在 linq-to-sql 中经常看到这种情况。首先进行查询以获取分组键,然后对每个键进行查询以填充组。我不知道为什么要这样实现,但恐怕你对此无能为力。 Entity Framework 在这个特定领域(而不是其他领域)要聪明得多。

当我连接到现有的 linq-to-sql 上下文时,Linqpad 也会执行此操作(并且不要让它动态创建上下文),因此我认为它与 Linqpad 没有任何关系。

关于c# - Linq 到 SQL : Simple group by generating many SQL queries,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12645767/

相关文章:

c# - Unity 中通过 WebRTC 进行 P2P 数据传输

c# - 组合或连接从单独的 XML 文件中读取的对象的最有效方法

C# 类型 _ 没有定义构造函数

php - 使用 PHP 通过 mysql 在多个表中按一个字段选择行并按另一个字段排序

php - 我应该对没有用户输入的查询使用bindParam吗?

c# - 无法创建类型为 'System.Int32[]' 的空常量值。

c# - 如何保存拖动项目的位置

c# - Lerp 颜色的 alpha 值

c# - 从 C# 错误调用的 PowerShell cmdlet Install-WindowsFeature 未在命令集合中列出

mysql - 如何对连接表中的多列求和[添加]