Ben*_*jol 10 c# linq entity-framework generated-sql
我知道这个问题,但我想做的是获得接近这个生成的SQL的东西:
select MAX(Column), MIN(Column) from Table WHERE Id = 1
Run Code Online (Sandbox Code Playgroud)
当我尝试这个:
var query = from d in db.Table
where d.Id == 1
select new
{
min = db.Table.Max(s => s.Column),
max = db.Table.Min(s => s.Column)
};
Run Code Online (Sandbox Code Playgroud)
生成的sql如下所示:
SELECT
[Extent1].[Id] AS [Id],
[GroupBy1].[A1] AS [C1],
[GroupBy2].[A1] AS [C2]
FROM [dbo].[Table] AS [Extent1]
CROSS JOIN (SELECT
MAX([Extent2].[Column]) AS [A1]
FROM [dbo].[Table] AS [Extent2] ) AS [GroupBy1]
CROSS JOIN (SELECT
MIN([Extent3].[Column]) AS [A1]
FROM [dbo].[Table] AS [Extent3] ) AS [GroupBy2]
WHERE ([Extent1].[Id] = 1) AND (1 IS NOT NULL)
Run Code Online (Sandbox Code Playgroud)
我也试过这个:
var query = from d in db.Table
where d.Id == 1
group d by d.Id into grp
let min = grp.Min(s => s.Column)
let max = grp.Max(s => s.Column)
select new { min, max };
Run Code Online (Sandbox Code Playgroud)
这给了这个:
SELECT
[Project2].[Id] AS [Id],
[Project2].[C1] AS [C1],
[Project2].[C2] AS [C2]
FROM ( SELECT
[Project1].[C1] AS [C1],
[Project1].[Id] AS [Id],
(SELECT
MAX([Extent2].[Column]) AS [A1]
FROM [dbo].[Table] AS [Extent2]
WHERE ([Extent2].[Id] = 1) AND (1 IS NOT NULL) AND ([Project1].[Id] = [Extent2].[Id])) AS [C2]
FROM ( SELECT
[GroupBy1].[A1] AS [C1],
[GroupBy1].[K1] AS [Id]
FROM ( SELECT
[Extent1].[Id] AS [K1],
MIN([Extent1].[Column]) AS [A1]
FROM [dbo].[Table] AS [Extent1]
WHERE ([Extent1].[Id] = 16) AND (16 IS NOT NULL)
GROUP BY [Extent1].[Id]
) AS [GroupBy1]
) AS [Project1]
) AS [Project2]
Run Code Online (Sandbox Code Playgroud)
它们都可以工作,性能受到的影响可能微乎其微,所以它主要是美学:
两个生成的查询都伤害了我的眼睛.
Bas*_*ers 11
8年后,我们来了!但还是有答案!
db.Table
.Where(d => d.Id == 1)
.GroupBy(_ => 1,
(_, records) => new
{
Max = records.Max(r => r.Column),
Min = records.Min(r => r.Column)
});
Run Code Online (Sandbox Code Playgroud)
这导致:
SELECT MAX([o].[Column]) AS [Max], MIN([o].[Column]) AS [Min]
FROM [Table] AS [o]
WHERE [o].[Id] = 1
GO
Run Code Online (Sandbox Code Playgroud)
请注意,在“Group by 1 ”中,1 与查询中的 ID 无关!
尝试删除let语句 - 以下产生预期结果:
var q = from d in db.Table
where d.Id == 1
group d by d.Id into g
select new
{
Id = g.Key, // shown for illustrative purposes
ColumnMin = g.Min( gi => gi.Column ),
ColumnMax = g.Max( gi => gi.Column )
};
var result = q.SingleOrDefault();
Run Code Online (Sandbox Code Playgroud)
结果SQL:
SELECT
[GroupBy1].[K1] AS [Id],
[GroupBy1].[A1] AS [C1],
[GroupBy1].[A2] AS [C2]
FROM ( SELECT
[Extent1].[Id] AS [K1],
MIN([Extent1].[Column]) AS [A1],
MAX([Extent1].[Column]) AS [A2]
FROM [dbo].[Table] AS [Extent1]
WHERE 1 = [Extent1].[Id]
GROUP BY [Extent1].[Id]
) AS [GroupBy1]
Run Code Online (Sandbox Code Playgroud)
小智 -4
var query = from d in db.Table
where d.Id == 1
select
{
d.Max(t =>t.yourColName),
d.Min(t =>t.yourColName)
};
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
9503 次 |
| 最近记录: |