`SELECT MIN(ZoneMin),MAX(ZoneMin)FROM Plant`作为LINQ to SQL

时间:2011-01-12 18:02:39

标签: .net linq linq-to-sql

从LINQ尝试时,这个相当简单的SQL查询被证明非常令人困惑。

我有一个带有Plant列的SQL表ZoneMin

我想找到列中值的最小值和最大值 T-SQL的答案很简单:

SELECT MIN(ZoneMin), MAX(ZoneMin) FROM Plant

什么是LINQ查询可以让我接触到这个(或类似的)SQL?

我在.Aggregate()和.GroupBy()上做过各种尝试而没有运气。我也看了几个看似相似的问题。

这可以通过应用于结果数组的方法简单地实现,但是当在T-SQL中如此简单时,我不需要从每个SQL行传输值。

1 个答案:

答案 0 :(得分:14)

要获得与原始查询相同的性能,您需要使用分组(通过常量来最小化影响,例如0),这样您就可以在两次中引用同一组记录相同的查询。使用表名会导致在每个引用上生成新查询。请尝试以下方法:

(from plant in db.Plants
 group plant by 0 into plants
 select new { Min = plants.Min(p => p.ZoneMin), Max = plants.Max(p => p.ZoneMin) }
).Single()

这会产生以下查询:

SELECT MIN(plants.ZoneMin), MAX(plants.ZoneMin)
FROM (SELECT 0 AS Grp, ZoneMin FROM Plants) AS plants
GROUP BY plants.Grp

在优化器完成之后,它会向您的查询发出相当于的内容,至少根据SQL Server Management Studio。