Microsoft表示实体框架核心 2.1 会向服务器生成GROUPBY
语句。我有一个使用实体框架核心 2.1.4 的 Azure 函数,但仍然得到:
Microsoft.EntityFrameworkCore.Query:警告:无法翻译 LINQ 表达式 'Sum()',将在本地进行计算。
Microsoft.EntityFrameworkCore.Query:警告:无法翻译 LINQ 表达式"Count()",将在本地进行计算。
我的查询是:
var q = await db.TblRainGauging5minutes
.Where(x => x.G_ID == 1)
.GroupBy(x => new { x.G_ID })
.Select(g => new {
Id = g.Key.G_ID,
Total = g.Sum(v => v.R_Value ?? 0),
Rows = g.Count()
})
.ToListAsync();
这是我的项目设置:
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFramework>netstandard2.0</TargetFramework>
<AzureFunctionsVersion>v2</AzureFunctionsVersion>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="AutoMapper.Extensions.ExpressionMapping" Version="2.0.0" />
<PackageReference Include="AutoMapper.Extensions.Microsoft.DependencyInjection" Version="6.0.0" />
<PackageReference Include="AzureFunctions.Autofac" Version="3.0.6" />
<PackageReference Include="Microsoft.EntityFrameworkCore" Version="2.1.4" />
<PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="2.1.4" />
<PackageReference Include="Microsoft.Extensions.Logging.Debug" Version="2.1.1" />
<PackageReference Include="Microsoft.NET.Sdk.Functions" Version="1.0.24" />
<PackageReference Include="Newtonsoft.Json" Version="11.0.2" />
</ItemGroup>
我的设置或代码有问题吗?也许它只是在 Azure 函数 2 中不起作用?我已经将目标框架从netstandard2.0
更改为netcoreapp2.1.4
,但我仍然遇到问题。
我能够用纯.NetCore项目,所以Azure功能不是问题。真正的问题可能是SQL服务器。当我以sql server 2012为目标时,我总是会遇到问题;但是当我以 sql Server 2016 为目标时,会显示 GROUP BY 语句,并且我不再看到警告。SQL 探查器显示相同的结果。