无法从Linq转换Odata查询

Odata Query can#39;t be translated from Linq(无法从Linq转换Odata查询)
本文介绍了无法从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查询的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

DispatcherQueue null when trying to update Ui property in ViewModel(尝试更新ViewModel中的Ui属性时DispatcherQueue为空)
Drawing over all windows on multiple monitors(在多个监视器上绘制所有窗口)
Programmatically show the desktop(以编程方式显示桌面)
c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
LINQ many-to-many relationship, how to write a correct WHERE clause?(LINQ多对多关系,如何写一个正确的WHERE子句?)