本文介绍了无法从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查询的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!