Odata Query can#39;t be translated from Linq(无法从Linq转换Odata查询)
问题描述
我正在尝试使OData查询在.Net Core 3.1上工作 在.Net Core 2.1上一切运行正常 现在升级后显示
System.InvalidOperationException:LINQ表达式‘$it’无法 被翻译。将查询重写为可以 转换,或通过插入 调用AsEnumerable()、AsAsyncEnumerable()、ToList()或 ToListAsync()。
我有两张表
public class WorkItem
{
[Key]
[Required]
public Guid Id { get; set; }
[Required]
[MaxLength(128)]
public string Name { get; set; }
public IEnumerable<Resource> Resources { get; set; }
public WorkItem(string name)
{
Name = name;
}
}
public class Resource
{
[Key]
[Required]
public Guid Id { get; set; }
[Required]
public Guid WorkItemId { get; set; }
[Required]
[MaxLength(128)]
public string Name { get; set; }
[Required]
public Guid StorageId { get; set; }
public DateTime CreateDate { get; set; }
public ContentItem ContentItem { get; set; }
public AppItem AppItem { get; set; }
public Resource(Guid workItemId, string name, Guid storageId)
{
WorkItemId = workItemId;
Name = name;
StorageId = storageId;
}
}
然后请求URI如下所示:
_appItemsBaseUri/response.Id?$expand=Resources($filter=Name eq‘test2.pdf’)";
成功命中接口,过滤数据,创建Odata SingleResult。如果我展开它,我可以看到有一个工作项和资源在那里。
var dto = dataset.Where(workItemId==responseId);
var res = SingleResult.Create(dto);
但当我返回时,它不会从API返回
// This results in the error mentioned above.
return Ok(res);
我能让它工作的唯一方法就是这样使用它...
var dto = dataset.Where(workItemId==responseId);
var res = SingleResult.Create(dto).Queryable.FirstOrDefault();
return Ok(res)
我正在使用以下程序包版本
Microsoft.AspNetCore.Odata 7.3.0
Microsoft.EntityFrameworkCore 3.1.0
请告诉我如何才能返回数据而不必执行客户端评估(.Queryable.FirstOrDefault())? 代码需要进行客户端评估的原因是什么,因为我可以看到没有需要客户端评估的代码?
推荐答案
我遇到了同样的问题,不仅是在单个结果上,在我尝试筛选子集合时也是如此。问题似乎出在实体框架3.1.0上。看起来像是实体框架3.1.0。如果无法将查询转换为SQL查询,则将引发异常。之前,ef核心执行一个查询以获取内存中的所有数据,并在之后处理该查询。 我的解决方案是使用FirstOrDefault或ToList().AsQueryable()。但当然,如果我们在表中有大量数据,这可能会导致性能问题。
这篇关于无法从Linq转换Odata查询的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:无法从Linq转换Odata查询


- C# 中多线程网络服务器的模式 2022-01-01
- 如何用自己压缩一个 IEnumerable 2022-01-01
- 输入按键事件处理程序 2022-01-01
- Web Api 中的 Swagger .netcore 3.1,使用 swagger UI 设置日期时间格式 2022-01-01
- MoreLinq maxBy vs LINQ max + where 2022-01-01
- C#MongoDB使用Builders查找派生对象 2022-09-04
- 良好实践:如何重用 .csproj 和 .sln 文件来为 CI 创建 2022-01-01
- WebMatrix WebSecurity PasswordSalt 2022-01-01
- 在哪里可以找到使用中的C#/XML文档注释的好例子? 2022-01-01
- 带有服务/守护程序应用程序的 Microsoft Graph CSharp SDK 和 OneDrive for Business - 配额方面返回 null 2022-01-01