Linq to SQL:通过生成许多SQL查询来实现简单组

时间:2012-09-28 18:54:57

标签: 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是unsigned int且不可为空。

1 个答案:

答案 0 :(得分:2)

我在linq-to-sql中一直看到这个。首先是获取分组键的查询,然后是每个键的查询以填充组。我不知道为什么会以这种方式实现,但是你可以做的很少,我很害怕。实体框架在这个特定领域(而不是其他领域)更加智能。

当我连接到现有的linq-to-sql上下文时,Linqpad也会这样做(并且不要让它动态创建上下文),所以我认为它与Linqpad没有任何关系。